From 12c2fa47c2117f2d70da976f3cacf5cca3f46f1e Mon Sep 17 00:00:00 2001 From: Trivikram Kamat <16024985+trivikr@users.noreply.github.com> Date: Thu, 3 Dec 2020 19:56:19 +0000 Subject: [PATCH] feat: update clients as of 12/3/2020 --- clients/client-amplifybackend/.gitignore | 14 + clients/client-amplifybackend/.npmignore | 4 + .../client-amplifybackend/AmplifyBackend.ts | 852 ++ .../AmplifyBackendClient.ts | 288 + clients/client-amplifybackend/LICENSE | 201 + clients/client-amplifybackend/README.md | 6 + .../commands/CloneBackendCommand.ts | 88 + .../commands/CreateBackendAPICommand.ts | 88 + .../commands/CreateBackendAuthCommand.ts | 88 + .../commands/CreateBackendCommand.ts | 88 + .../commands/CreateBackendConfigCommand.ts | 88 + .../commands/CreateTokenCommand.ts | 88 + .../commands/DeleteBackendAPICommand.ts | 88 + .../commands/DeleteBackendAuthCommand.ts | 88 + .../commands/DeleteBackendCommand.ts | 88 + .../commands/DeleteTokenCommand.ts | 88 + .../GenerateBackendAPIModelsCommand.ts | 88 + .../commands/GetBackendAPICommand.ts | 88 + .../commands/GetBackendAPIModelsCommand.ts | 88 + .../commands/GetBackendAuthCommand.ts | 88 + .../commands/GetBackendCommand.ts | 88 + .../commands/GetBackendJobCommand.ts | 88 + .../commands/GetTokenCommand.ts | 88 + .../commands/ListBackendJobsCommand.ts | 88 + .../commands/RemoveAllBackendsCommand.ts | 88 + .../commands/RemoveBackendConfigCommand.ts | 88 + .../commands/UpdateBackendAPICommand.ts | 88 + .../commands/UpdateBackendAuthCommand.ts | 88 + .../commands/UpdateBackendConfigCommand.ts | 88 + .../commands/UpdateBackendJobCommand.ts | 88 + clients/client-amplifybackend/endpoints.ts | 81 + clients/client-amplifybackend/index.ts | 27 + clients/client-amplifybackend/models/index.ts | 1 + .../client-amplifybackend/models/models_0.ts | 2304 +++ clients/client-amplifybackend/package.json | 83 + .../protocols/Aws_restJson1.ts | 4171 ++++++ .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + .../client-amplifybackend/runtimeConfig.ts | 36 + .../client-amplifybackend/tsconfig.es.json | 12 + clients/client-amplifybackend/tsconfig.json | 31 + clients/client-appintegrations/.gitignore | 14 + clients/client-appintegrations/.npmignore | 4 + .../client-appintegrations/AppIntegrations.ts | 346 + .../AppIntegrationsClient.ts | 252 + clients/client-appintegrations/LICENSE | 201 + clients/client-appintegrations/README.md | 6 + .../commands/CreateEventIntegrationCommand.ts | 92 + .../commands/DeleteEventIntegrationCommand.ts | 90 + .../commands/GetEventIntegrationCommand.ts | 89 + ...ListEventIntegrationAssociationsCommand.ts | 95 + .../commands/ListEventIntegrationsCommand.ts | 89 + .../commands/ListTagsForResourceCommand.ts | 89 + .../commands/TagResourceCommand.ts | 89 + .../commands/UntagResourceCommand.ts | 89 + .../commands/UpdateEventIntegrationCommand.ts | 89 + clients/client-appintegrations/endpoints.ts | 81 + clients/client-appintegrations/index.ts | 12 + .../client-appintegrations/models/index.ts | 1 + .../client-appintegrations/models/models_0.ts | 515 + clients/client-appintegrations/package.json | 85 + .../protocols/Aws_restJson1.ts | 1400 ++ .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + .../client-appintegrations/runtimeConfig.ts | 36 + .../client-appintegrations/tsconfig.es.json | 12 + clients/client-appintegrations/tsconfig.json | 31 + .../client-connect-contact-lens/.gitignore | 14 + .../client-connect-contact-lens/.npmignore | 4 + .../ConnectContactLens.ts | 50 + .../ConnectContactLensClient.ts | 211 + clients/client-connect-contact-lens/LICENSE | 201 + clients/client-connect-contact-lens/README.md | 6 + ...tRealtimeContactAnalysisSegmentsCommand.ts | 102 + .../client-connect-contact-lens/endpoints.ts | 111 + clients/client-connect-contact-lens/index.ts | 6 + .../models/index.ts | 1 + .../models/models_0.ts | 310 + .../client-connect-contact-lens/package.json | 83 + .../pagination/Interfaces.ts | 7 + ...ealtimeContactAnalysisSegmentsPaginator.ts | 57 + .../protocols/Aws_restJson1.ts | 415 + .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + .../runtimeConfig.ts | 36 + .../tsconfig.es.json | 12 + .../client-connect-contact-lens/tsconfig.json | 31 + clients/client-connect/Connect.ts | 341 +- clients/client-connect/ConnectClient.ts | 33 +- .../AssociateInstanceStorageConfigCommand.ts | 9 +- .../commands/CreateInstanceCommand.ts | 3 +- .../CreateIntegrationAssociationCommand.ts | 92 + .../commands/CreateUseCaseCommand.ts | 89 + .../commands/DeleteInstanceCommand.ts | 3 +- .../DeleteIntegrationAssociationCommand.ts | 93 + .../commands/DeleteUseCaseCommand.ts | 89 + .../commands/DeleteUserCommand.ts | 3 +- .../DeleteUserHierarchyGroupCommand.ts | 3 +- .../commands/DescribeInstanceCommand.ts | 11 +- .../DescribeInstanceStorageConfigCommand.ts | 3 +- ...isassociateInstanceStorageConfigCommand.ts | 3 +- .../commands/ListInstanceAttributesCommand.ts | 3 +- .../ListInstanceStorageConfigsCommand.ts | 4 +- .../commands/ListInstancesCommand.ts | 3 +- .../ListIntegrationAssociationsCommand.ts | 93 + .../commands/ListLambdaFunctionsCommand.ts | 3 +- .../commands/ListLexBotsCommand.ts | 3 +- .../commands/ListPromptsCommand.ts | 3 +- .../commands/ListUseCasesCommand.ts | 89 + .../commands/StartContactRecordingCommand.ts | 2 +- .../StartOutboundVoiceContactCommand.ts | 2 +- .../commands/StartTaskContactCommand.ts | 88 + .../UpdateInstanceAttributeCommand.ts | 3 +- .../UpdateInstanceStorageConfigCommand.ts | 3 +- .../UpdateRoutingProfileConcurrencyCommand.ts | 3 +- .../UpdateRoutingProfileNameCommand.ts | 4 +- clients/client-connect/index.ts | 9 + clients/client-connect/models/models_0.ts | 468 +- .../ListIntegrationAssociationsPaginator.ts | 57 + .../pagination/ListUseCasesPaginator.ts | 57 + .../client-connect/protocols/Aws_restJson1.ts | 1067 +- clients/client-devops-guru/.gitignore | 14 + clients/client-devops-guru/.npmignore | 4 + clients/client-devops-guru/DevOpsGuru.ts | 720 + .../client-devops-guru/DevOpsGuruClient.ts | 306 + clients/client-devops-guru/LICENSE | 201 + clients/client-devops-guru/README.md | 6 + .../commands/AddNotificationChannelCommand.ts | 90 + .../commands/DescribeAccountHealthCommand.ts | 91 + .../DescribeAccountOverviewCommand.ts | 91 + .../commands/DescribeAnomalyCommand.ts | 90 + .../commands/DescribeInsightCommand.ts | 90 + ...DescribeResourceCollectionHealthCommand.ts | 98 + .../DescribeServiceIntegrationCommand.ts | 95 + .../commands/GetResourceCollectionCommand.ts | 91 + .../ListAnomaliesForInsightCommand.ts | 90 + .../commands/ListEventsCommand.ts | 90 + .../commands/ListInsightsCommand.ts | 91 + .../ListNotificationChannelsCommand.ts | 92 + .../commands/ListRecommendationsCommand.ts | 90 + .../commands/PutFeedbackCommand.ts | 90 + .../RemoveNotificationChannelCommand.ts | 94 + .../commands/SearchInsightsCommand.ts | 96 + .../UpdateResourceCollectionCommand.ts | 91 + .../UpdateServiceIntegrationCommand.ts | 91 + clients/client-devops-guru/endpoints.ts | 81 + clients/client-devops-guru/index.ts | 30 + clients/client-devops-guru/models/index.ts | 1 + clients/client-devops-guru/models/models_0.ts | 2677 ++++ clients/client-devops-guru/package.json | 83 + ...scribeResourceCollectionHealthPaginator.ts | 56 + .../GetResourceCollectionPaginator.ts | 56 + .../pagination/Interfaces.ts | 7 + .../ListAnomaliesForInsightPaginator.ts | 57 + .../pagination/ListEventsPaginator.ts | 53 + .../pagination/ListInsightsPaginator.ts | 57 + .../ListNotificationChannelsPaginator.ts | 56 + .../ListRecommendationsPaginator.ts | 56 + .../pagination/SearchInsightsPaginator.ts | 57 + .../protocols/Aws_restJson1.ts | 3271 +++++ .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + clients/client-devops-guru/runtimeConfig.ts | 36 + clients/client-devops-guru/tsconfig.es.json | 12 + clients/client-devops-guru/tsconfig.json | 31 + .../DirectoryService.ts | 74 + .../DirectoryServiceClient.ts | 12 + .../DisableClientAuthenticationCommand.ts | 91 + .../EnableClientAuthenticationCommand.ts | 91 + clients/client-directory-service/index.ts | 2 + .../models/models_0.ts | 1307 +- .../protocols/Aws_json1_1.ts | 319 + clients/client-ec2/EC2.ts | 52 +- .../commands/AttachVolumeCommand.ts | 2 +- .../commands/CreateSnapshotCommand.ts | 4 +- .../commands/CreateVolumeCommand.ts | 7 +- .../DescribeSnapshotAttributeCommand.ts | 2 +- .../commands/DescribeSnapshotsCommand.ts | 2 +- .../DescribeVolumeAttributeCommand.ts | 2 +- .../commands/DescribeVolumeStatusCommand.ts | 8 +- .../commands/DescribeVolumesCommand.ts | 2 +- .../DisableEbsEncryptionByDefaultCommand.ts | 2 +- .../EnableEbsEncryptionByDefaultCommand.ts | 2 +- .../commands/GetEbsDefaultKmsKeyIdCommand.ts | 2 +- .../GetEbsEncryptionByDefaultCommand.ts | 2 +- .../ModifyEbsDefaultKmsKeyIdCommand.ts | 2 +- .../commands/ModifyVolumeCommand.ts | 11 +- .../ResetEbsDefaultKmsKeyIdCommand.ts | 2 +- clients/client-ec2/models/models_0.ts | 193 +- clients/client-ec2/models/models_1.ts | 133 +- clients/client-ec2/models/models_3.ts | 23 +- clients/client-ec2/models/models_4.ts | 53 +- clients/client-ec2/protocols/Aws_ec2.ts | 32 + clients/client-ecr-public/.gitignore | 14 + clients/client-ecr-public/.npmignore | 4 + clients/client-ecr-public/ECRPUBLIC.ts | 796 + clients/client-ecr-public/ECRPUBLICClient.ts | 303 + clients/client-ecr-public/LICENSE | 201 + clients/client-ecr-public/README.md | 6 + .../BatchCheckLayerAvailabilityCommand.ts | 97 + .../commands/BatchDeleteImageCommand.ts | 93 + .../commands/CompleteLayerUploadCommand.ts | 95 + .../commands/CreateRepositoryCommand.ts | 89 + .../commands/DeleteRepositoryCommand.ts | 90 + .../commands/DeleteRepositoryPolicyCommand.ts | 88 + .../commands/DescribeImageTagsCommand.ts | 88 + .../commands/DescribeImagesCommand.ts | 94 + .../commands/DescribeRegistriesCommand.ts | 88 + .../commands/DescribeRepositoriesCommand.ts | 88 + .../commands/GetAuthorizationTokenCommand.ts | 92 + .../commands/GetRegistryCatalogDataCommand.ts | 88 + .../GetRepositoryCatalogDataCommand.ts | 89 + .../commands/GetRepositoryPolicyCommand.ts | 88 + .../commands/InitiateLayerUploadCommand.ts | 94 + .../commands/PutImageCommand.ts | 92 + .../commands/PutRegistryCatalogDataCommand.ts | 88 + .../PutRepositoryCatalogDataCommand.ts | 88 + .../commands/SetRepositoryPolicyCommand.ts | 90 + .../commands/UploadLayerPartCommand.ts | 94 + clients/client-ecr-public/endpoints.ts | 81 + clients/client-ecr-public/index.ts | 28 + clients/client-ecr-public/models/index.ts | 1 + clients/client-ecr-public/models/models_0.ts | 1894 +++ clients/client-ecr-public/package.json | 83 + .../pagination/DescribeImageTagsPaginator.ts | 57 + .../pagination/DescribeImagesPaginator.ts | 57 + .../pagination/DescribeRegistriesPaginator.ts | 57 + .../DescribeRepositoriesPaginator.ts | 57 + .../pagination/Interfaces.ts | 7 + .../protocols/Aws_json1_1.ts | 3338 +++++ .../runtimeConfig.browser.ts | 34 + .../client-ecr-public/runtimeConfig.native.ts | 17 + .../client-ecr-public/runtimeConfig.shared.ts | 13 + clients/client-ecr-public/runtimeConfig.ts | 36 + clients/client-ecr-public/tsconfig.es.json | 12 + clients/client-ecr-public/tsconfig.json | 31 + clients/client-eks/EKS.ts | 196 +- clients/client-eks/EKSClient.ts | 21 + .../client-eks/commands/CreateAddonCommand.ts | 93 + .../commands/CreateNodegroupCommand.ts | 4 +- .../client-eks/commands/DeleteAddonCommand.ts | 90 + .../commands/DescribeAddonCommand.ts | 88 + .../commands/DescribeAddonVersionsCommand.ts | 88 + .../client-eks/commands/ListAddonsCommand.ts | 88 + .../client-eks/commands/UpdateAddonCommand.ts | 88 + .../commands/UpdateNodegroupVersionCommand.ts | 3 +- clients/client-eks/index.ts | 8 + clients/client-eks/models/models_0.ts | 1808 ++- .../DescribeAddonVersionsPaginator.ts | 57 + .../pagination/ListAddonsPaginator.ts | 53 + clients/client-eks/protocols/Aws_restJson1.ts | 1001 +- clients/client-honeycode/Honeycode.ts | 407 + clients/client-honeycode/HoneycodeClient.ts | 56 +- .../commands/BatchCreateTableRowsCommand.ts | 97 + .../commands/BatchDeleteTableRowsCommand.ts | 91 + .../commands/BatchUpdateTableRowsCommand.ts | 97 + .../commands/BatchUpsertTableRowsCommand.ts | 100 + .../DescribeTableDataImportJobCommand.ts | 93 + .../commands/ListTableColumnsCommand.ts | 90 + .../commands/ListTableRowsCommand.ts | 90 + .../commands/ListTablesCommand.ts | 90 + .../commands/QueryTableRowsCommand.ts | 90 + .../StartTableDataImportJobCommand.ts | 92 + clients/client-honeycode/index.ts | 15 + clients/client-honeycode/models/models_0.ts | 1743 ++- .../client-honeycode/pagination/Interfaces.ts | 7 + .../pagination/ListTableColumnsPaginator.ts | 56 + .../pagination/ListTableRowsPaginator.ts | 57 + .../pagination/ListTablesPaginator.ts | 53 + .../pagination/QueryTableRowsPaginator.ts | 57 + .../protocols/Aws_restJson1.ts | 2069 ++- clients/client-lambda/Lambda.ts | 9 +- .../commands/CreateFunctionCommand.ts | 7 +- .../commands/ListCodeSigningConfigsCommand.ts | 2 +- clients/client-lambda/models/models_0.ts | 143 +- .../client-lambda/protocols/Aws_restJson1.ts | 111 + clients/client-lookoutvision/.gitignore | 14 + clients/client-lookoutvision/.npmignore | 4 + clients/client-lookoutvision/LICENSE | 201 + clients/client-lookoutvision/LookoutVision.ts | 612 + .../LookoutVisionClient.ts | 258 + clients/client-lookoutvision/README.md | 6 + .../commands/CreateDatasetCommand.ts | 97 + .../commands/CreateModelCommand.ts | 98 + .../commands/CreateProjectCommand.ts | 89 + .../commands/DeleteDatasetCommand.ts | 102 + .../commands/DeleteModelCommand.ts | 89 + .../commands/DeleteProjectCommand.ts | 92 + .../commands/DescribeDatasetCommand.ts | 88 + .../commands/DescribeModelCommand.ts | 88 + .../commands/DescribeProjectCommand.ts | 88 + .../commands/DetectAnomaliesCommand.ts | 97 + .../commands/ListDatasetEntriesCommand.ts | 89 + .../commands/ListModelsCommand.ts | 88 + .../commands/ListProjectsCommand.ts | 88 + .../commands/StartModelCommand.ts | 95 + .../commands/StopModelCommand.ts | 89 + .../commands/UpdateDatasetEntriesCommand.ts | 93 + clients/client-lookoutvision/endpoints.ts | 81 + clients/client-lookoutvision/index.ts | 23 + clients/client-lookoutvision/models/index.ts | 1 + .../client-lookoutvision/models/models_0.ts | 1397 ++ clients/client-lookoutvision/package.json | 85 + .../pagination/Interfaces.ts | 7 + .../pagination/ListDatasetEntriesPaginator.ts | 57 + .../pagination/ListModelsPaginator.ts | 53 + .../pagination/ListProjectsPaginator.ts | 57 + .../protocols/Aws_restJson1.ts | 2723 ++++ .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + clients/client-lookoutvision/runtimeConfig.ts | 36 + clients/client-lookoutvision/tsconfig.es.json | 12 + clients/client-lookoutvision/tsconfig.json | 31 + clients/client-s3/S3.ts | 50 +- .../client-s3/commands/CopyObjectCommand.ts | 17 +- .../commands/PutBucketEncryptionCommand.ts | 15 +- .../commands/PutBucketReplicationCommand.ts | 8 +- .../client-s3/commands/PutObjectCommand.ts | 10 +- clients/client-s3/models/models_0.ts | 215 +- clients/client-s3/models/models_1.ts | 96 +- clients/client-s3/protocols/Aws_restXml.ts | 87 +- .../.gitignore | 14 + .../.npmignore | 4 + .../LICENSE | 201 + .../README.md | 6 + .../SageMakerFeatureStoreRuntime.ts | 129 + .../SageMakerFeatureStoreRuntimeClient.ts | 230 + .../commands/DeleteRecordCommand.ts | 94 + .../commands/GetRecordCommand.ts | 94 + .../commands/PutRecordCommand.ts | 96 + .../endpoints.ts | 81 + .../index.ts | 6 + .../models/index.ts | 1 + .../models/models_0.ts | 193 + .../package.json | 83 + .../protocols/Aws_restJson1.ts | 539 + .../runtimeConfig.browser.ts | 34 + .../runtimeConfig.native.ts | 17 + .../runtimeConfig.shared.ts | 13 + .../runtimeConfig.ts | 36 + .../tsconfig.es.json | 12 + .../tsconfig.json | 31 + clients/client-sagemaker/SageMaker.ts | 1919 ++- clients/client-sagemaker/SageMakerClient.ts | 207 + .../commands/AddAssociationCommand.ts | 92 + .../commands/CreateActionCommand.ts | 92 + .../commands/CreateArtifactCommand.ts | 92 + .../commands/CreateContextCommand.ts | 92 + .../commands/CreateDomainCommand.ts | 10 + .../commands/CreateFeatureGroupCommand.ts | 100 + .../commands/CreateModelPackageCommand.ts | 13 +- .../CreateModelPackageGroupCommand.ts | 88 + .../commands/CreatePipelineCommand.ts | 88 + .../CreatePresignedDomainUrlCommand.ts | 3 +- ...eatePresignedNotebookInstanceUrlCommand.ts | 2 +- .../commands/CreateProcessingJobCommand.ts | 2 +- .../commands/CreateProjectCommand.ts | 89 + .../commands/CreateTrainingJobCommand.ts | 12 +- .../commands/CreateTransformJobCommand.ts | 2 +- .../commands/CreateTrialCommand.ts | 2 +- .../commands/CreateTrialComponentCommand.ts | 2 +- .../commands/CreateUserProfileCommand.ts | 2 +- .../commands/CreateWorkforceCommand.ts | 2 +- .../commands/CreateWorkteamCommand.ts | 2 +- .../commands/DeleteActionCommand.ts | 88 + .../commands/DeleteAlgorithmCommand.ts | 2 +- .../commands/DeleteAppCommand.ts | 2 +- .../commands/DeleteAppImageConfigCommand.ts | 2 +- .../commands/DeleteArtifactCommand.ts | 89 + .../commands/DeleteAssociationCommand.ts | 88 + .../commands/DeleteCodeRepositoryCommand.ts | 2 +- .../commands/DeleteContextCommand.ts | 88 + .../commands/DeleteFeatureGroupCommand.ts | 93 + .../DeleteModelPackageGroupCommand.ts | 88 + .../DeleteModelPackageGroupPolicyCommand.ts | 91 + .../commands/DeletePipelineCommand.ts | 88 + .../commands/DeleteProjectCommand.ts | 88 + .../commands/DescribeActionCommand.ts | 88 + .../commands/DescribeArtifactCommand.ts | 88 + .../commands/DescribeContextCommand.ts | 88 + .../commands/DescribeFeatureGroupCommand.ts | 90 + .../DescribeModelPackageGroupCommand.ts | 91 + .../commands/DescribePipelineCommand.ts | 88 + ...bePipelineDefinitionForExecutionCommand.ts | 98 + .../DescribePipelineExecutionCommand.ts | 91 + .../commands/DescribeProjectCommand.ts | 88 + ...SagemakerServicecatalogPortfolioCommand.ts | 102 + ...SagemakerServicecatalogPortfolioCommand.ts | 99 + .../GetModelPackageGroupPolicyCommand.ts | 94 + ...kerServicecatalogPortfolioStatusCommand.ts | 102 + .../commands/ListActionsCommand.ts | 88 + .../commands/ListArtifactsCommand.ts | 88 + .../commands/ListAssociationsCommand.ts | 89 + .../commands/ListAutoMLJobsCommand.ts | 2 +- .../ListCandidatesForAutoMLJobCommand.ts | 2 +- .../commands/ListCodeRepositoriesCommand.ts | 2 +- .../commands/ListCompilationJobsCommand.ts | 2 +- .../commands/ListContextsCommand.ts | 88 + .../commands/ListDomainsCommand.ts | 2 +- .../commands/ListEndpointConfigsCommand.ts | 2 +- .../commands/ListEndpointsCommand.ts | 2 +- .../commands/ListExperimentsCommand.ts | 2 +- .../commands/ListFeatureGroupsCommand.ts | 88 + .../commands/ListFlowDefinitionsCommand.ts | 2 +- .../commands/ListHumanTaskUisCommand.ts | 2 +- .../ListHyperParameterTuningJobsCommand.ts | 2 +- .../commands/ListImageVersionsCommand.ts | 2 +- .../commands/ListImagesCommand.ts | 2 +- .../commands/ListLabelingJobsCommand.ts | 2 +- .../ListLabelingJobsForWorkteamCommand.ts | 2 +- .../commands/ListModelPackageGroupsCommand.ts | 88 + .../commands/ListModelPackagesCommand.ts | 2 +- .../commands/ListModelsCommand.ts | 2 +- .../ListMonitoringExecutionsCommand.ts | 2 +- .../ListMonitoringSchedulesCommand.ts | 2 +- ...NotebookInstanceLifecycleConfigsCommand.ts | 2 +- .../commands/ListNotebookInstancesCommand.ts | 2 +- .../ListPipelineExecutionStepsCommand.ts | 91 + .../commands/ListPipelineExecutionsCommand.ts | 88 + ...stPipelineParametersForExecutionCommand.ts | 98 + .../commands/ListPipelinesCommand.ts | 88 + .../commands/ListProcessingJobsCommand.ts | 2 +- .../commands/ListProjectsCommand.ts | 88 + .../ListSubscribedWorkteamsCommand.ts | 2 +- .../commands/ListTagsCommand.ts | 2 +- .../commands/ListTrainingJobsCommand.ts | 2 +- ...ngJobsForHyperParameterTuningJobCommand.ts | 2 +- .../commands/ListTransformJobsCommand.ts | 2 +- .../commands/ListTrialComponentsCommand.ts | 2 +- .../commands/ListTrialsCommand.ts | 2 +- .../commands/ListUserProfilesCommand.ts | 2 +- .../commands/ListWorkforcesCommand.ts | 2 +- .../commands/ListWorkteamsCommand.ts | 2 +- .../PutModelPackageGroupPolicyCommand.ts | 93 + .../commands/RenderUiTemplateCommand.ts | 2 +- .../commands/SearchCommand.ts | 3 +- .../StartMonitoringScheduleCommand.ts | 2 +- .../commands/StartNotebookInstanceCommand.ts | 2 +- .../commands/StartPipelineExecutionCommand.ts | 88 + .../commands/StopAutoMLJobCommand.ts | 2 +- .../commands/StopCompilationJobCommand.ts | 2 +- .../StopHyperParameterTuningJobCommand.ts | 2 +- .../commands/StopLabelingJobCommand.ts | 2 +- .../commands/StopMonitoringScheduleCommand.ts | 2 +- .../commands/StopNotebookInstanceCommand.ts | 2 +- .../commands/StopPipelineExecutionCommand.ts | 88 + .../commands/StopProcessingJobCommand.ts | 2 +- .../commands/StopTrainingJobCommand.ts | 2 +- .../commands/StopTransformJobCommand.ts | 2 +- .../commands/UpdateActionCommand.ts | 88 + .../commands/UpdateAppImageConfigCommand.ts | 2 +- .../commands/UpdateArtifactCommand.ts | 88 + .../commands/UpdateCodeRepositoryCommand.ts | 2 +- .../commands/UpdateContextCommand.ts | 88 + .../commands/UpdateDomainCommand.ts | 2 +- .../commands/UpdateModelPackageCommand.ts | 88 + .../commands/UpdatePipelineCommand.ts | 88 + .../UpdatePipelineExecutionCommand.ts | 88 + clients/client-sagemaker/index.ts | 61 + clients/client-sagemaker/models/models_0.ts | 3422 +++-- clients/client-sagemaker/models/models_1.ts | 12128 ++++++++-------- clients/client-sagemaker/models/models_2.ts | 6267 +++++++- .../pagination/ListActionsPaginator.ts | 53 + .../ListAppImageConfigsPaginator.ts | 57 + .../pagination/ListArtifactsPaginator.ts | 57 + .../pagination/ListAssociationsPaginator.ts | 57 + .../pagination/ListContextsPaginator.ts | 57 + .../ListModelPackageGroupsPaginator.ts | 57 + .../ListPipelineExecutionStepsPaginator.ts | 57 + .../ListPipelineExecutionsPaginator.ts | 57 + ...PipelineParametersForExecutionPaginator.ts | 57 + .../pagination/ListPipelinesPaginator.ts | 57 + .../pagination/ListProjectsPaginator.ts | 57 + .../client-sagemaker/protocols/Aws_json1_1.ts | 9189 ++++++++++-- 479 files changed, 85507 insertions(+), 11635 deletions(-) create mode 100644 clients/client-amplifybackend/.gitignore create mode 100644 clients/client-amplifybackend/.npmignore create mode 100644 clients/client-amplifybackend/AmplifyBackend.ts create mode 100644 clients/client-amplifybackend/AmplifyBackendClient.ts create mode 100644 clients/client-amplifybackend/LICENSE create mode 100644 clients/client-amplifybackend/README.md create mode 100644 clients/client-amplifybackend/commands/CloneBackendCommand.ts create mode 100644 clients/client-amplifybackend/commands/CreateBackendAPICommand.ts create mode 100644 clients/client-amplifybackend/commands/CreateBackendAuthCommand.ts create mode 100644 clients/client-amplifybackend/commands/CreateBackendCommand.ts create mode 100644 clients/client-amplifybackend/commands/CreateBackendConfigCommand.ts create mode 100644 clients/client-amplifybackend/commands/CreateTokenCommand.ts create mode 100644 clients/client-amplifybackend/commands/DeleteBackendAPICommand.ts create mode 100644 clients/client-amplifybackend/commands/DeleteBackendAuthCommand.ts create mode 100644 clients/client-amplifybackend/commands/DeleteBackendCommand.ts create mode 100644 clients/client-amplifybackend/commands/DeleteTokenCommand.ts create mode 100644 clients/client-amplifybackend/commands/GenerateBackendAPIModelsCommand.ts create mode 100644 clients/client-amplifybackend/commands/GetBackendAPICommand.ts create mode 100644 clients/client-amplifybackend/commands/GetBackendAPIModelsCommand.ts create mode 100644 clients/client-amplifybackend/commands/GetBackendAuthCommand.ts create mode 100644 clients/client-amplifybackend/commands/GetBackendCommand.ts create mode 100644 clients/client-amplifybackend/commands/GetBackendJobCommand.ts create mode 100644 clients/client-amplifybackend/commands/GetTokenCommand.ts create mode 100644 clients/client-amplifybackend/commands/ListBackendJobsCommand.ts create mode 100644 clients/client-amplifybackend/commands/RemoveAllBackendsCommand.ts create mode 100644 clients/client-amplifybackend/commands/RemoveBackendConfigCommand.ts create mode 100644 clients/client-amplifybackend/commands/UpdateBackendAPICommand.ts create mode 100644 clients/client-amplifybackend/commands/UpdateBackendAuthCommand.ts create mode 100644 clients/client-amplifybackend/commands/UpdateBackendConfigCommand.ts create mode 100644 clients/client-amplifybackend/commands/UpdateBackendJobCommand.ts create mode 100644 clients/client-amplifybackend/endpoints.ts create mode 100644 clients/client-amplifybackend/index.ts create mode 100644 clients/client-amplifybackend/models/index.ts create mode 100644 clients/client-amplifybackend/models/models_0.ts create mode 100644 clients/client-amplifybackend/package.json create mode 100644 clients/client-amplifybackend/protocols/Aws_restJson1.ts create mode 100644 clients/client-amplifybackend/runtimeConfig.browser.ts create mode 100644 clients/client-amplifybackend/runtimeConfig.native.ts create mode 100644 clients/client-amplifybackend/runtimeConfig.shared.ts create mode 100644 clients/client-amplifybackend/runtimeConfig.ts create mode 100644 clients/client-amplifybackend/tsconfig.es.json create mode 100644 clients/client-amplifybackend/tsconfig.json create mode 100644 clients/client-appintegrations/.gitignore create mode 100644 clients/client-appintegrations/.npmignore create mode 100644 clients/client-appintegrations/AppIntegrations.ts create mode 100644 clients/client-appintegrations/AppIntegrationsClient.ts create mode 100644 clients/client-appintegrations/LICENSE create mode 100644 clients/client-appintegrations/README.md create mode 100644 clients/client-appintegrations/commands/CreateEventIntegrationCommand.ts create mode 100644 clients/client-appintegrations/commands/DeleteEventIntegrationCommand.ts create mode 100644 clients/client-appintegrations/commands/GetEventIntegrationCommand.ts create mode 100644 clients/client-appintegrations/commands/ListEventIntegrationAssociationsCommand.ts create mode 100644 clients/client-appintegrations/commands/ListEventIntegrationsCommand.ts create mode 100644 clients/client-appintegrations/commands/ListTagsForResourceCommand.ts create mode 100644 clients/client-appintegrations/commands/TagResourceCommand.ts create mode 100644 clients/client-appintegrations/commands/UntagResourceCommand.ts create mode 100644 clients/client-appintegrations/commands/UpdateEventIntegrationCommand.ts create mode 100644 clients/client-appintegrations/endpoints.ts create mode 100644 clients/client-appintegrations/index.ts create mode 100644 clients/client-appintegrations/models/index.ts create mode 100644 clients/client-appintegrations/models/models_0.ts create mode 100644 clients/client-appintegrations/package.json create mode 100644 clients/client-appintegrations/protocols/Aws_restJson1.ts create mode 100644 clients/client-appintegrations/runtimeConfig.browser.ts create mode 100644 clients/client-appintegrations/runtimeConfig.native.ts create mode 100644 clients/client-appintegrations/runtimeConfig.shared.ts create mode 100644 clients/client-appintegrations/runtimeConfig.ts create mode 100644 clients/client-appintegrations/tsconfig.es.json create mode 100644 clients/client-appintegrations/tsconfig.json create mode 100644 clients/client-connect-contact-lens/.gitignore create mode 100644 clients/client-connect-contact-lens/.npmignore create mode 100644 clients/client-connect-contact-lens/ConnectContactLens.ts create mode 100644 clients/client-connect-contact-lens/ConnectContactLensClient.ts create mode 100644 clients/client-connect-contact-lens/LICENSE create mode 100644 clients/client-connect-contact-lens/README.md create mode 100644 clients/client-connect-contact-lens/commands/ListRealtimeContactAnalysisSegmentsCommand.ts create mode 100644 clients/client-connect-contact-lens/endpoints.ts create mode 100644 clients/client-connect-contact-lens/index.ts create mode 100644 clients/client-connect-contact-lens/models/index.ts create mode 100644 clients/client-connect-contact-lens/models/models_0.ts create mode 100644 clients/client-connect-contact-lens/package.json create mode 100644 clients/client-connect-contact-lens/pagination/Interfaces.ts create mode 100644 clients/client-connect-contact-lens/pagination/ListRealtimeContactAnalysisSegmentsPaginator.ts create mode 100644 clients/client-connect-contact-lens/protocols/Aws_restJson1.ts create mode 100644 clients/client-connect-contact-lens/runtimeConfig.browser.ts create mode 100644 clients/client-connect-contact-lens/runtimeConfig.native.ts create mode 100644 clients/client-connect-contact-lens/runtimeConfig.shared.ts create mode 100644 clients/client-connect-contact-lens/runtimeConfig.ts create mode 100644 clients/client-connect-contact-lens/tsconfig.es.json create mode 100644 clients/client-connect-contact-lens/tsconfig.json create mode 100644 clients/client-connect/commands/CreateIntegrationAssociationCommand.ts create mode 100644 clients/client-connect/commands/CreateUseCaseCommand.ts create mode 100644 clients/client-connect/commands/DeleteIntegrationAssociationCommand.ts create mode 100644 clients/client-connect/commands/DeleteUseCaseCommand.ts create mode 100644 clients/client-connect/commands/ListIntegrationAssociationsCommand.ts create mode 100644 clients/client-connect/commands/ListUseCasesCommand.ts create mode 100644 clients/client-connect/commands/StartTaskContactCommand.ts create mode 100644 clients/client-connect/pagination/ListIntegrationAssociationsPaginator.ts create mode 100644 clients/client-connect/pagination/ListUseCasesPaginator.ts create mode 100644 clients/client-devops-guru/.gitignore create mode 100644 clients/client-devops-guru/.npmignore create mode 100644 clients/client-devops-guru/DevOpsGuru.ts create mode 100644 clients/client-devops-guru/DevOpsGuruClient.ts create mode 100644 clients/client-devops-guru/LICENSE create mode 100644 clients/client-devops-guru/README.md create mode 100644 clients/client-devops-guru/commands/AddNotificationChannelCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeAccountHealthCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeAccountOverviewCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeAnomalyCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeInsightCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeResourceCollectionHealthCommand.ts create mode 100644 clients/client-devops-guru/commands/DescribeServiceIntegrationCommand.ts create mode 100644 clients/client-devops-guru/commands/GetResourceCollectionCommand.ts create mode 100644 clients/client-devops-guru/commands/ListAnomaliesForInsightCommand.ts create mode 100644 clients/client-devops-guru/commands/ListEventsCommand.ts create mode 100644 clients/client-devops-guru/commands/ListInsightsCommand.ts create mode 100644 clients/client-devops-guru/commands/ListNotificationChannelsCommand.ts create mode 100644 clients/client-devops-guru/commands/ListRecommendationsCommand.ts create mode 100644 clients/client-devops-guru/commands/PutFeedbackCommand.ts create mode 100644 clients/client-devops-guru/commands/RemoveNotificationChannelCommand.ts create mode 100644 clients/client-devops-guru/commands/SearchInsightsCommand.ts create mode 100644 clients/client-devops-guru/commands/UpdateResourceCollectionCommand.ts create mode 100644 clients/client-devops-guru/commands/UpdateServiceIntegrationCommand.ts create mode 100644 clients/client-devops-guru/endpoints.ts create mode 100644 clients/client-devops-guru/index.ts create mode 100644 clients/client-devops-guru/models/index.ts create mode 100644 clients/client-devops-guru/models/models_0.ts create mode 100644 clients/client-devops-guru/package.json create mode 100644 clients/client-devops-guru/pagination/DescribeResourceCollectionHealthPaginator.ts create mode 100644 clients/client-devops-guru/pagination/GetResourceCollectionPaginator.ts create mode 100644 clients/client-devops-guru/pagination/Interfaces.ts create mode 100644 clients/client-devops-guru/pagination/ListAnomaliesForInsightPaginator.ts create mode 100644 clients/client-devops-guru/pagination/ListEventsPaginator.ts create mode 100644 clients/client-devops-guru/pagination/ListInsightsPaginator.ts create mode 100644 clients/client-devops-guru/pagination/ListNotificationChannelsPaginator.ts create mode 100644 clients/client-devops-guru/pagination/ListRecommendationsPaginator.ts create mode 100644 clients/client-devops-guru/pagination/SearchInsightsPaginator.ts create mode 100644 clients/client-devops-guru/protocols/Aws_restJson1.ts create mode 100644 clients/client-devops-guru/runtimeConfig.browser.ts create mode 100644 clients/client-devops-guru/runtimeConfig.native.ts create mode 100644 clients/client-devops-guru/runtimeConfig.shared.ts create mode 100644 clients/client-devops-guru/runtimeConfig.ts create mode 100644 clients/client-devops-guru/tsconfig.es.json create mode 100644 clients/client-devops-guru/tsconfig.json create mode 100644 clients/client-directory-service/commands/DisableClientAuthenticationCommand.ts create mode 100644 clients/client-directory-service/commands/EnableClientAuthenticationCommand.ts create mode 100644 clients/client-ecr-public/.gitignore create mode 100644 clients/client-ecr-public/.npmignore create mode 100644 clients/client-ecr-public/ECRPUBLIC.ts create mode 100644 clients/client-ecr-public/ECRPUBLICClient.ts create mode 100644 clients/client-ecr-public/LICENSE create mode 100644 clients/client-ecr-public/README.md create mode 100644 clients/client-ecr-public/commands/BatchCheckLayerAvailabilityCommand.ts create mode 100644 clients/client-ecr-public/commands/BatchDeleteImageCommand.ts create mode 100644 clients/client-ecr-public/commands/CompleteLayerUploadCommand.ts create mode 100644 clients/client-ecr-public/commands/CreateRepositoryCommand.ts create mode 100644 clients/client-ecr-public/commands/DeleteRepositoryCommand.ts create mode 100644 clients/client-ecr-public/commands/DeleteRepositoryPolicyCommand.ts create mode 100644 clients/client-ecr-public/commands/DescribeImageTagsCommand.ts create mode 100644 clients/client-ecr-public/commands/DescribeImagesCommand.ts create mode 100644 clients/client-ecr-public/commands/DescribeRegistriesCommand.ts create mode 100644 clients/client-ecr-public/commands/DescribeRepositoriesCommand.ts create mode 100644 clients/client-ecr-public/commands/GetAuthorizationTokenCommand.ts create mode 100644 clients/client-ecr-public/commands/GetRegistryCatalogDataCommand.ts create mode 100644 clients/client-ecr-public/commands/GetRepositoryCatalogDataCommand.ts create mode 100644 clients/client-ecr-public/commands/GetRepositoryPolicyCommand.ts create mode 100644 clients/client-ecr-public/commands/InitiateLayerUploadCommand.ts create mode 100644 clients/client-ecr-public/commands/PutImageCommand.ts create mode 100644 clients/client-ecr-public/commands/PutRegistryCatalogDataCommand.ts create mode 100644 clients/client-ecr-public/commands/PutRepositoryCatalogDataCommand.ts create mode 100644 clients/client-ecr-public/commands/SetRepositoryPolicyCommand.ts create mode 100644 clients/client-ecr-public/commands/UploadLayerPartCommand.ts create mode 100644 clients/client-ecr-public/endpoints.ts create mode 100644 clients/client-ecr-public/index.ts create mode 100644 clients/client-ecr-public/models/index.ts create mode 100644 clients/client-ecr-public/models/models_0.ts create mode 100644 clients/client-ecr-public/package.json create mode 100644 clients/client-ecr-public/pagination/DescribeImageTagsPaginator.ts create mode 100644 clients/client-ecr-public/pagination/DescribeImagesPaginator.ts create mode 100644 clients/client-ecr-public/pagination/DescribeRegistriesPaginator.ts create mode 100644 clients/client-ecr-public/pagination/DescribeRepositoriesPaginator.ts create mode 100644 clients/client-ecr-public/pagination/Interfaces.ts create mode 100644 clients/client-ecr-public/protocols/Aws_json1_1.ts create mode 100644 clients/client-ecr-public/runtimeConfig.browser.ts create mode 100644 clients/client-ecr-public/runtimeConfig.native.ts create mode 100644 clients/client-ecr-public/runtimeConfig.shared.ts create mode 100644 clients/client-ecr-public/runtimeConfig.ts create mode 100644 clients/client-ecr-public/tsconfig.es.json create mode 100644 clients/client-ecr-public/tsconfig.json create mode 100644 clients/client-eks/commands/CreateAddonCommand.ts create mode 100644 clients/client-eks/commands/DeleteAddonCommand.ts create mode 100644 clients/client-eks/commands/DescribeAddonCommand.ts create mode 100644 clients/client-eks/commands/DescribeAddonVersionsCommand.ts create mode 100644 clients/client-eks/commands/ListAddonsCommand.ts create mode 100644 clients/client-eks/commands/UpdateAddonCommand.ts create mode 100644 clients/client-eks/pagination/DescribeAddonVersionsPaginator.ts create mode 100644 clients/client-eks/pagination/ListAddonsPaginator.ts create mode 100644 clients/client-honeycode/commands/BatchCreateTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/BatchDeleteTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/BatchUpdateTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/BatchUpsertTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/DescribeTableDataImportJobCommand.ts create mode 100644 clients/client-honeycode/commands/ListTableColumnsCommand.ts create mode 100644 clients/client-honeycode/commands/ListTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/ListTablesCommand.ts create mode 100644 clients/client-honeycode/commands/QueryTableRowsCommand.ts create mode 100644 clients/client-honeycode/commands/StartTableDataImportJobCommand.ts create mode 100644 clients/client-honeycode/pagination/Interfaces.ts create mode 100644 clients/client-honeycode/pagination/ListTableColumnsPaginator.ts create mode 100644 clients/client-honeycode/pagination/ListTableRowsPaginator.ts create mode 100644 clients/client-honeycode/pagination/ListTablesPaginator.ts create mode 100644 clients/client-honeycode/pagination/QueryTableRowsPaginator.ts create mode 100644 clients/client-lookoutvision/.gitignore create mode 100644 clients/client-lookoutvision/.npmignore create mode 100644 clients/client-lookoutvision/LICENSE create mode 100644 clients/client-lookoutvision/LookoutVision.ts create mode 100644 clients/client-lookoutvision/LookoutVisionClient.ts create mode 100644 clients/client-lookoutvision/README.md create mode 100644 clients/client-lookoutvision/commands/CreateDatasetCommand.ts create mode 100644 clients/client-lookoutvision/commands/CreateModelCommand.ts create mode 100644 clients/client-lookoutvision/commands/CreateProjectCommand.ts create mode 100644 clients/client-lookoutvision/commands/DeleteDatasetCommand.ts create mode 100644 clients/client-lookoutvision/commands/DeleteModelCommand.ts create mode 100644 clients/client-lookoutvision/commands/DeleteProjectCommand.ts create mode 100644 clients/client-lookoutvision/commands/DescribeDatasetCommand.ts create mode 100644 clients/client-lookoutvision/commands/DescribeModelCommand.ts create mode 100644 clients/client-lookoutvision/commands/DescribeProjectCommand.ts create mode 100644 clients/client-lookoutvision/commands/DetectAnomaliesCommand.ts create mode 100644 clients/client-lookoutvision/commands/ListDatasetEntriesCommand.ts create mode 100644 clients/client-lookoutvision/commands/ListModelsCommand.ts create mode 100644 clients/client-lookoutvision/commands/ListProjectsCommand.ts create mode 100644 clients/client-lookoutvision/commands/StartModelCommand.ts create mode 100644 clients/client-lookoutvision/commands/StopModelCommand.ts create mode 100644 clients/client-lookoutvision/commands/UpdateDatasetEntriesCommand.ts create mode 100644 clients/client-lookoutvision/endpoints.ts create mode 100644 clients/client-lookoutvision/index.ts create mode 100644 clients/client-lookoutvision/models/index.ts create mode 100644 clients/client-lookoutvision/models/models_0.ts create mode 100644 clients/client-lookoutvision/package.json create mode 100644 clients/client-lookoutvision/pagination/Interfaces.ts create mode 100644 clients/client-lookoutvision/pagination/ListDatasetEntriesPaginator.ts create mode 100644 clients/client-lookoutvision/pagination/ListModelsPaginator.ts create mode 100644 clients/client-lookoutvision/pagination/ListProjectsPaginator.ts create mode 100644 clients/client-lookoutvision/protocols/Aws_restJson1.ts create mode 100644 clients/client-lookoutvision/runtimeConfig.browser.ts create mode 100644 clients/client-lookoutvision/runtimeConfig.native.ts create mode 100644 clients/client-lookoutvision/runtimeConfig.shared.ts create mode 100644 clients/client-lookoutvision/runtimeConfig.ts create mode 100644 clients/client-lookoutvision/tsconfig.es.json create mode 100644 clients/client-lookoutvision/tsconfig.json create mode 100644 clients/client-sagemaker-featurestore-runtime/.gitignore create mode 100644 clients/client-sagemaker-featurestore-runtime/.npmignore create mode 100644 clients/client-sagemaker-featurestore-runtime/LICENSE create mode 100644 clients/client-sagemaker-featurestore-runtime/README.md create mode 100644 clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntime.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntimeClient.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/commands/DeleteRecordCommand.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/commands/GetRecordCommand.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/commands/PutRecordCommand.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/endpoints.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/index.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/models/index.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/models/models_0.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/package.json create mode 100644 clients/client-sagemaker-featurestore-runtime/protocols/Aws_restJson1.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/runtimeConfig.browser.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/runtimeConfig.native.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/runtimeConfig.shared.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/runtimeConfig.ts create mode 100644 clients/client-sagemaker-featurestore-runtime/tsconfig.es.json create mode 100644 clients/client-sagemaker-featurestore-runtime/tsconfig.json create mode 100644 clients/client-sagemaker/commands/AddAssociationCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateActionCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateArtifactCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateContextCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateFeatureGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateModelPackageGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/CreatePipelineCommand.ts create mode 100644 clients/client-sagemaker/commands/CreateProjectCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteActionCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteArtifactCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteAssociationCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteContextCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteFeatureGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteModelPackageGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteModelPackageGroupPolicyCommand.ts create mode 100644 clients/client-sagemaker/commands/DeletePipelineCommand.ts create mode 100644 clients/client-sagemaker/commands/DeleteProjectCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeActionCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeArtifactCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeContextCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeFeatureGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeModelPackageGroupCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribePipelineCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribePipelineDefinitionForExecutionCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribePipelineExecutionCommand.ts create mode 100644 clients/client-sagemaker/commands/DescribeProjectCommand.ts create mode 100644 clients/client-sagemaker/commands/DisableSagemakerServicecatalogPortfolioCommand.ts create mode 100644 clients/client-sagemaker/commands/EnableSagemakerServicecatalogPortfolioCommand.ts create mode 100644 clients/client-sagemaker/commands/GetModelPackageGroupPolicyCommand.ts create mode 100644 clients/client-sagemaker/commands/GetSagemakerServicecatalogPortfolioStatusCommand.ts create mode 100644 clients/client-sagemaker/commands/ListActionsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListArtifactsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListAssociationsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListContextsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListFeatureGroupsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListModelPackageGroupsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListPipelineExecutionStepsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListPipelineExecutionsCommand.ts create mode 100644 clients/client-sagemaker/commands/ListPipelineParametersForExecutionCommand.ts create mode 100644 clients/client-sagemaker/commands/ListPipelinesCommand.ts create mode 100644 clients/client-sagemaker/commands/ListProjectsCommand.ts create mode 100644 clients/client-sagemaker/commands/PutModelPackageGroupPolicyCommand.ts create mode 100644 clients/client-sagemaker/commands/StartPipelineExecutionCommand.ts create mode 100644 clients/client-sagemaker/commands/StopPipelineExecutionCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdateActionCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdateArtifactCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdateContextCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdateModelPackageCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdatePipelineCommand.ts create mode 100644 clients/client-sagemaker/commands/UpdatePipelineExecutionCommand.ts create mode 100644 clients/client-sagemaker/pagination/ListActionsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListAppImageConfigsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListArtifactsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListAssociationsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListContextsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListModelPackageGroupsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListPipelineExecutionStepsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListPipelineExecutionsPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListPipelineParametersForExecutionPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListPipelinesPaginator.ts create mode 100644 clients/client-sagemaker/pagination/ListProjectsPaginator.ts diff --git a/clients/client-amplifybackend/.gitignore b/clients/client-amplifybackend/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-amplifybackend/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-amplifybackend/.npmignore b/clients/client-amplifybackend/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-amplifybackend/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-amplifybackend/AmplifyBackend.ts b/clients/client-amplifybackend/AmplifyBackend.ts new file mode 100644 index 000000000000..4518096f6af1 --- /dev/null +++ b/clients/client-amplifybackend/AmplifyBackend.ts @@ -0,0 +1,852 @@ +import { AmplifyBackendClient } from "./AmplifyBackendClient"; +import { + CloneBackendCommand, + CloneBackendCommandInput, + CloneBackendCommandOutput, +} from "./commands/CloneBackendCommand"; +import { + CreateBackendAPICommand, + CreateBackendAPICommandInput, + CreateBackendAPICommandOutput, +} from "./commands/CreateBackendAPICommand"; +import { + CreateBackendAuthCommand, + CreateBackendAuthCommandInput, + CreateBackendAuthCommandOutput, +} from "./commands/CreateBackendAuthCommand"; +import { + CreateBackendCommand, + CreateBackendCommandInput, + CreateBackendCommandOutput, +} from "./commands/CreateBackendCommand"; +import { + CreateBackendConfigCommand, + CreateBackendConfigCommandInput, + CreateBackendConfigCommandOutput, +} from "./commands/CreateBackendConfigCommand"; +import { CreateTokenCommand, CreateTokenCommandInput, CreateTokenCommandOutput } from "./commands/CreateTokenCommand"; +import { + DeleteBackendAPICommand, + DeleteBackendAPICommandInput, + DeleteBackendAPICommandOutput, +} from "./commands/DeleteBackendAPICommand"; +import { + DeleteBackendAuthCommand, + DeleteBackendAuthCommandInput, + DeleteBackendAuthCommandOutput, +} from "./commands/DeleteBackendAuthCommand"; +import { + DeleteBackendCommand, + DeleteBackendCommandInput, + DeleteBackendCommandOutput, +} from "./commands/DeleteBackendCommand"; +import { DeleteTokenCommand, DeleteTokenCommandInput, DeleteTokenCommandOutput } from "./commands/DeleteTokenCommand"; +import { + GenerateBackendAPIModelsCommand, + GenerateBackendAPIModelsCommandInput, + GenerateBackendAPIModelsCommandOutput, +} from "./commands/GenerateBackendAPIModelsCommand"; +import { + GetBackendAPICommand, + GetBackendAPICommandInput, + GetBackendAPICommandOutput, +} from "./commands/GetBackendAPICommand"; +import { + GetBackendAPIModelsCommand, + GetBackendAPIModelsCommandInput, + GetBackendAPIModelsCommandOutput, +} from "./commands/GetBackendAPIModelsCommand"; +import { + GetBackendAuthCommand, + GetBackendAuthCommandInput, + GetBackendAuthCommandOutput, +} from "./commands/GetBackendAuthCommand"; +import { GetBackendCommand, GetBackendCommandInput, GetBackendCommandOutput } from "./commands/GetBackendCommand"; +import { + GetBackendJobCommand, + GetBackendJobCommandInput, + GetBackendJobCommandOutput, +} from "./commands/GetBackendJobCommand"; +import { GetTokenCommand, GetTokenCommandInput, GetTokenCommandOutput } from "./commands/GetTokenCommand"; +import { + ListBackendJobsCommand, + ListBackendJobsCommandInput, + ListBackendJobsCommandOutput, +} from "./commands/ListBackendJobsCommand"; +import { + RemoveAllBackendsCommand, + RemoveAllBackendsCommandInput, + RemoveAllBackendsCommandOutput, +} from "./commands/RemoveAllBackendsCommand"; +import { + RemoveBackendConfigCommand, + RemoveBackendConfigCommandInput, + RemoveBackendConfigCommandOutput, +} from "./commands/RemoveBackendConfigCommand"; +import { + UpdateBackendAPICommand, + UpdateBackendAPICommandInput, + UpdateBackendAPICommandOutput, +} from "./commands/UpdateBackendAPICommand"; +import { + UpdateBackendAuthCommand, + UpdateBackendAuthCommandInput, + UpdateBackendAuthCommandOutput, +} from "./commands/UpdateBackendAuthCommand"; +import { + UpdateBackendConfigCommand, + UpdateBackendConfigCommandInput, + UpdateBackendConfigCommandOutput, +} from "./commands/UpdateBackendConfigCommand"; +import { + UpdateBackendJobCommand, + UpdateBackendJobCommandInput, + UpdateBackendJobCommandOutput, +} from "./commands/UpdateBackendJobCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

AWS Amplify Admin API

+ */ +export class AmplifyBackend extends AmplifyBackendClient { + /** + *

This operation clones an existing backend.

+ */ + public cloneBackend( + args: CloneBackendCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public cloneBackend(args: CloneBackendCommandInput, cb: (err: any, data?: CloneBackendCommandOutput) => void): void; + public cloneBackend( + args: CloneBackendCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CloneBackendCommandOutput) => void + ): void; + public cloneBackend( + args: CloneBackendCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CloneBackendCommandOutput) => void), + cb?: (err: any, data?: CloneBackendCommandOutput) => void + ): Promise | void { + const command = new CloneBackendCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

This operation creates a backend for an Amplify app. Backends are automatically created at the time of app creation.

+ */ + public createBackend( + args: CreateBackendCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createBackend( + args: CreateBackendCommandInput, + cb: (err: any, data?: CreateBackendCommandOutput) => void + ): void; + public createBackend( + args: CreateBackendCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateBackendCommandOutput) => void + ): void; + public createBackend( + args: CreateBackendCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateBackendCommandOutput) => void), + cb?: (err: any, data?: CreateBackendCommandOutput) => void + ): Promise | void { + const command = new CreateBackendCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Creates a new backend API resource.

+ */ + public createBackendAPI( + args: CreateBackendAPICommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createBackendAPI( + args: CreateBackendAPICommandInput, + cb: (err: any, data?: CreateBackendAPICommandOutput) => void + ): void; + public createBackendAPI( + args: CreateBackendAPICommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateBackendAPICommandOutput) => void + ): void; + public createBackendAPI( + args: CreateBackendAPICommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateBackendAPICommandOutput) => void), + cb?: (err: any, data?: CreateBackendAPICommandOutput) => void + ): Promise | void { + const command = new CreateBackendAPICommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Creates a new backend authentication resource.

+ */ + public createBackendAuth( + args: CreateBackendAuthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createBackendAuth( + args: CreateBackendAuthCommandInput, + cb: (err: any, data?: CreateBackendAuthCommandOutput) => void + ): void; + public createBackendAuth( + args: CreateBackendAuthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateBackendAuthCommandOutput) => void + ): void; + public createBackendAuth( + args: CreateBackendAuthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateBackendAuthCommandOutput) => void), + cb?: (err: any, data?: CreateBackendAuthCommandOutput) => void + ): Promise | void { + const command = new CreateBackendAuthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Creates a config object for a backend.

+ */ + public createBackendConfig( + args: CreateBackendConfigCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createBackendConfig( + args: CreateBackendConfigCommandInput, + cb: (err: any, data?: CreateBackendConfigCommandOutput) => void + ): void; + public createBackendConfig( + args: CreateBackendConfigCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateBackendConfigCommandOutput) => void + ): void; + public createBackendConfig( + args: CreateBackendConfigCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateBackendConfigCommandOutput) => void), + cb?: (err: any, data?: CreateBackendConfigCommandOutput) => void + ): Promise | void { + const command = new CreateBackendConfigCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Generates a one time challenge code to authenticate a user into your Amplify Admin UI.

+ */ + public createToken(args: CreateTokenCommandInput, options?: __HttpHandlerOptions): Promise; + public createToken(args: CreateTokenCommandInput, cb: (err: any, data?: CreateTokenCommandOutput) => void): void; + public createToken( + args: CreateTokenCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateTokenCommandOutput) => void + ): void; + public createToken( + args: CreateTokenCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateTokenCommandOutput) => void), + cb?: (err: any, data?: CreateTokenCommandOutput) => void + ): Promise | void { + const command = new CreateTokenCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Removes an existing environment from your Ampify project.

+ */ + public deleteBackend( + args: DeleteBackendCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteBackend( + args: DeleteBackendCommandInput, + cb: (err: any, data?: DeleteBackendCommandOutput) => void + ): void; + public deleteBackend( + args: DeleteBackendCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteBackendCommandOutput) => void + ): void; + public deleteBackend( + args: DeleteBackendCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteBackendCommandOutput) => void), + cb?: (err: any, data?: DeleteBackendCommandOutput) => void + ): Promise | void { + const command = new DeleteBackendCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Deletes an existing backend API resource.

+ */ + public deleteBackendAPI( + args: DeleteBackendAPICommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteBackendAPI( + args: DeleteBackendAPICommandInput, + cb: (err: any, data?: DeleteBackendAPICommandOutput) => void + ): void; + public deleteBackendAPI( + args: DeleteBackendAPICommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteBackendAPICommandOutput) => void + ): void; + public deleteBackendAPI( + args: DeleteBackendAPICommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteBackendAPICommandOutput) => void), + cb?: (err: any, data?: DeleteBackendAPICommandOutput) => void + ): Promise | void { + const command = new DeleteBackendAPICommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Deletes an existing backend authentication resource.

+ */ + public deleteBackendAuth( + args: DeleteBackendAuthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteBackendAuth( + args: DeleteBackendAuthCommandInput, + cb: (err: any, data?: DeleteBackendAuthCommandOutput) => void + ): void; + public deleteBackendAuth( + args: DeleteBackendAuthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteBackendAuthCommandOutput) => void + ): void; + public deleteBackendAuth( + args: DeleteBackendAuthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteBackendAuthCommandOutput) => void), + cb?: (err: any, data?: DeleteBackendAuthCommandOutput) => void + ): Promise | void { + const command = new DeleteBackendAuthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Deletes the challenge token based on the given appId and sessionId.

+ */ + public deleteToken(args: DeleteTokenCommandInput, options?: __HttpHandlerOptions): Promise; + public deleteToken(args: DeleteTokenCommandInput, cb: (err: any, data?: DeleteTokenCommandOutput) => void): void; + public deleteToken( + args: DeleteTokenCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteTokenCommandOutput) => void + ): void; + public deleteToken( + args: DeleteTokenCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteTokenCommandOutput) => void), + cb?: (err: any, data?: DeleteTokenCommandOutput) => void + ): Promise | void { + const command = new DeleteTokenCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Generates a model schema for an existing backend API resource.

+ */ + public generateBackendAPIModels( + args: GenerateBackendAPIModelsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public generateBackendAPIModels( + args: GenerateBackendAPIModelsCommandInput, + cb: (err: any, data?: GenerateBackendAPIModelsCommandOutput) => void + ): void; + public generateBackendAPIModels( + args: GenerateBackendAPIModelsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GenerateBackendAPIModelsCommandOutput) => void + ): void; + public generateBackendAPIModels( + args: GenerateBackendAPIModelsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GenerateBackendAPIModelsCommandOutput) => void), + cb?: (err: any, data?: GenerateBackendAPIModelsCommandOutput) => void + ): Promise | void { + const command = new GenerateBackendAPIModelsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Provides project level details for your Amplify UI project.

+ */ + public getBackend(args: GetBackendCommandInput, options?: __HttpHandlerOptions): Promise; + public getBackend(args: GetBackendCommandInput, cb: (err: any, data?: GetBackendCommandOutput) => void): void; + public getBackend( + args: GetBackendCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetBackendCommandOutput) => void + ): void; + public getBackend( + args: GetBackendCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetBackendCommandOutput) => void), + cb?: (err: any, data?: GetBackendCommandOutput) => void + ): Promise | void { + const command = new GetBackendCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Gets the details for a backend api.

+ */ + public getBackendAPI( + args: GetBackendAPICommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getBackendAPI( + args: GetBackendAPICommandInput, + cb: (err: any, data?: GetBackendAPICommandOutput) => void + ): void; + public getBackendAPI( + args: GetBackendAPICommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetBackendAPICommandOutput) => void + ): void; + public getBackendAPI( + args: GetBackendAPICommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetBackendAPICommandOutput) => void), + cb?: (err: any, data?: GetBackendAPICommandOutput) => void + ): Promise | void { + const command = new GetBackendAPICommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Generates a model schema for existing backend API resource.

+ */ + public getBackendAPIModels( + args: GetBackendAPIModelsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getBackendAPIModels( + args: GetBackendAPIModelsCommandInput, + cb: (err: any, data?: GetBackendAPIModelsCommandOutput) => void + ): void; + public getBackendAPIModels( + args: GetBackendAPIModelsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetBackendAPIModelsCommandOutput) => void + ): void; + public getBackendAPIModels( + args: GetBackendAPIModelsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetBackendAPIModelsCommandOutput) => void), + cb?: (err: any, data?: GetBackendAPIModelsCommandOutput) => void + ): Promise | void { + const command = new GetBackendAPIModelsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Gets a backend auth details.

+ */ + public getBackendAuth( + args: GetBackendAuthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getBackendAuth( + args: GetBackendAuthCommandInput, + cb: (err: any, data?: GetBackendAuthCommandOutput) => void + ): void; + public getBackendAuth( + args: GetBackendAuthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetBackendAuthCommandOutput) => void + ): void; + public getBackendAuth( + args: GetBackendAuthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetBackendAuthCommandOutput) => void), + cb?: (err: any, data?: GetBackendAuthCommandOutput) => void + ): Promise | void { + const command = new GetBackendAuthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Returns information about a specific job.

+ */ + public getBackendJob( + args: GetBackendJobCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getBackendJob( + args: GetBackendJobCommandInput, + cb: (err: any, data?: GetBackendJobCommandOutput) => void + ): void; + public getBackendJob( + args: GetBackendJobCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetBackendJobCommandOutput) => void + ): void; + public getBackendJob( + args: GetBackendJobCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetBackendJobCommandOutput) => void), + cb?: (err: any, data?: GetBackendJobCommandOutput) => void + ): Promise | void { + const command = new GetBackendJobCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Gets the challenge token based on the given appId and sessionId.

+ */ + public getToken(args: GetTokenCommandInput, options?: __HttpHandlerOptions): Promise; + public getToken(args: GetTokenCommandInput, cb: (err: any, data?: GetTokenCommandOutput) => void): void; + public getToken( + args: GetTokenCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetTokenCommandOutput) => void + ): void; + public getToken( + args: GetTokenCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetTokenCommandOutput) => void), + cb?: (err: any, data?: GetTokenCommandOutput) => void + ): Promise | void { + const command = new GetTokenCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Lists the jobs for the backend of an Amplify app.

+ */ + public listBackendJobs( + args: ListBackendJobsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listBackendJobs( + args: ListBackendJobsCommandInput, + cb: (err: any, data?: ListBackendJobsCommandOutput) => void + ): void; + public listBackendJobs( + args: ListBackendJobsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListBackendJobsCommandOutput) => void + ): void; + public listBackendJobs( + args: ListBackendJobsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListBackendJobsCommandOutput) => void), + cb?: (err: any, data?: ListBackendJobsCommandOutput) => void + ): Promise | void { + const command = new ListBackendJobsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Removes all backend environments from your Amplify project.

+ */ + public removeAllBackends( + args: RemoveAllBackendsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public removeAllBackends( + args: RemoveAllBackendsCommandInput, + cb: (err: any, data?: RemoveAllBackendsCommandOutput) => void + ): void; + public removeAllBackends( + args: RemoveAllBackendsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: RemoveAllBackendsCommandOutput) => void + ): void; + public removeAllBackends( + args: RemoveAllBackendsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: RemoveAllBackendsCommandOutput) => void), + cb?: (err: any, data?: RemoveAllBackendsCommandOutput) => void + ): Promise | void { + const command = new RemoveAllBackendsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Removes the AWS resources required to access the Amplify Admin UI.

+ */ + public removeBackendConfig( + args: RemoveBackendConfigCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public removeBackendConfig( + args: RemoveBackendConfigCommandInput, + cb: (err: any, data?: RemoveBackendConfigCommandOutput) => void + ): void; + public removeBackendConfig( + args: RemoveBackendConfigCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: RemoveBackendConfigCommandOutput) => void + ): void; + public removeBackendConfig( + args: RemoveBackendConfigCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: RemoveBackendConfigCommandOutput) => void), + cb?: (err: any, data?: RemoveBackendConfigCommandOutput) => void + ): Promise | void { + const command = new RemoveBackendConfigCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Updates an existing backend API resource.

+ */ + public updateBackendAPI( + args: UpdateBackendAPICommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateBackendAPI( + args: UpdateBackendAPICommandInput, + cb: (err: any, data?: UpdateBackendAPICommandOutput) => void + ): void; + public updateBackendAPI( + args: UpdateBackendAPICommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateBackendAPICommandOutput) => void + ): void; + public updateBackendAPI( + args: UpdateBackendAPICommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateBackendAPICommandOutput) => void), + cb?: (err: any, data?: UpdateBackendAPICommandOutput) => void + ): Promise | void { + const command = new UpdateBackendAPICommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Updates an existing backend authentication resource.

+ */ + public updateBackendAuth( + args: UpdateBackendAuthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateBackendAuth( + args: UpdateBackendAuthCommandInput, + cb: (err: any, data?: UpdateBackendAuthCommandOutput) => void + ): void; + public updateBackendAuth( + args: UpdateBackendAuthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateBackendAuthCommandOutput) => void + ): void; + public updateBackendAuth( + args: UpdateBackendAuthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateBackendAuthCommandOutput) => void), + cb?: (err: any, data?: UpdateBackendAuthCommandOutput) => void + ): Promise | void { + const command = new UpdateBackendAuthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Updates the AWS resources required to access the Amplify Admin UI.

+ */ + public updateBackendConfig( + args: UpdateBackendConfigCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateBackendConfig( + args: UpdateBackendConfigCommandInput, + cb: (err: any, data?: UpdateBackendConfigCommandOutput) => void + ): void; + public updateBackendConfig( + args: UpdateBackendConfigCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateBackendConfigCommandOutput) => void + ): void; + public updateBackendConfig( + args: UpdateBackendConfigCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateBackendConfigCommandOutput) => void), + cb?: (err: any, data?: UpdateBackendConfigCommandOutput) => void + ): Promise | void { + const command = new UpdateBackendConfigCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Updates a specific job.

+ */ + public updateBackendJob( + args: UpdateBackendJobCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateBackendJob( + args: UpdateBackendJobCommandInput, + cb: (err: any, data?: UpdateBackendJobCommandOutput) => void + ): void; + public updateBackendJob( + args: UpdateBackendJobCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateBackendJobCommandOutput) => void + ): void; + public updateBackendJob( + args: UpdateBackendJobCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateBackendJobCommandOutput) => void), + cb?: (err: any, data?: UpdateBackendJobCommandOutput) => void + ): Promise | void { + const command = new UpdateBackendJobCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-amplifybackend/AmplifyBackendClient.ts b/clients/client-amplifybackend/AmplifyBackendClient.ts new file mode 100644 index 000000000000..1e71768b091f --- /dev/null +++ b/clients/client-amplifybackend/AmplifyBackendClient.ts @@ -0,0 +1,288 @@ +import { CloneBackendCommandInput, CloneBackendCommandOutput } from "./commands/CloneBackendCommand"; +import { CreateBackendAPICommandInput, CreateBackendAPICommandOutput } from "./commands/CreateBackendAPICommand"; +import { CreateBackendAuthCommandInput, CreateBackendAuthCommandOutput } from "./commands/CreateBackendAuthCommand"; +import { CreateBackendCommandInput, CreateBackendCommandOutput } from "./commands/CreateBackendCommand"; +import { + CreateBackendConfigCommandInput, + CreateBackendConfigCommandOutput, +} from "./commands/CreateBackendConfigCommand"; +import { CreateTokenCommandInput, CreateTokenCommandOutput } from "./commands/CreateTokenCommand"; +import { DeleteBackendAPICommandInput, DeleteBackendAPICommandOutput } from "./commands/DeleteBackendAPICommand"; +import { DeleteBackendAuthCommandInput, DeleteBackendAuthCommandOutput } from "./commands/DeleteBackendAuthCommand"; +import { DeleteBackendCommandInput, DeleteBackendCommandOutput } from "./commands/DeleteBackendCommand"; +import { DeleteTokenCommandInput, DeleteTokenCommandOutput } from "./commands/DeleteTokenCommand"; +import { + GenerateBackendAPIModelsCommandInput, + GenerateBackendAPIModelsCommandOutput, +} from "./commands/GenerateBackendAPIModelsCommand"; +import { GetBackendAPICommandInput, GetBackendAPICommandOutput } from "./commands/GetBackendAPICommand"; +import { + GetBackendAPIModelsCommandInput, + GetBackendAPIModelsCommandOutput, +} from "./commands/GetBackendAPIModelsCommand"; +import { GetBackendAuthCommandInput, GetBackendAuthCommandOutput } from "./commands/GetBackendAuthCommand"; +import { GetBackendCommandInput, GetBackendCommandOutput } from "./commands/GetBackendCommand"; +import { GetBackendJobCommandInput, GetBackendJobCommandOutput } from "./commands/GetBackendJobCommand"; +import { GetTokenCommandInput, GetTokenCommandOutput } from "./commands/GetTokenCommand"; +import { ListBackendJobsCommandInput, ListBackendJobsCommandOutput } from "./commands/ListBackendJobsCommand"; +import { RemoveAllBackendsCommandInput, RemoveAllBackendsCommandOutput } from "./commands/RemoveAllBackendsCommand"; +import { + RemoveBackendConfigCommandInput, + RemoveBackendConfigCommandOutput, +} from "./commands/RemoveBackendConfigCommand"; +import { UpdateBackendAPICommandInput, UpdateBackendAPICommandOutput } from "./commands/UpdateBackendAPICommand"; +import { UpdateBackendAuthCommandInput, UpdateBackendAuthCommandOutput } from "./commands/UpdateBackendAuthCommand"; +import { + UpdateBackendConfigCommandInput, + UpdateBackendConfigCommandOutput, +} from "./commands/UpdateBackendConfigCommand"; +import { UpdateBackendJobCommandInput, UpdateBackendJobCommandOutput } from "./commands/UpdateBackendJobCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = + | CloneBackendCommandInput + | CreateBackendAPICommandInput + | CreateBackendAuthCommandInput + | CreateBackendCommandInput + | CreateBackendConfigCommandInput + | CreateTokenCommandInput + | DeleteBackendAPICommandInput + | DeleteBackendAuthCommandInput + | DeleteBackendCommandInput + | DeleteTokenCommandInput + | GenerateBackendAPIModelsCommandInput + | GetBackendAPICommandInput + | GetBackendAPIModelsCommandInput + | GetBackendAuthCommandInput + | GetBackendCommandInput + | GetBackendJobCommandInput + | GetTokenCommandInput + | ListBackendJobsCommandInput + | RemoveAllBackendsCommandInput + | RemoveBackendConfigCommandInput + | UpdateBackendAPICommandInput + | UpdateBackendAuthCommandInput + | UpdateBackendConfigCommandInput + | UpdateBackendJobCommandInput; + +export type ServiceOutputTypes = + | CloneBackendCommandOutput + | CreateBackendAPICommandOutput + | CreateBackendAuthCommandOutput + | CreateBackendCommandOutput + | CreateBackendConfigCommandOutput + | CreateTokenCommandOutput + | DeleteBackendAPICommandOutput + | DeleteBackendAuthCommandOutput + | DeleteBackendCommandOutput + | DeleteTokenCommandOutput + | GenerateBackendAPIModelsCommandOutput + | GetBackendAPICommandOutput + | GetBackendAPIModelsCommandOutput + | GetBackendAuthCommandOutput + | GetBackendCommandOutput + | GetBackendJobCommandOutput + | GetTokenCommandOutput + | ListBackendJobsCommandOutput + | RemoveAllBackendsCommandOutput + | RemoveBackendConfigCommandOutput + | UpdateBackendAPICommandOutput + | UpdateBackendAuthCommandOutput + | UpdateBackendConfigCommandOutput + | UpdateBackendJobCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type AmplifyBackendClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type AmplifyBackendClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

AWS Amplify Admin API

+ */ +export class AmplifyBackendClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + AmplifyBackendClientResolvedConfig +> { + readonly config: AmplifyBackendClientResolvedConfig; + + constructor(configuration: AmplifyBackendClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-amplifybackend/LICENSE b/clients/client-amplifybackend/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-amplifybackend/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-amplifybackend/README.md b/clients/client-amplifybackend/README.md new file mode 100644 index 000000000000..a9536c7cbe27 --- /dev/null +++ b/clients/client-amplifybackend/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-amplifybackend + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-amplifybackend/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-amplifybackend) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-amplifybackend.svg)](https://www.npmjs.com/package/@aws-sdk/client-amplifybackend) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-amplifybackend/commands/CloneBackendCommand.ts b/clients/client-amplifybackend/commands/CloneBackendCommand.ts new file mode 100644 index 000000000000..c815afdc69fc --- /dev/null +++ b/clients/client-amplifybackend/commands/CloneBackendCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CloneBackendRequest, CloneBackendResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CloneBackendCommand, + serializeAws_restJson1CloneBackendCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CloneBackendCommandInput = CloneBackendRequest; +export type CloneBackendCommandOutput = CloneBackendResponse & __MetadataBearer; + +/** + *

This operation clones an existing backend.

+ */ +export class CloneBackendCommand extends $Command< + CloneBackendCommandInput, + CloneBackendCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CloneBackendCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CloneBackendCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CloneBackendRequest.filterSensitiveLog, + outputFilterSensitiveLog: CloneBackendResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CloneBackendCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CloneBackendCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CloneBackendCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/CreateBackendAPICommand.ts b/clients/client-amplifybackend/commands/CreateBackendAPICommand.ts new file mode 100644 index 000000000000..8c6d617f9478 --- /dev/null +++ b/clients/client-amplifybackend/commands/CreateBackendAPICommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CreateBackendAPIRequest, CreateBackendAPIResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateBackendAPICommand, + serializeAws_restJson1CreateBackendAPICommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateBackendAPICommandInput = CreateBackendAPIRequest; +export type CreateBackendAPICommandOutput = CreateBackendAPIResponse & __MetadataBearer; + +/** + *

Creates a new backend API resource.

+ */ +export class CreateBackendAPICommand extends $Command< + CreateBackendAPICommandInput, + CreateBackendAPICommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateBackendAPICommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CreateBackendAPICommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateBackendAPIRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateBackendAPIResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateBackendAPICommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateBackendAPICommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateBackendAPICommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/CreateBackendAuthCommand.ts b/clients/client-amplifybackend/commands/CreateBackendAuthCommand.ts new file mode 100644 index 000000000000..de98dd804402 --- /dev/null +++ b/clients/client-amplifybackend/commands/CreateBackendAuthCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CreateBackendAuthRequest, CreateBackendAuthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateBackendAuthCommand, + serializeAws_restJson1CreateBackendAuthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateBackendAuthCommandInput = CreateBackendAuthRequest; +export type CreateBackendAuthCommandOutput = CreateBackendAuthResponse & __MetadataBearer; + +/** + *

Creates a new backend authentication resource.

+ */ +export class CreateBackendAuthCommand extends $Command< + CreateBackendAuthCommandInput, + CreateBackendAuthCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateBackendAuthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CreateBackendAuthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateBackendAuthRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateBackendAuthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateBackendAuthCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateBackendAuthCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateBackendAuthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/CreateBackendCommand.ts b/clients/client-amplifybackend/commands/CreateBackendCommand.ts new file mode 100644 index 000000000000..7a91cab86ce7 --- /dev/null +++ b/clients/client-amplifybackend/commands/CreateBackendCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CreateBackendRequest, CreateBackendResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateBackendCommand, + serializeAws_restJson1CreateBackendCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateBackendCommandInput = CreateBackendRequest; +export type CreateBackendCommandOutput = CreateBackendResponse & __MetadataBearer; + +/** + *

This operation creates a backend for an Amplify app. Backends are automatically created at the time of app creation.

+ */ +export class CreateBackendCommand extends $Command< + CreateBackendCommandInput, + CreateBackendCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateBackendCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CreateBackendCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateBackendRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateBackendResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateBackendCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateBackendCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateBackendCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/CreateBackendConfigCommand.ts b/clients/client-amplifybackend/commands/CreateBackendConfigCommand.ts new file mode 100644 index 000000000000..beed2fdce68a --- /dev/null +++ b/clients/client-amplifybackend/commands/CreateBackendConfigCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CreateBackendConfigRequest, CreateBackendConfigResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateBackendConfigCommand, + serializeAws_restJson1CreateBackendConfigCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateBackendConfigCommandInput = CreateBackendConfigRequest; +export type CreateBackendConfigCommandOutput = CreateBackendConfigResponse & __MetadataBearer; + +/** + *

Creates a config object for a backend.

+ */ +export class CreateBackendConfigCommand extends $Command< + CreateBackendConfigCommandInput, + CreateBackendConfigCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateBackendConfigCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CreateBackendConfigCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateBackendConfigRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateBackendConfigResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateBackendConfigCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateBackendConfigCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateBackendConfigCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/CreateTokenCommand.ts b/clients/client-amplifybackend/commands/CreateTokenCommand.ts new file mode 100644 index 000000000000..5fe9ee32fe27 --- /dev/null +++ b/clients/client-amplifybackend/commands/CreateTokenCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { CreateTokenRequest, CreateTokenResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateTokenCommand, + serializeAws_restJson1CreateTokenCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateTokenCommandInput = CreateTokenRequest; +export type CreateTokenCommandOutput = CreateTokenResponse & __MetadataBearer; + +/** + *

Generates a one time challenge code to authenticate a user into your Amplify Admin UI.

+ */ +export class CreateTokenCommand extends $Command< + CreateTokenCommandInput, + CreateTokenCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateTokenCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "CreateTokenCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateTokenRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateTokenResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateTokenCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateTokenCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateTokenCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/DeleteBackendAPICommand.ts b/clients/client-amplifybackend/commands/DeleteBackendAPICommand.ts new file mode 100644 index 000000000000..38d076f456a7 --- /dev/null +++ b/clients/client-amplifybackend/commands/DeleteBackendAPICommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { DeleteBackendAPIRequest, DeleteBackendAPIResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteBackendAPICommand, + serializeAws_restJson1DeleteBackendAPICommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteBackendAPICommandInput = DeleteBackendAPIRequest; +export type DeleteBackendAPICommandOutput = DeleteBackendAPIResponse & __MetadataBearer; + +/** + *

Deletes an existing backend API resource.

+ */ +export class DeleteBackendAPICommand extends $Command< + DeleteBackendAPICommandInput, + DeleteBackendAPICommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteBackendAPICommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "DeleteBackendAPICommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteBackendAPIRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteBackendAPIResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteBackendAPICommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteBackendAPICommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteBackendAPICommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/DeleteBackendAuthCommand.ts b/clients/client-amplifybackend/commands/DeleteBackendAuthCommand.ts new file mode 100644 index 000000000000..d975b859f741 --- /dev/null +++ b/clients/client-amplifybackend/commands/DeleteBackendAuthCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { DeleteBackendAuthRequest, DeleteBackendAuthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteBackendAuthCommand, + serializeAws_restJson1DeleteBackendAuthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteBackendAuthCommandInput = DeleteBackendAuthRequest; +export type DeleteBackendAuthCommandOutput = DeleteBackendAuthResponse & __MetadataBearer; + +/** + *

Deletes an existing backend authentication resource.

+ */ +export class DeleteBackendAuthCommand extends $Command< + DeleteBackendAuthCommandInput, + DeleteBackendAuthCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteBackendAuthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "DeleteBackendAuthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteBackendAuthRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteBackendAuthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteBackendAuthCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteBackendAuthCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteBackendAuthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/DeleteBackendCommand.ts b/clients/client-amplifybackend/commands/DeleteBackendCommand.ts new file mode 100644 index 000000000000..78dcb1503295 --- /dev/null +++ b/clients/client-amplifybackend/commands/DeleteBackendCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { DeleteBackendRequest, DeleteBackendResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteBackendCommand, + serializeAws_restJson1DeleteBackendCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteBackendCommandInput = DeleteBackendRequest; +export type DeleteBackendCommandOutput = DeleteBackendResponse & __MetadataBearer; + +/** + *

Removes an existing environment from your Ampify project.

+ */ +export class DeleteBackendCommand extends $Command< + DeleteBackendCommandInput, + DeleteBackendCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteBackendCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "DeleteBackendCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteBackendRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteBackendResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteBackendCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteBackendCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteBackendCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/DeleteTokenCommand.ts b/clients/client-amplifybackend/commands/DeleteTokenCommand.ts new file mode 100644 index 000000000000..e5d9f3f59607 --- /dev/null +++ b/clients/client-amplifybackend/commands/DeleteTokenCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { DeleteTokenRequest, DeleteTokenResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteTokenCommand, + serializeAws_restJson1DeleteTokenCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteTokenCommandInput = DeleteTokenRequest; +export type DeleteTokenCommandOutput = DeleteTokenResponse & __MetadataBearer; + +/** + *

Deletes the challenge token based on the given appId and sessionId.

+ */ +export class DeleteTokenCommand extends $Command< + DeleteTokenCommandInput, + DeleteTokenCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteTokenCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "DeleteTokenCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteTokenRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteTokenResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteTokenCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteTokenCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteTokenCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GenerateBackendAPIModelsCommand.ts b/clients/client-amplifybackend/commands/GenerateBackendAPIModelsCommand.ts new file mode 100644 index 000000000000..7213fcac6460 --- /dev/null +++ b/clients/client-amplifybackend/commands/GenerateBackendAPIModelsCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GenerateBackendAPIModelsRequest, GenerateBackendAPIModelsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GenerateBackendAPIModelsCommand, + serializeAws_restJson1GenerateBackendAPIModelsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GenerateBackendAPIModelsCommandInput = GenerateBackendAPIModelsRequest; +export type GenerateBackendAPIModelsCommandOutput = GenerateBackendAPIModelsResponse & __MetadataBearer; + +/** + *

Generates a model schema for an existing backend API resource.

+ */ +export class GenerateBackendAPIModelsCommand extends $Command< + GenerateBackendAPIModelsCommandInput, + GenerateBackendAPIModelsCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GenerateBackendAPIModelsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GenerateBackendAPIModelsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GenerateBackendAPIModelsRequest.filterSensitiveLog, + outputFilterSensitiveLog: GenerateBackendAPIModelsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GenerateBackendAPIModelsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GenerateBackendAPIModelsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GenerateBackendAPIModelsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetBackendAPICommand.ts b/clients/client-amplifybackend/commands/GetBackendAPICommand.ts new file mode 100644 index 000000000000..55031c3a3274 --- /dev/null +++ b/clients/client-amplifybackend/commands/GetBackendAPICommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetBackendAPIRequest, GetBackendAPIResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetBackendAPICommand, + serializeAws_restJson1GetBackendAPICommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetBackendAPICommandInput = GetBackendAPIRequest; +export type GetBackendAPICommandOutput = GetBackendAPIResponse & __MetadataBearer; + +/** + *

Gets the details for a backend api.

+ */ +export class GetBackendAPICommand extends $Command< + GetBackendAPICommandInput, + GetBackendAPICommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetBackendAPICommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetBackendAPICommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetBackendAPIRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetBackendAPIResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetBackendAPICommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetBackendAPICommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetBackendAPICommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetBackendAPIModelsCommand.ts b/clients/client-amplifybackend/commands/GetBackendAPIModelsCommand.ts new file mode 100644 index 000000000000..c701048618c1 --- /dev/null +++ b/clients/client-amplifybackend/commands/GetBackendAPIModelsCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetBackendAPIModelsRequest, GetBackendAPIModelsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetBackendAPIModelsCommand, + serializeAws_restJson1GetBackendAPIModelsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetBackendAPIModelsCommandInput = GetBackendAPIModelsRequest; +export type GetBackendAPIModelsCommandOutput = GetBackendAPIModelsResponse & __MetadataBearer; + +/** + *

Generates a model schema for existing backend API resource.

+ */ +export class GetBackendAPIModelsCommand extends $Command< + GetBackendAPIModelsCommandInput, + GetBackendAPIModelsCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetBackendAPIModelsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetBackendAPIModelsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetBackendAPIModelsRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetBackendAPIModelsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetBackendAPIModelsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetBackendAPIModelsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetBackendAPIModelsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetBackendAuthCommand.ts b/clients/client-amplifybackend/commands/GetBackendAuthCommand.ts new file mode 100644 index 000000000000..684eb18bba6a --- /dev/null +++ b/clients/client-amplifybackend/commands/GetBackendAuthCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetBackendAuthRequest, GetBackendAuthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetBackendAuthCommand, + serializeAws_restJson1GetBackendAuthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetBackendAuthCommandInput = GetBackendAuthRequest; +export type GetBackendAuthCommandOutput = GetBackendAuthResponse & __MetadataBearer; + +/** + *

Gets a backend auth details.

+ */ +export class GetBackendAuthCommand extends $Command< + GetBackendAuthCommandInput, + GetBackendAuthCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetBackendAuthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetBackendAuthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetBackendAuthRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetBackendAuthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetBackendAuthCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetBackendAuthCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetBackendAuthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetBackendCommand.ts b/clients/client-amplifybackend/commands/GetBackendCommand.ts new file mode 100644 index 000000000000..14b938ab2113 --- /dev/null +++ b/clients/client-amplifybackend/commands/GetBackendCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetBackendRequest, GetBackendResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetBackendCommand, + serializeAws_restJson1GetBackendCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetBackendCommandInput = GetBackendRequest; +export type GetBackendCommandOutput = GetBackendResponse & __MetadataBearer; + +/** + *

Provides project level details for your Amplify UI project.

+ */ +export class GetBackendCommand extends $Command< + GetBackendCommandInput, + GetBackendCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetBackendCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetBackendCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetBackendRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetBackendResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetBackendCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetBackendCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetBackendCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetBackendJobCommand.ts b/clients/client-amplifybackend/commands/GetBackendJobCommand.ts new file mode 100644 index 000000000000..cdf94b437d00 --- /dev/null +++ b/clients/client-amplifybackend/commands/GetBackendJobCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetBackendJobRequest, GetBackendJobResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetBackendJobCommand, + serializeAws_restJson1GetBackendJobCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetBackendJobCommandInput = GetBackendJobRequest; +export type GetBackendJobCommandOutput = GetBackendJobResponse & __MetadataBearer; + +/** + *

Returns information about a specific job.

+ */ +export class GetBackendJobCommand extends $Command< + GetBackendJobCommandInput, + GetBackendJobCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetBackendJobCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetBackendJobCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetBackendJobRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetBackendJobResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetBackendJobCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetBackendJobCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetBackendJobCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/GetTokenCommand.ts b/clients/client-amplifybackend/commands/GetTokenCommand.ts new file mode 100644 index 000000000000..05911cdfa47e --- /dev/null +++ b/clients/client-amplifybackend/commands/GetTokenCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { GetTokenRequest, GetTokenResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetTokenCommand, + serializeAws_restJson1GetTokenCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetTokenCommandInput = GetTokenRequest; +export type GetTokenCommandOutput = GetTokenResponse & __MetadataBearer; + +/** + *

Gets the challenge token based on the given appId and sessionId.

+ */ +export class GetTokenCommand extends $Command< + GetTokenCommandInput, + GetTokenCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetTokenCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "GetTokenCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetTokenRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetTokenResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetTokenCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetTokenCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetTokenCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/ListBackendJobsCommand.ts b/clients/client-amplifybackend/commands/ListBackendJobsCommand.ts new file mode 100644 index 000000000000..81df36ae2949 --- /dev/null +++ b/clients/client-amplifybackend/commands/ListBackendJobsCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { ListBackendJobsRequest, ListBackendJobsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListBackendJobsCommand, + serializeAws_restJson1ListBackendJobsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListBackendJobsCommandInput = ListBackendJobsRequest; +export type ListBackendJobsCommandOutput = ListBackendJobsResponse & __MetadataBearer; + +/** + *

Lists the jobs for the backend of an Amplify app.

+ */ +export class ListBackendJobsCommand extends $Command< + ListBackendJobsCommandInput, + ListBackendJobsCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListBackendJobsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "ListBackendJobsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListBackendJobsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListBackendJobsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListBackendJobsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListBackendJobsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListBackendJobsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/RemoveAllBackendsCommand.ts b/clients/client-amplifybackend/commands/RemoveAllBackendsCommand.ts new file mode 100644 index 000000000000..8ef08a42135b --- /dev/null +++ b/clients/client-amplifybackend/commands/RemoveAllBackendsCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { RemoveAllBackendsRequest, RemoveAllBackendsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1RemoveAllBackendsCommand, + serializeAws_restJson1RemoveAllBackendsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type RemoveAllBackendsCommandInput = RemoveAllBackendsRequest; +export type RemoveAllBackendsCommandOutput = RemoveAllBackendsResponse & __MetadataBearer; + +/** + *

Removes all backend environments from your Amplify project.

+ */ +export class RemoveAllBackendsCommand extends $Command< + RemoveAllBackendsCommandInput, + RemoveAllBackendsCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: RemoveAllBackendsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "RemoveAllBackendsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: RemoveAllBackendsRequest.filterSensitiveLog, + outputFilterSensitiveLog: RemoveAllBackendsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: RemoveAllBackendsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1RemoveAllBackendsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1RemoveAllBackendsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/RemoveBackendConfigCommand.ts b/clients/client-amplifybackend/commands/RemoveBackendConfigCommand.ts new file mode 100644 index 000000000000..b10546f809af --- /dev/null +++ b/clients/client-amplifybackend/commands/RemoveBackendConfigCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { RemoveBackendConfigRequest, RemoveBackendConfigResponse } from "../models/models_0"; +import { + deserializeAws_restJson1RemoveBackendConfigCommand, + serializeAws_restJson1RemoveBackendConfigCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type RemoveBackendConfigCommandInput = RemoveBackendConfigRequest; +export type RemoveBackendConfigCommandOutput = RemoveBackendConfigResponse & __MetadataBearer; + +/** + *

Removes the AWS resources required to access the Amplify Admin UI.

+ */ +export class RemoveBackendConfigCommand extends $Command< + RemoveBackendConfigCommandInput, + RemoveBackendConfigCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: RemoveBackendConfigCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "RemoveBackendConfigCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: RemoveBackendConfigRequest.filterSensitiveLog, + outputFilterSensitiveLog: RemoveBackendConfigResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: RemoveBackendConfigCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1RemoveBackendConfigCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1RemoveBackendConfigCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/UpdateBackendAPICommand.ts b/clients/client-amplifybackend/commands/UpdateBackendAPICommand.ts new file mode 100644 index 000000000000..2ad68d8b599f --- /dev/null +++ b/clients/client-amplifybackend/commands/UpdateBackendAPICommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { UpdateBackendAPIRequest, UpdateBackendAPIResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateBackendAPICommand, + serializeAws_restJson1UpdateBackendAPICommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateBackendAPICommandInput = UpdateBackendAPIRequest; +export type UpdateBackendAPICommandOutput = UpdateBackendAPIResponse & __MetadataBearer; + +/** + *

Updates an existing backend API resource.

+ */ +export class UpdateBackendAPICommand extends $Command< + UpdateBackendAPICommandInput, + UpdateBackendAPICommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateBackendAPICommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "UpdateBackendAPICommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateBackendAPIRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateBackendAPIResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateBackendAPICommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateBackendAPICommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateBackendAPICommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/UpdateBackendAuthCommand.ts b/clients/client-amplifybackend/commands/UpdateBackendAuthCommand.ts new file mode 100644 index 000000000000..9c0edcb8254e --- /dev/null +++ b/clients/client-amplifybackend/commands/UpdateBackendAuthCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { UpdateBackendAuthRequest, UpdateBackendAuthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateBackendAuthCommand, + serializeAws_restJson1UpdateBackendAuthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateBackendAuthCommandInput = UpdateBackendAuthRequest; +export type UpdateBackendAuthCommandOutput = UpdateBackendAuthResponse & __MetadataBearer; + +/** + *

Updates an existing backend authentication resource.

+ */ +export class UpdateBackendAuthCommand extends $Command< + UpdateBackendAuthCommandInput, + UpdateBackendAuthCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateBackendAuthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "UpdateBackendAuthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateBackendAuthRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateBackendAuthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateBackendAuthCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateBackendAuthCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateBackendAuthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/UpdateBackendConfigCommand.ts b/clients/client-amplifybackend/commands/UpdateBackendConfigCommand.ts new file mode 100644 index 000000000000..7e633ab3635a --- /dev/null +++ b/clients/client-amplifybackend/commands/UpdateBackendConfigCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { UpdateBackendConfigRequest, UpdateBackendConfigResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateBackendConfigCommand, + serializeAws_restJson1UpdateBackendConfigCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateBackendConfigCommandInput = UpdateBackendConfigRequest; +export type UpdateBackendConfigCommandOutput = UpdateBackendConfigResponse & __MetadataBearer; + +/** + *

Updates the AWS resources required to access the Amplify Admin UI.

+ */ +export class UpdateBackendConfigCommand extends $Command< + UpdateBackendConfigCommandInput, + UpdateBackendConfigCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateBackendConfigCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "UpdateBackendConfigCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateBackendConfigRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateBackendConfigResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateBackendConfigCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateBackendConfigCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateBackendConfigCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/commands/UpdateBackendJobCommand.ts b/clients/client-amplifybackend/commands/UpdateBackendJobCommand.ts new file mode 100644 index 000000000000..99f3e909c417 --- /dev/null +++ b/clients/client-amplifybackend/commands/UpdateBackendJobCommand.ts @@ -0,0 +1,88 @@ +import { AmplifyBackendClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AmplifyBackendClient"; +import { UpdateBackendJobRequest, UpdateBackendJobResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateBackendJobCommand, + serializeAws_restJson1UpdateBackendJobCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateBackendJobCommandInput = UpdateBackendJobRequest; +export type UpdateBackendJobCommandOutput = UpdateBackendJobResponse & __MetadataBearer; + +/** + *

Updates a specific job.

+ */ +export class UpdateBackendJobCommand extends $Command< + UpdateBackendJobCommandInput, + UpdateBackendJobCommandOutput, + AmplifyBackendClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateBackendJobCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AmplifyBackendClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AmplifyBackendClient"; + const commandName = "UpdateBackendJobCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateBackendJobRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateBackendJobResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateBackendJobCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateBackendJobCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateBackendJobCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-amplifybackend/endpoints.ts b/clients/client-amplifybackend/endpoints.ts new file mode 100644 index 000000000000..afd16e8e49b0 --- /dev/null +++ b/clients/client-amplifybackend/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "amplifybackend.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "amplifybackend.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "amplifybackend.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "amplifybackend.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "amplifybackend.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-amplifybackend/index.ts b/clients/client-amplifybackend/index.ts new file mode 100644 index 000000000000..d8c74182c9c4 --- /dev/null +++ b/clients/client-amplifybackend/index.ts @@ -0,0 +1,27 @@ +export * from "./AmplifyBackendClient"; +export * from "./AmplifyBackend"; +export * from "./commands/CloneBackendCommand"; +export * from "./commands/CreateBackendCommand"; +export * from "./commands/CreateBackendAPICommand"; +export * from "./commands/CreateBackendAuthCommand"; +export * from "./commands/CreateBackendConfigCommand"; +export * from "./commands/CreateTokenCommand"; +export * from "./commands/DeleteBackendCommand"; +export * from "./commands/DeleteBackendAPICommand"; +export * from "./commands/DeleteBackendAuthCommand"; +export * from "./commands/DeleteTokenCommand"; +export * from "./commands/GenerateBackendAPIModelsCommand"; +export * from "./commands/GetBackendCommand"; +export * from "./commands/GetBackendAPICommand"; +export * from "./commands/GetBackendAPIModelsCommand"; +export * from "./commands/GetBackendAuthCommand"; +export * from "./commands/GetBackendJobCommand"; +export * from "./commands/GetTokenCommand"; +export * from "./commands/ListBackendJobsCommand"; +export * from "./commands/RemoveAllBackendsCommand"; +export * from "./commands/RemoveBackendConfigCommand"; +export * from "./commands/UpdateBackendAPICommand"; +export * from "./commands/UpdateBackendAuthCommand"; +export * from "./commands/UpdateBackendConfigCommand"; +export * from "./commands/UpdateBackendJobCommand"; +export * from "./models/index"; diff --git a/clients/client-amplifybackend/models/index.ts b/clients/client-amplifybackend/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-amplifybackend/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-amplifybackend/models/models_0.ts b/clients/client-amplifybackend/models/models_0.ts new file mode 100644 index 000000000000..6abbc5a0b439 --- /dev/null +++ b/clients/client-amplifybackend/models/models_0.ts @@ -0,0 +1,2304 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +export enum AdditionalConstraintsElement { + REQUIRE_DIGIT = "REQUIRE_DIGIT", + REQUIRE_LOWERCASE = "REQUIRE_LOWERCASE", + REQUIRE_SYMBOL = "REQUIRE_SYMBOL", + REQUIRE_UPPERCASE = "REQUIRE_UPPERCASE", +} + +/** + *

An error returned if a request is not formed properly.

+ */ +export interface BadRequestException extends __SmithyException, $MetadataBearer { + name: "BadRequestException"; + $fault: "client"; + /** + *

An error message to inform that the request has failed.

+ */ + Message?: string; +} + +export namespace BadRequestException { + export const filterSensitiveLog = (obj: BadRequestException): any => ({ + ...obj, + }); +} + +/** + *

The request body for CloneBackend.

+ */ +export interface CloneBackendRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The name of the destination backend environment to be created.

+ */ + TargetEnvironmentName: string | undefined; +} + +export namespace CloneBackendRequest { + export const filterSensitiveLog = (obj: CloneBackendRequest): any => ({ + ...obj, + }); +} + +export interface CloneBackendResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace CloneBackendResponse { + export const filterSensitiveLog = (obj: CloneBackendResponse): any => ({ + ...obj, + }); +} + +/** + *

An error returned if there's a temporary issue with the service.

+ */ +export interface GatewayTimeoutException extends __SmithyException, $MetadataBearer { + name: "GatewayTimeoutException"; + $fault: "server"; + /** + *

An error message to inform that the request has failed.

+ */ + Message?: string; +} + +export namespace GatewayTimeoutException { + export const filterSensitiveLog = (obj: GatewayTimeoutException): any => ({ + ...obj, + }); +} + +/** + *

An error returned when a specific resource type is not found.

+ */ +export interface NotFoundException extends __SmithyException, $MetadataBearer { + name: "NotFoundException"; + $fault: "client"; + /** + *

An error message to inform that the request has failed.

+ */ + Message?: string; + + /** + *

The type of resource that wasn't found.

+ */ + ResourceType?: string; +} + +export namespace NotFoundException { + export const filterSensitiveLog = (obj: NotFoundException): any => ({ + ...obj, + }); +} + +/** + *

An error that is returned when a limit of a specific type has been exceeded.

+ */ +export interface TooManyRequestsException extends __SmithyException, $MetadataBearer { + name: "TooManyRequestsException"; + $fault: "client"; + /** + *

The type of limit that was exceeded.

+ */ + LimitType?: string; + + /** + *

An error message to inform that the request has failed.

+ */ + Message?: string; +} + +export namespace TooManyRequestsException { + export const filterSensitiveLog = (obj: TooManyRequestsException): any => ({ + ...obj, + }); +} + +/** + *

Defines the resource configuration for the data model in your Amplify project.

+ */ +export interface ResourceConfig {} + +export namespace ResourceConfig { + export const filterSensitiveLog = (obj: ResourceConfig): any => ({ + ...obj, + }); +} + +/** + *

The request body for CreateBackend.

+ */ +export interface CreateBackendRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the app.

+ */ + AppName: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The resource configuration for the create backend request.

+ */ + ResourceConfig?: ResourceConfig; + + /** + *

The name of the resource.

+ */ + ResourceName?: string; +} + +export namespace CreateBackendRequest { + export const filterSensitiveLog = (obj: CreateBackendRequest): any => ({ + ...obj, + }); +} + +export interface CreateBackendResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace CreateBackendResponse { + export const filterSensitiveLog = (obj: CreateBackendResponse): any => ({ + ...obj, + }); +} + +export enum Mode { + AMAZON_COGNITO_USER_POOLS = "AMAZON_COGNITO_USER_POOLS", + API_KEY = "API_KEY", + AWS_IAM = "AWS_IAM", + OPENID_CONNECT = "OPENID_CONNECT", +} + +/** + *

The authentication settings for accessing provisioned data models in your Amplify project.

+ */ +export interface BackendAPIAppSyncAuthSettings { + /** + *

The Amazon Cognito user pool id, if Amazon Cognito was used as an authentication setting to access your data models.

+ */ + CognitoUserPoolId?: string; + + /** + *

The api key description for API_KEY, if it was used as an authentication mechanism to access your data models.

+ */ + Description?: string; + + /** + *

The api key expiration time for API_KEY, if it was used as an authentication mechanism to access your data models.

+ */ + ExpirationTime?: number; + + /** + *

The expiry time for the OpenID authentication mechanism.

+ */ + OpenIDAuthTTL?: string; + + /** + *

The clientID for openID, if openID was used as an authentication setting to access your data models.

+ */ + OpenIDClientId?: string; + + /** + *

The expiry time for the OpenID authentication mechanism.

+ */ + OpenIDIatTTL?: string; + + /** + *

The openID issuer URL, if openID was used as an authentication setting to access your data models.

+ */ + OpenIDIssueURL?: string; + + /** + *

The open id provider name, if openID was used as an authentication mechanism to access your data models.

+ */ + OpenIDProviderName?: string; +} + +export namespace BackendAPIAppSyncAuthSettings { + export const filterSensitiveLog = (obj: BackendAPIAppSyncAuthSettings): any => ({ + ...obj, + }); +} + +/** + *

Describes the auth types for your configured data models.

+ */ +export interface BackendAPIAuthType { + /** + *

Describes the authentication mode.

+ */ + Mode?: Mode | string; + + /** + *

Describes settings for the authentication mode.

+ */ + Settings?: BackendAPIAppSyncAuthSettings; +} + +export namespace BackendAPIAuthType { + export const filterSensitiveLog = (obj: BackendAPIAuthType): any => ({ + ...obj, + }); +} + +export enum ResolutionStrategy { + AUTOMERGE = "AUTOMERGE", + LAMBDA = "LAMBDA", + NONE = "NONE", + OPTIMISTIC_CONCURRENCY = "OPTIMISTIC_CONCURRENCY", +} + +/** + *

Describes the conflict resolution configuration for your data model configured in your Amplify project.

+ */ +export interface BackendAPIConflictResolution { + /** + *

The strategy for conflict resolution.

+ */ + ResolutionStrategy?: ResolutionStrategy | string; +} + +export namespace BackendAPIConflictResolution { + export const filterSensitiveLog = (obj: BackendAPIConflictResolution): any => ({ + ...obj, + }); +} + +/** + *

The resource config for the data model,configured as a part of the Amplify project.

+ */ +export interface BackendAPIResourceConfig { + /** + *

Addition authentication methods used to interact with your data models.

+ */ + AdditionalAuthTypes?: BackendAPIAuthType[]; + + /** + *

The API name used to interact with the data model, configured as a part of the amplify project.

+ */ + ApiName?: string; + + /** + *

The conflict resoultion strategy for your data stored in the data models.

+ */ + ConflictResolution?: BackendAPIConflictResolution; + + /** + *

The default authentication type for interacting with the configured data models in your amplify project.

+ */ + DefaultAuthType?: BackendAPIAuthType; + + /** + *

The service used to provision and interact with the data model.

+ */ + Service?: string; + + /** + *

The definition of the data model in the annotated transform of the graphql schema.

+ */ + TransformSchema?: string; +} + +export namespace BackendAPIResourceConfig { + export const filterSensitiveLog = (obj: BackendAPIResourceConfig): any => ({ + ...obj, + }); +} + +/** + *

The request body for CreateBackendAPI.

+ */ +export interface CreateBackendAPIRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The resource configuration for this request.

+ */ + ResourceConfig: BackendAPIResourceConfig | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace CreateBackendAPIRequest { + export const filterSensitiveLog = (obj: CreateBackendAPIRequest): any => ({ + ...obj, + }); +} + +export interface CreateBackendAPIResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace CreateBackendAPIResponse { + export const filterSensitiveLog = (obj: CreateBackendAPIResponse): any => ({ + ...obj, + }); +} + +export enum AuthResources { + IDENTITY_POOL_AND_USER_POOL = "IDENTITY_POOL_AND_USER_POOL", + USER_POOL_ONLY = "USER_POOL_ONLY", +} + +/** + *

Describes authorization configurations for the auth resources, configures as a part of your Amplify project.

+ */ +export interface CreateBackendAuthIdentityPoolConfig { + /** + *

Name of the identity pool used for authorization.

+ */ + IdentityPoolName: string | undefined; + + /** + *

Set to true or false based on whether you want to enable guest authorization to your Amplify app.

+ */ + UnauthenticatedLogin: boolean | undefined; +} + +export namespace CreateBackendAuthIdentityPoolConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthIdentityPoolConfig): any => ({ + ...obj, + }); +} + +export enum Service { + COGNITO = "COGNITO", +} + +export enum DeliveryMethod { + EMAIL = "EMAIL", + SMS = "SMS", +} + +/** + *

The configuration for the email sent when an app user forgets their password.

+ */ +export interface EmailSettings { + /** + *

The body of the email.

+ */ + EmailMessage?: string; + + /** + *

The subject of the email.

+ */ + EmailSubject?: string; +} + +export namespace EmailSettings { + export const filterSensitiveLog = (obj: EmailSettings): any => ({ + ...obj, + }); +} + +/** + *

SMS settings for authentication.

+ */ +export interface SmsSettings { + /** + *

The body of the SMS message.

+ */ + SmsMessage?: string; +} + +export namespace SmsSettings { + export const filterSensitiveLog = (obj: SmsSettings): any => ({ + ...obj, + }); +} + +/** + *

Describes the forgot password policy for authenticating into the Amlify app.

+ */ +export interface CreateBackendAuthForgotPasswordConfig { + /** + *

Describes which mode to use (either SMS or email) to deliver messages to app users that want to recover their password.

+ */ + DeliveryMethod: DeliveryMethod | string | undefined; + + /** + *

The configuration for the email sent when an app user forgets their password.

+ */ + EmailSettings?: EmailSettings; + + /** + *

The configuration for the SMS message sent when an app user forgets their password.

+ */ + SmsSettings?: SmsSettings; +} + +export namespace CreateBackendAuthForgotPasswordConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthForgotPasswordConfig): any => ({ + ...obj, + }); +} + +export enum MFAMode { + OFF = "OFF", + ON = "ON", + OPTIONAL = "OPTIONAL", +} + +export enum MfaTypesElement { + SMS = "SMS", + TOTP = "TOTP", +} + +/** + *

The settings of your MFA configuration for the backend of your Amplify project.

+ */ +export interface Settings { + /** + *

The supported MFA types

+ */ + MfaTypes?: (MfaTypesElement | string)[]; + + /** + *

The body of the SMS message.

+ */ + SmsMessage?: string; +} + +export namespace Settings { + export const filterSensitiveLog = (obj: Settings): any => ({ + ...obj, + }); +} + +/** + *

Describes whether multi-factor authentication policies should be applied for your Amazon Cognito user pool configured as a part of your Amplify project.

+ */ +export interface CreateBackendAuthMFAConfig { + /** + *

Describes whether MFA should be [ON, OFF, OPTIONAL] for authentication in your Amplify project.

+ */ + MFAMode: MFAMode | string | undefined; + + /** + *

Describes the configuration settings and methods for your Amplify app users to use MFA.

+ */ + Settings?: Settings; +} + +export namespace CreateBackendAuthMFAConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthMFAConfig): any => ({ + ...obj, + }); +} + +export enum OAuthGrantType { + CODE = "CODE", + IMPLICIT = "IMPLICIT", +} + +export enum OAuthScopesElement { + AWS_COGNITO_SIGNIN_USER_ADMIN = "AWS_COGNITO_SIGNIN_USER_ADMIN", + EMAIL = "EMAIL", + OPENID = "OPENID", + PHONE = "PHONE", + PROFILE = "PROFILE", +} + +/** + *

Describes third party social federation configurations for allowing your app users to sign in using OAuth.

+ */ +export interface BackendAuthSocialProviderConfig { + /** + *

Describes the client_id which can be obtained from the third party social federation provider.

+ */ + ClientId?: string; + + /** + *

Describes the client_secret which can be obtained from third party social federation providers.

+ */ + ClientSecret?: string; +} + +export namespace BackendAuthSocialProviderConfig { + export const filterSensitiveLog = (obj: BackendAuthSocialProviderConfig): any => ({ + ...obj, + }); +} + +/** + *

The settings for using the social providers for access to your Amplify app.

+ */ +export interface SocialProviderSettings { + /** + *

Describes third party social federation configurations for allowing your app users to sign in using OAuth.

+ */ + Facebook?: BackendAuthSocialProviderConfig; + + /** + *

Describes third party social federation configurations for allowing your app users to sign in using OAuth.

+ */ + Google?: BackendAuthSocialProviderConfig; + + /** + *

Describes third party social federation configurations for allowing your app users to sign in using OAuth.

+ */ + LoginWithAmazon?: BackendAuthSocialProviderConfig; +} + +export namespace SocialProviderSettings { + export const filterSensitiveLog = (obj: SocialProviderSettings): any => ({ + ...obj, + }); +} + +/** + *

Creates the OAuth configuration for your Amplify project.

+ */ +export interface CreateBackendAuthOAuthConfig { + /** + *

The domain prefix for your Amplify app.

+ */ + DomainPrefix?: string; + + /** + *

The OAuth grant type which you use to allow app users to authenticate from your Amplify app.

+ */ + OAuthGrantType: OAuthGrantType | string | undefined; + + /** + *

List of OAuth related flows which use to allow your app users to authenticate from your Amplify app.

+ */ + OAuthScopes: (OAuthScopesElement | string)[] | undefined; + + /** + *

The redirected URI for sigining into your Amplify app.

+ */ + RedirectSignInURIs: string[] | undefined; + + /** + *

Redirect URLs used by OAuth when a user signs out of an Amplify app.

+ */ + RedirectSignOutURIs: string[] | undefined; + + /** + *

The settings for using the social providers for access to your Amplify app.

+ */ + SocialProviderSettings?: SocialProviderSettings; +} + +export namespace CreateBackendAuthOAuthConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthOAuthConfig): any => ({ + ...obj, + }); +} + +/** + *

The password policy configuration for the backend to your Amplify project.

+ */ +export interface CreateBackendAuthPasswordPolicyConfig { + /** + *

Additional constraints for the pasword used to access the backend of your Amplify project.

+ */ + AdditionalConstraints?: (AdditionalConstraintsElement | string)[]; + + /** + *

The minimum length of password used to access the backend of your Amplify project.

+ */ + MinimumLength: number | undefined; +} + +export namespace CreateBackendAuthPasswordPolicyConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthPasswordPolicyConfig): any => ({ + ...obj, + }); +} + +export enum RequiredSignUpAttributesElement { + ADDRESS = "ADDRESS", + BIRTHDATE = "BIRTHDATE", + EMAIL = "EMAIL", + FAMILY_NAME = "FAMILY_NAME", + GENDER = "GENDER", + GIVEN_NAME = "GIVEN_NAME", + LOCALE = "LOCALE", + MIDDLE_NAME = "MIDDLE_NAME", + NAME = "NAME", + NICKNAME = "NICKNAME", + PHONE_NUMBER = "PHONE_NUMBER", + PICTURE = "PICTURE", + PREFERRED_USERNAME = "PREFERRED_USERNAME", + PROFILE = "PROFILE", + UPDATED_AT = "UPDATED_AT", + WEBSITE = "WEBSITE", + ZONE_INFO = "ZONE_INFO", +} + +export enum SignInMethod { + EMAIL = "EMAIL", + EMAIL_AND_PHONE_NUMBER = "EMAIL_AND_PHONE_NUMBER", + PHONE_NUMBER = "PHONE_NUMBER", + USERNAME = "USERNAME", +} + +/** + *

Describes the Amazon Cognito user pool configuration for the auth resource to be configured for your Amplify project.

+ */ +export interface CreateBackendAuthUserPoolConfig { + /** + *

Describes the forgotten password policy for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + ForgotPassword?: CreateBackendAuthForgotPasswordConfig; + + /** + *

Describes whether multi-factor authentication policies should be applied for your Amazon Cognito user pool configured as a part of your Amplify project.

+ */ + Mfa?: CreateBackendAuthMFAConfig; + + /** + *

Describes the OAuth policy and rules for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + OAuth?: CreateBackendAuthOAuthConfig; + + /** + *

Describes the password policy for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + PasswordPolicy?: CreateBackendAuthPasswordPolicyConfig; + + /** + *

The required attributes to sign up new users in the user pool.

+ */ + RequiredSignUpAttributes: (RequiredSignUpAttributesElement | string)[] | undefined; + + /** + *

Describes the sign-in methods that your Amplify app users to login using the Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + SignInMethod: SignInMethod | string | undefined; + + /** + *

The Amazon Cognito user pool name.

+ */ + UserPoolName: string | undefined; +} + +export namespace CreateBackendAuthUserPoolConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthUserPoolConfig): any => ({ + ...obj, + }); +} + +/** + *

Defines the resource configuration when creating an auth resource in your Amplify project.

+ */ +export interface CreateBackendAuthResourceConfig { + /** + *

Defines whether you want to configure only authentication or both authentication and authorization settings.

+ */ + AuthResources: AuthResources | string | undefined; + + /** + *

Describes the authorization configuration for the Amazon Cognito identity pool, provisioned as a part of your auth resource in the Amplify project.

+ */ + IdentityPoolConfigs?: CreateBackendAuthIdentityPoolConfig; + + /** + *

Defines the service name to use when configuring an authentication resource in your Amplify project.

+ */ + Service: Service | string | undefined; + + /** + *

Describes authentication configuration for the Amazon Cognito user pool, provisioned as a part of your auth resource in the Amplify project.

+ */ + UserPoolConfigs: CreateBackendAuthUserPoolConfig | undefined; +} + +export namespace CreateBackendAuthResourceConfig { + export const filterSensitiveLog = (obj: CreateBackendAuthResourceConfig): any => ({ + ...obj, + }); +} + +/** + *

The request body for CreateBackendAuth.

+ */ +export interface CreateBackendAuthRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The resource configuration for this request object.

+ */ + ResourceConfig: CreateBackendAuthResourceConfig | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace CreateBackendAuthRequest { + export const filterSensitiveLog = (obj: CreateBackendAuthRequest): any => ({ + ...obj, + }); +} + +export interface CreateBackendAuthResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace CreateBackendAuthResponse { + export const filterSensitiveLog = (obj: CreateBackendAuthResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for CreateBackendConfig.

+ */ +export interface CreateBackendConfigRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The app ID for the backend manager.

+ */ + BackendManagerAppId?: string; +} + +export namespace CreateBackendConfigRequest { + export const filterSensitiveLog = (obj: CreateBackendConfigRequest): any => ({ + ...obj, + }); +} + +export interface CreateBackendConfigResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace CreateBackendConfigResponse { + export const filterSensitiveLog = (obj: CreateBackendConfigResponse): any => ({ + ...obj, + }); +} + +export interface CreateTokenRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; +} + +export namespace CreateTokenRequest { + export const filterSensitiveLog = (obj: CreateTokenRequest): any => ({ + ...obj, + }); +} + +export interface CreateTokenResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

One time challenge code for authenticating into Amplify Admin UI.

+ */ + ChallengeCode?: string; + + /** + *

A unique identifier provided when creating a new challenge token.

+ */ + SessionId?: string; + + /** + *

The expiry time for the one time generated token code.

+ */ + Ttl?: string; +} + +export namespace CreateTokenResponse { + export const filterSensitiveLog = (obj: CreateTokenResponse): any => ({ + ...obj, + }); +} + +export interface DeleteBackendRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; +} + +export namespace DeleteBackendRequest { + export const filterSensitiveLog = (obj: DeleteBackendRequest): any => ({ + ...obj, + }); +} + +export interface DeleteBackendResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace DeleteBackendResponse { + export const filterSensitiveLog = (obj: DeleteBackendResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for DeleteBackendAPI.

+ */ +export interface DeleteBackendAPIRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

Defines the resource configuration for the data model in your Amplify project.

+ */ + ResourceConfig?: BackendAPIResourceConfig; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace DeleteBackendAPIRequest { + export const filterSensitiveLog = (obj: DeleteBackendAPIRequest): any => ({ + ...obj, + }); +} + +export interface DeleteBackendAPIResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace DeleteBackendAPIResponse { + export const filterSensitiveLog = (obj: DeleteBackendAPIResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for DeleteBackendAuth.

+ */ +export interface DeleteBackendAuthRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace DeleteBackendAuthRequest { + export const filterSensitiveLog = (obj: DeleteBackendAuthRequest): any => ({ + ...obj, + }); +} + +export interface DeleteBackendAuthResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace DeleteBackendAuthResponse { + export const filterSensitiveLog = (obj: DeleteBackendAuthResponse): any => ({ + ...obj, + }); +} + +export interface DeleteTokenRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The session Id.

+ */ + SessionId: string | undefined; +} + +export namespace DeleteTokenRequest { + export const filterSensitiveLog = (obj: DeleteTokenRequest): any => ({ + ...obj, + }); +} + +export interface DeleteTokenResponse { + /** + *

Indicates whether the request succeeded or failed.

+ */ + IsSuccess?: boolean; +} + +export namespace DeleteTokenResponse { + export const filterSensitiveLog = (obj: DeleteTokenResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GenerateBackendAPIModels.

+ */ +export interface GenerateBackendAPIModelsRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace GenerateBackendAPIModelsRequest { + export const filterSensitiveLog = (obj: GenerateBackendAPIModelsRequest): any => ({ + ...obj, + }); +} + +export interface GenerateBackendAPIModelsResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace GenerateBackendAPIModelsResponse { + export const filterSensitiveLog = (obj: GenerateBackendAPIModelsResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GetBackend.

+ */ +export interface GetBackendRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; +} + +export namespace GetBackendRequest { + export const filterSensitiveLog = (obj: GetBackendRequest): any => ({ + ...obj, + }); +} + +export interface GetBackendResponse { + /** + *

A stringified version of the current configs for your Amplify project.

+ */ + AmplifyMetaConfig?: string; + + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the app.

+ */ + AppName?: string; + + /** + *

A list of backend environments in an array.

+ */ + BackendEnvironmentList?: string[]; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; +} + +export namespace GetBackendResponse { + export const filterSensitiveLog = (obj: GetBackendResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GetBackendAPI.

+ */ +export interface GetBackendAPIRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

Defines the resource configuration for the data model in your Amplify project.

+ */ + ResourceConfig?: BackendAPIResourceConfig; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace GetBackendAPIRequest { + export const filterSensitiveLog = (obj: GetBackendAPIRequest): any => ({ + ...obj, + }); +} + +export interface GetBackendAPIResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The resource configuration for this response object.

+ */ + ResourceConfig?: BackendAPIResourceConfig; + + /** + *

The name of this resource.

+ */ + ResourceName?: string; +} + +export namespace GetBackendAPIResponse { + export const filterSensitiveLog = (obj: GetBackendAPIResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GetBackendAPIModels.

+ */ +export interface GetBackendAPIModelsRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace GetBackendAPIModelsRequest { + export const filterSensitiveLog = (obj: GetBackendAPIModelsRequest): any => ({ + ...obj, + }); +} + +export enum Status { + LATEST = "LATEST", + STALE = "STALE", +} + +export interface GetBackendAPIModelsResponse { + /** + *

Stringified JSON of the datastore model.

+ */ + Models?: string; + + /** + *

The current status of the request.

+ */ + Status?: Status | string; +} + +export namespace GetBackendAPIModelsResponse { + export const filterSensitiveLog = (obj: GetBackendAPIModelsResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GetBackendAuth.

+ */ +export interface GetBackendAuthRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace GetBackendAuthRequest { + export const filterSensitiveLog = (obj: GetBackendAuthRequest): any => ({ + ...obj, + }); +} + +export interface GetBackendAuthResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The resource configuration for authorization requests to the backend of your Amplify project.

+ */ + ResourceConfig?: CreateBackendAuthResourceConfig; + + /** + *

The name of this resource.

+ */ + ResourceName?: string; +} + +export namespace GetBackendAuthResponse { + export const filterSensitiveLog = (obj: GetBackendAuthResponse): any => ({ + ...obj, + }); +} + +export interface GetBackendJobRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The ID for the job.

+ */ + JobId: string | undefined; +} + +export namespace GetBackendJobRequest { + export const filterSensitiveLog = (obj: GetBackendJobRequest): any => ({ + ...obj, + }); +} + +export interface GetBackendJobResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

The time when the job was created.

+ */ + CreateTime?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; + + /** + *

The time when the job was last updated.

+ */ + UpdateTime?: string; +} + +export namespace GetBackendJobResponse { + export const filterSensitiveLog = (obj: GetBackendJobResponse): any => ({ + ...obj, + }); +} + +export interface GetTokenRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The session Id.

+ */ + SessionId: string | undefined; +} + +export namespace GetTokenRequest { + export const filterSensitiveLog = (obj: GetTokenRequest): any => ({ + ...obj, + }); +} + +export interface GetTokenResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The one time challenge code for authenticating into Amplify Admin UI.

+ */ + ChallengeCode?: string; + + /** + *

A unique identifier provided when creating a new challenge token.

+ */ + SessionId?: string; + + /** + *

The expiry time for the one time generated token code.

+ */ + Ttl?: string; +} + +export namespace GetTokenResponse { + export const filterSensitiveLog = (obj: GetTokenResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for ListBackendJobs.

+ */ +export interface ListBackendJobsRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The maximum number of results you want in the response.

+ */ + MaxResults?: number; + + /** + *

The token for the next set of results.

+ */ + NextToken?: string; + + /** + *

Filters the list of response objects to only include those with the specified operation name.

+ */ + Operation?: string; + + /** + *

Filters the list of response objects to only include those with the specified status.

+ */ + Status?: string; +} + +export namespace ListBackendJobsRequest { + export const filterSensitiveLog = (obj: ListBackendJobsRequest): any => ({ + ...obj, + }); +} + +/** + *

The response object for this operation.

+ */ +export interface BackendJobRespObj { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The time when the job was created.

+ */ + CreateTime?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; + + /** + *

The time when the job was last updated.

+ */ + UpdateTime?: string; +} + +export namespace BackendJobRespObj { + export const filterSensitiveLog = (obj: BackendJobRespObj): any => ({ + ...obj, + }); +} + +export interface ListBackendJobsResponse { + /** + *

An array of jobs and their properties.

+ */ + Jobs?: BackendJobRespObj[]; + + /** + *

The token for the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListBackendJobsResponse { + export const filterSensitiveLog = (obj: ListBackendJobsResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for RemoveAllBackends.

+ */ +export interface RemoveAllBackendsRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

Cleans up the Amplify Console app if this value is set to true.

+ */ + CleanAmplifyApp?: boolean; +} + +export namespace RemoveAllBackendsRequest { + export const filterSensitiveLog = (obj: RemoveAllBackendsRequest): any => ({ + ...obj, + }); +} + +export interface RemoveAllBackendsResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace RemoveAllBackendsResponse { + export const filterSensitiveLog = (obj: RemoveAllBackendsResponse): any => ({ + ...obj, + }); +} + +export interface RemoveBackendConfigRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; +} + +export namespace RemoveBackendConfigRequest { + export const filterSensitiveLog = (obj: RemoveBackendConfigRequest): any => ({ + ...obj, + }); +} + +export interface RemoveBackendConfigResponse { + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; +} + +export namespace RemoveBackendConfigResponse { + export const filterSensitiveLog = (obj: RemoveBackendConfigResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for UpdateBackendAPI.

+ */ +export interface UpdateBackendAPIRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

Defines the resource configuration for the data model in your Amplify project.

+ */ + ResourceConfig?: BackendAPIResourceConfig; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace UpdateBackendAPIRequest { + export const filterSensitiveLog = (obj: UpdateBackendAPIRequest): any => ({ + ...obj, + }); +} + +export interface UpdateBackendAPIResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace UpdateBackendAPIResponse { + export const filterSensitiveLog = (obj: UpdateBackendAPIResponse): any => ({ + ...obj, + }); +} + +/** + *

Describes the authorization configuration for the Amazon Cognito identity pool, provisioned as a part of your auth resource in the Amplify project.

+ */ +export interface UpdateBackendAuthIdentityPoolConfig { + /** + *

A boolean value which can be set to allow or disallow guest level authorization into your Amplify app.

+ */ + UnauthenticatedLogin?: boolean; +} + +export namespace UpdateBackendAuthIdentityPoolConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthIdentityPoolConfig): any => ({ + ...obj, + }); +} + +/** + *

Describes the forgot password policy for authenticating into the Amlify app.

+ */ +export interface UpdateBackendAuthForgotPasswordConfig { + /** + *

Describes which mode to use (either SMS or email) to deliver messages to app users that want to recover their password.

+ */ + DeliveryMethod?: DeliveryMethod | string; + + /** + *

The configuration for the email sent when an app user forgets their password.

+ */ + EmailSettings?: EmailSettings; + + /** + *

The configuration for the SMS message sent when an Amplify app user forgets their password.

+ */ + SmsSettings?: SmsSettings; +} + +export namespace UpdateBackendAuthForgotPasswordConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthForgotPasswordConfig): any => ({ + ...obj, + }); +} + +/** + *

Updates the multi-factor authentication (MFA) configuration for the backend of your Amplify project.

+ */ +export interface UpdateBackendAuthMFAConfig { + /** + *

The MFA mode for the backend of your Amplify project.

+ */ + MFAMode?: MFAMode | string; + + /** + *

The settings of your MFA configuration for the backend of your Amplify project.

+ */ + Settings?: Settings; +} + +export namespace UpdateBackendAuthMFAConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthMFAConfig): any => ({ + ...obj, + }); +} + +/** + *

The OAuth configurations for authenticating users into your Amplify app.

+ */ +export interface UpdateBackendAuthOAuthConfig { + /** + *

The Amazon Cognito domain prefix used to create a hosted UI for authentication.

+ */ + DomainPrefix?: string; + + /** + *

The OAuth grant type to allow app users to authenticate from your Amplify app.

+ */ + OAuthGrantType?: OAuthGrantType | string; + + /** + *

The list of OAuth related flows which can allow users to authenticate from your Amplify app.

+ */ + OAuthScopes?: (OAuthScopesElement | string)[]; + + /** + *

Redirect URLs used by OAuth when a user signs in to an Amplify app.

+ */ + RedirectSignInURIs?: string[]; + + /** + *

Redirect URLs used by OAuth when a user signs out of an Amplify app.

+ */ + RedirectSignOutURIs?: string[]; + + /** + *

Describes third party social federation configurations for allowing your users to sign in with OAuth.

+ */ + SocialProviderSettings?: SocialProviderSettings; +} + +export namespace UpdateBackendAuthOAuthConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthOAuthConfig): any => ({ + ...obj, + }); +} + +/** + *

Describes the password policy for your Amazon Cognito user pool configured as a part of your Amplify project.

+ */ +export interface UpdateBackendAuthPasswordPolicyConfig { + /** + *

Describes additional constrains on password requirements to sign in into the auth resource, configured as a part of your Ampify project.

+ */ + AdditionalConstraints?: (AdditionalConstraintsElement | string)[]; + + /** + *

Describes the minimum length of password required to sign in into the auth resource, configured as a part of your Ampify project.

+ */ + MinimumLength?: number; +} + +export namespace UpdateBackendAuthPasswordPolicyConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthPasswordPolicyConfig): any => ({ + ...obj, + }); +} + +/** + *

Describes the Amazon Cognito user pool configuration for the authorization resource to be configured for your Amplify project on an update.

+ */ +export interface UpdateBackendAuthUserPoolConfig { + /** + *

Describes the forgot password policy for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + ForgotPassword?: UpdateBackendAuthForgotPasswordConfig; + + /** + *

Describes whether multi-factor authentication policies should be applied for your Amazon Cognito user pool configured as a part of your Amplify project.

+ */ + Mfa?: UpdateBackendAuthMFAConfig; + + /** + *

Describes the OAuth policy and rules for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + OAuth?: UpdateBackendAuthOAuthConfig; + + /** + *

Describes the password policy for your Amazon Cognito user pool, configured as a part of your Amplify project.

+ */ + PasswordPolicy?: UpdateBackendAuthPasswordPolicyConfig; +} + +export namespace UpdateBackendAuthUserPoolConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthUserPoolConfig): any => ({ + ...obj, + }); +} + +/** + *

Defines the resource configuration when updating an authentication resource in your Amplify project.

+ */ +export interface UpdateBackendAuthResourceConfig { + /** + *

Defines the service name to use when configuring an authentication resource in your Amplify project.

+ */ + AuthResources: AuthResources | string | undefined; + + /** + *

Describes the authorization configuration for the Amazon Cognito identity pool, provisioned as a part of your auth resource in the Amplify project.

+ */ + IdentityPoolConfigs?: UpdateBackendAuthIdentityPoolConfig; + + /** + *

Defines the service name to use when configuring an authentication resource in your Amplify project.

+ */ + Service: Service | string | undefined; + + /** + *

Describes the authentication configuration for the Amazon Cognito userpool, provisioned as a part of your auth resource in the Amplify project.

+ */ + UserPoolConfigs: UpdateBackendAuthUserPoolConfig | undefined; +} + +export namespace UpdateBackendAuthResourceConfig { + export const filterSensitiveLog = (obj: UpdateBackendAuthResourceConfig): any => ({ + ...obj, + }); +} + +/** + *

The request body for UpdateBackendAuth.

+ */ +export interface UpdateBackendAuthRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The resource configuration for this request object.

+ */ + ResourceConfig: UpdateBackendAuthResourceConfig | undefined; + + /** + *

The name of this resource.

+ */ + ResourceName: string | undefined; +} + +export namespace UpdateBackendAuthRequest { + export const filterSensitiveLog = (obj: UpdateBackendAuthRequest): any => ({ + ...obj, + }); +} + +export interface UpdateBackendAuthResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; +} + +export namespace UpdateBackendAuthResponse { + export const filterSensitiveLog = (obj: UpdateBackendAuthResponse): any => ({ + ...obj, + }); +} + +/** + *

The request object for this operation.

+ */ +export interface LoginAuthConfigReqObj { + /** + *

Amazon Cognito identitypool id used for the Amplify Admin UI login authorization.

+ */ + AwsCognitoIdentityPoolId?: string; + + /** + *

The AWS Region for the the Amplify Admin login.

+ */ + AwsCognitoRegion?: string; + + /** + *

The Amazon Cognito userpool id used for Amplify Admin UI login authentication.

+ */ + AwsUserPoolsId?: string; + + /** + *

The web client ID for the Amazon Cognito userpools.

+ */ + AwsUserPoolsWebClientId?: string; +} + +export namespace LoginAuthConfigReqObj { + export const filterSensitiveLog = (obj: LoginAuthConfigReqObj): any => ({ + ...obj, + }); +} + +/** + *

The request body for UpdateBackendConfig.

+ */ +export interface UpdateBackendConfigRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

Describes the Amazon Cognito configuration for Admin UI access.

+ */ + LoginAuthConfig?: LoginAuthConfigReqObj; +} + +export namespace UpdateBackendConfigRequest { + export const filterSensitiveLog = (obj: UpdateBackendConfigRequest): any => ({ + ...obj, + }); +} + +export interface UpdateBackendConfigResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The app ID for the backend manager.

+ */ + BackendManagerAppId?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

Describes the Amazon Cognito configurations for the Admin UI auth resource to login with.

+ */ + LoginAuthConfig?: LoginAuthConfigReqObj; +} + +export namespace UpdateBackendConfigResponse { + export const filterSensitiveLog = (obj: UpdateBackendConfigResponse): any => ({ + ...obj, + }); +} + +/** + *

The request body for GetBackendJob.

+ */ +export interface UpdateBackendJobRequest { + /** + *

The app ID.

+ */ + AppId: string | undefined; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName: string | undefined; + + /** + *

The ID for the job.

+ */ + JobId: string | undefined; + + /** + *

Filters the list of response objects to only include those with the specified operation name.

+ */ + Operation?: string; + + /** + *

Filters the list of response objects to only include those with the specified status.

+ */ + Status?: string; +} + +export namespace UpdateBackendJobRequest { + export const filterSensitiveLog = (obj: UpdateBackendJobRequest): any => ({ + ...obj, + }); +} + +export interface UpdateBackendJobResponse { + /** + *

The app ID.

+ */ + AppId?: string; + + /** + *

The name of the backend environment.

+ */ + BackendEnvironmentName?: string; + + /** + *

The time when the job was created.

+ */ + CreateTime?: string; + + /** + *

If the request failed, this is the returned error.

+ */ + Error?: string; + + /** + *

The ID for the job.

+ */ + JobId?: string; + + /** + *

The name of the operation.

+ */ + Operation?: string; + + /** + *

The current status of the request.

+ */ + Status?: string; + + /** + *

The time when the job was last updated.

+ */ + UpdateTime?: string; +} + +export namespace UpdateBackendJobResponse { + export const filterSensitiveLog = (obj: UpdateBackendJobResponse): any => ({ + ...obj, + }); +} diff --git a/clients/client-amplifybackend/package.json b/clients/client-amplifybackend/package.json new file mode 100644 index 000000000000..d97624a2c39e --- /dev/null +++ b/clients/client-amplifybackend/package.json @@ -0,0 +1,83 @@ +{ + "name": "@aws-sdk/client-amplifybackend", + "description": "AWS SDK for JavaScript Amplifybackend Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-amplifybackend", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-amplifybackend" + } +} diff --git a/clients/client-amplifybackend/protocols/Aws_restJson1.ts b/clients/client-amplifybackend/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..0a9fd55db711 --- /dev/null +++ b/clients/client-amplifybackend/protocols/Aws_restJson1.ts @@ -0,0 +1,4171 @@ +import { CloneBackendCommandInput, CloneBackendCommandOutput } from "../commands/CloneBackendCommand"; +import { CreateBackendAPICommandInput, CreateBackendAPICommandOutput } from "../commands/CreateBackendAPICommand"; +import { CreateBackendAuthCommandInput, CreateBackendAuthCommandOutput } from "../commands/CreateBackendAuthCommand"; +import { CreateBackendCommandInput, CreateBackendCommandOutput } from "../commands/CreateBackendCommand"; +import { + CreateBackendConfigCommandInput, + CreateBackendConfigCommandOutput, +} from "../commands/CreateBackendConfigCommand"; +import { CreateTokenCommandInput, CreateTokenCommandOutput } from "../commands/CreateTokenCommand"; +import { DeleteBackendAPICommandInput, DeleteBackendAPICommandOutput } from "../commands/DeleteBackendAPICommand"; +import { DeleteBackendAuthCommandInput, DeleteBackendAuthCommandOutput } from "../commands/DeleteBackendAuthCommand"; +import { DeleteBackendCommandInput, DeleteBackendCommandOutput } from "../commands/DeleteBackendCommand"; +import { DeleteTokenCommandInput, DeleteTokenCommandOutput } from "../commands/DeleteTokenCommand"; +import { + GenerateBackendAPIModelsCommandInput, + GenerateBackendAPIModelsCommandOutput, +} from "../commands/GenerateBackendAPIModelsCommand"; +import { GetBackendAPICommandInput, GetBackendAPICommandOutput } from "../commands/GetBackendAPICommand"; +import { + GetBackendAPIModelsCommandInput, + GetBackendAPIModelsCommandOutput, +} from "../commands/GetBackendAPIModelsCommand"; +import { GetBackendAuthCommandInput, GetBackendAuthCommandOutput } from "../commands/GetBackendAuthCommand"; +import { GetBackendCommandInput, GetBackendCommandOutput } from "../commands/GetBackendCommand"; +import { GetBackendJobCommandInput, GetBackendJobCommandOutput } from "../commands/GetBackendJobCommand"; +import { GetTokenCommandInput, GetTokenCommandOutput } from "../commands/GetTokenCommand"; +import { ListBackendJobsCommandInput, ListBackendJobsCommandOutput } from "../commands/ListBackendJobsCommand"; +import { RemoveAllBackendsCommandInput, RemoveAllBackendsCommandOutput } from "../commands/RemoveAllBackendsCommand"; +import { + RemoveBackendConfigCommandInput, + RemoveBackendConfigCommandOutput, +} from "../commands/RemoveBackendConfigCommand"; +import { UpdateBackendAPICommandInput, UpdateBackendAPICommandOutput } from "../commands/UpdateBackendAPICommand"; +import { UpdateBackendAuthCommandInput, UpdateBackendAuthCommandOutput } from "../commands/UpdateBackendAuthCommand"; +import { + UpdateBackendConfigCommandInput, + UpdateBackendConfigCommandOutput, +} from "../commands/UpdateBackendConfigCommand"; +import { UpdateBackendJobCommandInput, UpdateBackendJobCommandOutput } from "../commands/UpdateBackendJobCommand"; +import { + AdditionalConstraintsElement, + BackendAPIAppSyncAuthSettings, + BackendAPIAuthType, + BackendAPIConflictResolution, + BackendAPIResourceConfig, + BackendAuthSocialProviderConfig, + BackendJobRespObj, + BadRequestException, + CreateBackendAuthForgotPasswordConfig, + CreateBackendAuthIdentityPoolConfig, + CreateBackendAuthMFAConfig, + CreateBackendAuthOAuthConfig, + CreateBackendAuthPasswordPolicyConfig, + CreateBackendAuthResourceConfig, + CreateBackendAuthUserPoolConfig, + EmailSettings, + GatewayTimeoutException, + LoginAuthConfigReqObj, + MfaTypesElement, + NotFoundException, + OAuthScopesElement, + RequiredSignUpAttributesElement, + ResourceConfig, + Settings, + SmsSettings, + SocialProviderSettings, + TooManyRequestsException, + UpdateBackendAuthForgotPasswordConfig, + UpdateBackendAuthIdentityPoolConfig, + UpdateBackendAuthMFAConfig, + UpdateBackendAuthOAuthConfig, + UpdateBackendAuthPasswordPolicyConfig, + UpdateBackendAuthResourceConfig, + UpdateBackendAuthUserPoolConfig, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { + SmithyException as __SmithyException, + extendedEncodeURIComponent as __extendedEncodeURIComponent, +} from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export const serializeAws_restJson1CloneBackendCommand = async ( + input: CloneBackendCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/environments/{BackendEnvironmentName}/clone"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.TargetEnvironmentName !== undefined && { targetEnvironmentName: input.TargetEnvironmentName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateBackendCommand = async ( + input: CreateBackendCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend"; + let body: any; + body = JSON.stringify({ + ...(input.AppId !== undefined && { appId: input.AppId }), + ...(input.AppName !== undefined && { appName: input.AppName }), + ...(input.BackendEnvironmentName !== undefined && { backendEnvironmentName: input.BackendEnvironmentName }), + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1ResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateBackendAPICommand = async ( + input: CreateBackendAPICommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.BackendEnvironmentName !== undefined && { backendEnvironmentName: input.BackendEnvironmentName }), + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1BackendAPIResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateBackendAuthCommand = async ( + input: CreateBackendAuthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/auth"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.BackendEnvironmentName !== undefined && { backendEnvironmentName: input.BackendEnvironmentName }), + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1CreateBackendAuthResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateBackendConfigCommand = async ( + input: CreateBackendConfigCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/config"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.BackendManagerAppId !== undefined && { backendManagerAppId: input.BackendManagerAppId }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateTokenCommand = async ( + input: CreateTokenCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/challenge"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteBackendCommand = async ( + input: DeleteBackendCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/environments/{BackendEnvironmentName}/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteBackendAPICommand = async ( + input: DeleteBackendAPICommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api/{BackendEnvironmentName}/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1BackendAPIResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteBackendAuthCommand = async ( + input: DeleteBackendAuthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/auth/{BackendEnvironmentName}/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteTokenCommand = async ( + input: DeleteTokenCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/challenge/{SessionId}/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.SessionId !== undefined) { + const labelValue: string = input.SessionId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: SessionId."); + } + resolvedPath = resolvedPath.replace("{SessionId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: SessionId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GenerateBackendAPIModelsCommand = async ( + input: GenerateBackendAPIModelsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api/{BackendEnvironmentName}/generateModels"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetBackendCommand = async ( + input: GetBackendCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/details"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.BackendEnvironmentName !== undefined && { backendEnvironmentName: input.BackendEnvironmentName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetBackendAPICommand = async ( + input: GetBackendAPICommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api/{BackendEnvironmentName}/details"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1BackendAPIResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetBackendAPIModelsCommand = async ( + input: GetBackendAPIModelsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api/{BackendEnvironmentName}/getModels"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetBackendAuthCommand = async ( + input: GetBackendAuthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/auth/{BackendEnvironmentName}/details"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetBackendJobCommand = async ( + input: GetBackendJobCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/job/{BackendEnvironmentName}/{JobId}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + if (input.JobId !== undefined) { + const labelValue: string = input.JobId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: JobId."); + } + resolvedPath = resolvedPath.replace("{JobId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: JobId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetTokenCommand = async ( + input: GetTokenCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/challenge/{SessionId}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.SessionId !== undefined) { + const labelValue: string = input.SessionId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: SessionId."); + } + resolvedPath = resolvedPath.replace("{SessionId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: SessionId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListBackendJobsCommand = async ( + input: ListBackendJobsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/job/{BackendEnvironmentName}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.JobId !== undefined && { jobId: input.JobId }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.Operation !== undefined && { operation: input.Operation }), + ...(input.Status !== undefined && { status: input.Status }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1RemoveAllBackendsCommand = async ( + input: RemoveAllBackendsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.CleanAmplifyApp !== undefined && { cleanAmplifyApp: input.CleanAmplifyApp }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1RemoveBackendConfigCommand = async ( + input: RemoveBackendConfigCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/backend/{AppId}/config/remove"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateBackendAPICommand = async ( + input: UpdateBackendAPICommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/api/{BackendEnvironmentName}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1BackendAPIResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateBackendAuthCommand = async ( + input: UpdateBackendAuthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/auth/{BackendEnvironmentName}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + let body: any; + body = JSON.stringify({ + ...(input.ResourceConfig !== undefined && { + resourceConfig: serializeAws_restJson1UpdateBackendAuthResourceConfig(input.ResourceConfig, context), + }), + ...(input.ResourceName !== undefined && { resourceName: input.ResourceName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateBackendConfigCommand = async ( + input: UpdateBackendConfigCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/config/update"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + let body: any; + body = JSON.stringify({ + ...(input.LoginAuthConfig !== undefined && { + loginAuthConfig: serializeAws_restJson1LoginAuthConfigReqObj(input.LoginAuthConfig, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateBackendJobCommand = async ( + input: UpdateBackendJobCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/backend/{AppId}/job/{BackendEnvironmentName}/{JobId}"; + if (input.AppId !== undefined) { + const labelValue: string = input.AppId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: AppId."); + } + resolvedPath = resolvedPath.replace("{AppId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: AppId."); + } + if (input.BackendEnvironmentName !== undefined) { + const labelValue: string = input.BackendEnvironmentName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: BackendEnvironmentName."); + } + resolvedPath = resolvedPath.replace("{BackendEnvironmentName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: BackendEnvironmentName."); + } + if (input.JobId !== undefined) { + const labelValue: string = input.JobId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: JobId."); + } + resolvedPath = resolvedPath.replace("{JobId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: JobId."); + } + let body: any; + body = JSON.stringify({ + ...(input.Operation !== undefined && { operation: input.Operation }), + ...(input.Status !== undefined && { status: input.Status }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1CloneBackendCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CloneBackendCommandError(output, context); + } + const contents: CloneBackendCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CloneBackendCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateBackendCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateBackendCommandError(output, context); + } + const contents: CreateBackendCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateBackendCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateBackendAPICommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateBackendAPICommandError(output, context); + } + const contents: CreateBackendAPICommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateBackendAPICommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateBackendAuthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateBackendAuthCommandError(output, context); + } + const contents: CreateBackendAuthCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateBackendAuthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateBackendConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateBackendConfigCommandError(output, context); + } + const contents: CreateBackendConfigCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + JobId: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateBackendConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateTokenCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateTokenCommandError(output, context); + } + const contents: CreateTokenCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + ChallengeCode: undefined, + SessionId: undefined, + Ttl: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.challengeCode !== undefined && data.challengeCode !== null) { + contents.ChallengeCode = data.challengeCode; + } + if (data.sessionId !== undefined && data.sessionId !== null) { + contents.SessionId = data.sessionId; + } + if (data.ttl !== undefined && data.ttl !== null) { + contents.Ttl = data.ttl; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateTokenCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteBackendCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteBackendCommandError(output, context); + } + const contents: DeleteBackendCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteBackendCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteBackendAPICommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteBackendAPICommandError(output, context); + } + const contents: DeleteBackendAPICommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteBackendAPICommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteBackendAuthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteBackendAuthCommandError(output, context); + } + const contents: DeleteBackendAuthCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteBackendAuthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteTokenCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteTokenCommandError(output, context); + } + const contents: DeleteTokenCommandOutput = { + $metadata: deserializeMetadata(output), + IsSuccess: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.isSuccess !== undefined && data.isSuccess !== null) { + contents.IsSuccess = data.isSuccess; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteTokenCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GenerateBackendAPIModelsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GenerateBackendAPIModelsCommandError(output, context); + } + const contents: GenerateBackendAPIModelsCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GenerateBackendAPIModelsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetBackendCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetBackendCommandError(output, context); + } + const contents: GetBackendCommandOutput = { + $metadata: deserializeMetadata(output), + AmplifyMetaConfig: undefined, + AppId: undefined, + AppName: undefined, + BackendEnvironmentList: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.amplifyMetaConfig !== undefined && data.amplifyMetaConfig !== null) { + contents.AmplifyMetaConfig = data.amplifyMetaConfig; + } + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.appName !== undefined && data.appName !== null) { + contents.AppName = data.appName; + } + if (data.backendEnvironmentList !== undefined && data.backendEnvironmentList !== null) { + contents.BackendEnvironmentList = deserializeAws_restJson1ListOf__string(data.backendEnvironmentList, context); + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetBackendCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetBackendAPICommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetBackendAPICommandError(output, context); + } + const contents: GetBackendAPICommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + ResourceConfig: undefined, + ResourceName: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.resourceConfig !== undefined && data.resourceConfig !== null) { + contents.ResourceConfig = deserializeAws_restJson1BackendAPIResourceConfig(data.resourceConfig, context); + } + if (data.resourceName !== undefined && data.resourceName !== null) { + contents.ResourceName = data.resourceName; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetBackendAPICommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetBackendAPIModelsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetBackendAPIModelsCommandError(output, context); + } + const contents: GetBackendAPIModelsCommandOutput = { + $metadata: deserializeMetadata(output), + Models: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.models !== undefined && data.models !== null) { + contents.Models = data.models; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetBackendAPIModelsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetBackendAuthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetBackendAuthCommandError(output, context); + } + const contents: GetBackendAuthCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + ResourceConfig: undefined, + ResourceName: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.resourceConfig !== undefined && data.resourceConfig !== null) { + contents.ResourceConfig = deserializeAws_restJson1CreateBackendAuthResourceConfig(data.resourceConfig, context); + } + if (data.resourceName !== undefined && data.resourceName !== null) { + contents.ResourceName = data.resourceName; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetBackendAuthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetBackendJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetBackendJobCommandError(output, context); + } + const contents: GetBackendJobCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + CreateTime: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + UpdateTime: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.createTime !== undefined && data.createTime !== null) { + contents.CreateTime = data.createTime; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + if (data.updateTime !== undefined && data.updateTime !== null) { + contents.UpdateTime = data.updateTime; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetBackendJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetTokenCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetTokenCommandError(output, context); + } + const contents: GetTokenCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + ChallengeCode: undefined, + SessionId: undefined, + Ttl: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.challengeCode !== undefined && data.challengeCode !== null) { + contents.ChallengeCode = data.challengeCode; + } + if (data.sessionId !== undefined && data.sessionId !== null) { + contents.SessionId = data.sessionId; + } + if (data.ttl !== undefined && data.ttl !== null) { + contents.Ttl = data.ttl; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetTokenCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListBackendJobsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListBackendJobsCommandError(output, context); + } + const contents: ListBackendJobsCommandOutput = { + $metadata: deserializeMetadata(output), + Jobs: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.jobs !== undefined && data.jobs !== null) { + contents.Jobs = deserializeAws_restJson1ListOfBackendJobRespObj(data.jobs, context); + } + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.NextToken = data.nextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListBackendJobsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1RemoveAllBackendsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1RemoveAllBackendsCommandError(output, context); + } + const contents: RemoveAllBackendsCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1RemoveAllBackendsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1RemoveBackendConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1RemoveBackendConfigCommandError(output, context); + } + const contents: RemoveBackendConfigCommandOutput = { + $metadata: deserializeMetadata(output), + Error: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1RemoveBackendConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateBackendAPICommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateBackendAPICommandError(output, context); + } + const contents: UpdateBackendAPICommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateBackendAPICommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateBackendAuthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateBackendAuthCommandError(output, context); + } + const contents: UpdateBackendAuthCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateBackendAuthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateBackendConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateBackendConfigCommandError(output, context); + } + const contents: UpdateBackendConfigCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendManagerAppId: undefined, + Error: undefined, + LoginAuthConfig: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendManagerAppId !== undefined && data.backendManagerAppId !== null) { + contents.BackendManagerAppId = data.backendManagerAppId; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.loginAuthConfig !== undefined && data.loginAuthConfig !== null) { + contents.LoginAuthConfig = deserializeAws_restJson1LoginAuthConfigReqObj(data.loginAuthConfig, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateBackendConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateBackendJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateBackendJobCommandError(output, context); + } + const contents: UpdateBackendJobCommandOutput = { + $metadata: deserializeMetadata(output), + AppId: undefined, + BackendEnvironmentName: undefined, + CreateTime: undefined, + Error: undefined, + JobId: undefined, + Operation: undefined, + Status: undefined, + UpdateTime: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.appId !== undefined && data.appId !== null) { + contents.AppId = data.appId; + } + if (data.backendEnvironmentName !== undefined && data.backendEnvironmentName !== null) { + contents.BackendEnvironmentName = data.backendEnvironmentName; + } + if (data.createTime !== undefined && data.createTime !== null) { + contents.CreateTime = data.createTime; + } + if (data.error !== undefined && data.error !== null) { + contents.Error = data.error; + } + if (data.jobId !== undefined && data.jobId !== null) { + contents.JobId = data.jobId; + } + if (data.operation !== undefined && data.operation !== null) { + contents.Operation = data.operation; + } + if (data.status !== undefined && data.status !== null) { + contents.Status = data.status; + } + if (data.updateTime !== undefined && data.updateTime !== null) { + contents.UpdateTime = data.updateTime; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateBackendJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "BadRequestException": + case "com.amazonaws.amplifybackend#BadRequestException": + response = { + ...(await deserializeAws_restJson1BadRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "GatewayTimeoutException": + case "com.amazonaws.amplifybackend#GatewayTimeoutException": + response = { + ...(await deserializeAws_restJson1GatewayTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NotFoundException": + case "com.amazonaws.amplifybackend#NotFoundException": + response = { + ...(await deserializeAws_restJson1NotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "TooManyRequestsException": + case "com.amazonaws.amplifybackend#TooManyRequestsException": + response = { + ...(await deserializeAws_restJson1TooManyRequestsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1BadRequestExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: BadRequestException = { + name: "BadRequestException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.message !== undefined && data.message !== null) { + contents.Message = data.message; + } + return contents; +}; + +const deserializeAws_restJson1GatewayTimeoutExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: GatewayTimeoutException = { + name: "GatewayTimeoutException", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.message !== undefined && data.message !== null) { + contents.Message = data.message; + } + return contents; +}; + +const deserializeAws_restJson1NotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: NotFoundException = { + name: "NotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + ResourceType: undefined, + }; + const data: any = parsedOutput.body; + if (data.message !== undefined && data.message !== null) { + contents.Message = data.message; + } + if (data.resourceType !== undefined && data.resourceType !== null) { + contents.ResourceType = data.resourceType; + } + return contents; +}; + +const deserializeAws_restJson1TooManyRequestsExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: TooManyRequestsException = { + name: "TooManyRequestsException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + LimitType: undefined, + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.limitType !== undefined && data.limitType !== null) { + contents.LimitType = data.limitType; + } + if (data.message !== undefined && data.message !== null) { + contents.Message = data.message; + } + return contents; +}; + +const serializeAws_restJson1BackendAPIAppSyncAuthSettings = ( + input: BackendAPIAppSyncAuthSettings, + context: __SerdeContext +): any => { + return { + ...(input.CognitoUserPoolId !== undefined && { cognitoUserPoolId: input.CognitoUserPoolId }), + ...(input.Description !== undefined && { description: input.Description }), + ...(input.ExpirationTime !== undefined && { expirationTime: input.ExpirationTime }), + ...(input.OpenIDAuthTTL !== undefined && { openIDAuthTTL: input.OpenIDAuthTTL }), + ...(input.OpenIDClientId !== undefined && { openIDClientId: input.OpenIDClientId }), + ...(input.OpenIDIatTTL !== undefined && { openIDIatTTL: input.OpenIDIatTTL }), + ...(input.OpenIDIssueURL !== undefined && { openIDIssueURL: input.OpenIDIssueURL }), + ...(input.OpenIDProviderName !== undefined && { openIDProviderName: input.OpenIDProviderName }), + }; +}; + +const serializeAws_restJson1BackendAPIAuthType = (input: BackendAPIAuthType, context: __SerdeContext): any => { + return { + ...(input.Mode !== undefined && { mode: input.Mode }), + ...(input.Settings !== undefined && { + settings: serializeAws_restJson1BackendAPIAppSyncAuthSettings(input.Settings, context), + }), + }; +}; + +const serializeAws_restJson1BackendAPIConflictResolution = ( + input: BackendAPIConflictResolution, + context: __SerdeContext +): any => { + return { + ...(input.ResolutionStrategy !== undefined && { resolutionStrategy: input.ResolutionStrategy }), + }; +}; + +const serializeAws_restJson1BackendAPIResourceConfig = ( + input: BackendAPIResourceConfig, + context: __SerdeContext +): any => { + return { + ...(input.AdditionalAuthTypes !== undefined && { + additionalAuthTypes: serializeAws_restJson1ListOfBackendAPIAuthType(input.AdditionalAuthTypes, context), + }), + ...(input.ApiName !== undefined && { apiName: input.ApiName }), + ...(input.ConflictResolution !== undefined && { + conflictResolution: serializeAws_restJson1BackendAPIConflictResolution(input.ConflictResolution, context), + }), + ...(input.DefaultAuthType !== undefined && { + defaultAuthType: serializeAws_restJson1BackendAPIAuthType(input.DefaultAuthType, context), + }), + ...(input.Service !== undefined && { service: input.Service }), + ...(input.TransformSchema !== undefined && { transformSchema: input.TransformSchema }), + }; +}; + +const serializeAws_restJson1BackendAuthSocialProviderConfig = ( + input: BackendAuthSocialProviderConfig, + context: __SerdeContext +): any => { + return { + ...(input.ClientId !== undefined && { client_id: input.ClientId }), + ...(input.ClientSecret !== undefined && { client_secret: input.ClientSecret }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthForgotPasswordConfig = ( + input: CreateBackendAuthForgotPasswordConfig, + context: __SerdeContext +): any => { + return { + ...(input.DeliveryMethod !== undefined && { deliveryMethod: input.DeliveryMethod }), + ...(input.EmailSettings !== undefined && { + emailSettings: serializeAws_restJson1EmailSettings(input.EmailSettings, context), + }), + ...(input.SmsSettings !== undefined && { + smsSettings: serializeAws_restJson1SmsSettings(input.SmsSettings, context), + }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthIdentityPoolConfig = ( + input: CreateBackendAuthIdentityPoolConfig, + context: __SerdeContext +): any => { + return { + ...(input.IdentityPoolName !== undefined && { identityPoolName: input.IdentityPoolName }), + ...(input.UnauthenticatedLogin !== undefined && { unauthenticatedLogin: input.UnauthenticatedLogin }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthMFAConfig = ( + input: CreateBackendAuthMFAConfig, + context: __SerdeContext +): any => { + return { + ...(input.MFAMode !== undefined && { MFAMode: input.MFAMode }), + ...(input.Settings !== undefined && { settings: serializeAws_restJson1Settings(input.Settings, context) }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthOAuthConfig = ( + input: CreateBackendAuthOAuthConfig, + context: __SerdeContext +): any => { + return { + ...(input.DomainPrefix !== undefined && { domainPrefix: input.DomainPrefix }), + ...(input.OAuthGrantType !== undefined && { oAuthGrantType: input.OAuthGrantType }), + ...(input.OAuthScopes !== undefined && { + oAuthScopes: serializeAws_restJson1ListOfOAuthScopesElement(input.OAuthScopes, context), + }), + ...(input.RedirectSignInURIs !== undefined && { + redirectSignInURIs: serializeAws_restJson1ListOf__string(input.RedirectSignInURIs, context), + }), + ...(input.RedirectSignOutURIs !== undefined && { + redirectSignOutURIs: serializeAws_restJson1ListOf__string(input.RedirectSignOutURIs, context), + }), + ...(input.SocialProviderSettings !== undefined && { + socialProviderSettings: serializeAws_restJson1SocialProviderSettings(input.SocialProviderSettings, context), + }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthPasswordPolicyConfig = ( + input: CreateBackendAuthPasswordPolicyConfig, + context: __SerdeContext +): any => { + return { + ...(input.AdditionalConstraints !== undefined && { + additionalConstraints: serializeAws_restJson1ListOfAdditionalConstraintsElement( + input.AdditionalConstraints, + context + ), + }), + ...(input.MinimumLength !== undefined && { minimumLength: input.MinimumLength }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthResourceConfig = ( + input: CreateBackendAuthResourceConfig, + context: __SerdeContext +): any => { + return { + ...(input.AuthResources !== undefined && { authResources: input.AuthResources }), + ...(input.IdentityPoolConfigs !== undefined && { + identityPoolConfigs: serializeAws_restJson1CreateBackendAuthIdentityPoolConfig( + input.IdentityPoolConfigs, + context + ), + }), + ...(input.Service !== undefined && { service: input.Service }), + ...(input.UserPoolConfigs !== undefined && { + userPoolConfigs: serializeAws_restJson1CreateBackendAuthUserPoolConfig(input.UserPoolConfigs, context), + }), + }; +}; + +const serializeAws_restJson1CreateBackendAuthUserPoolConfig = ( + input: CreateBackendAuthUserPoolConfig, + context: __SerdeContext +): any => { + return { + ...(input.ForgotPassword !== undefined && { + forgotPassword: serializeAws_restJson1CreateBackendAuthForgotPasswordConfig(input.ForgotPassword, context), + }), + ...(input.Mfa !== undefined && { mfa: serializeAws_restJson1CreateBackendAuthMFAConfig(input.Mfa, context) }), + ...(input.OAuth !== undefined && { + oAuth: serializeAws_restJson1CreateBackendAuthOAuthConfig(input.OAuth, context), + }), + ...(input.PasswordPolicy !== undefined && { + passwordPolicy: serializeAws_restJson1CreateBackendAuthPasswordPolicyConfig(input.PasswordPolicy, context), + }), + ...(input.RequiredSignUpAttributes !== undefined && { + requiredSignUpAttributes: serializeAws_restJson1ListOfRequiredSignUpAttributesElement( + input.RequiredSignUpAttributes, + context + ), + }), + ...(input.SignInMethod !== undefined && { signInMethod: input.SignInMethod }), + ...(input.UserPoolName !== undefined && { userPoolName: input.UserPoolName }), + }; +}; + +const serializeAws_restJson1EmailSettings = (input: EmailSettings, context: __SerdeContext): any => { + return { + ...(input.EmailMessage !== undefined && { emailMessage: input.EmailMessage }), + ...(input.EmailSubject !== undefined && { emailSubject: input.EmailSubject }), + }; +}; + +const serializeAws_restJson1ListOf__string = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1ListOfAdditionalConstraintsElement = ( + input: (AdditionalConstraintsElement | string)[], + context: __SerdeContext +): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1ListOfBackendAPIAuthType = (input: BackendAPIAuthType[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_restJson1BackendAPIAuthType(entry, context)); +}; + +const serializeAws_restJson1ListOfMfaTypesElement = ( + input: (MfaTypesElement | string)[], + context: __SerdeContext +): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1ListOfOAuthScopesElement = ( + input: (OAuthScopesElement | string)[], + context: __SerdeContext +): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1ListOfRequiredSignUpAttributesElement = ( + input: (RequiredSignUpAttributesElement | string)[], + context: __SerdeContext +): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1LoginAuthConfigReqObj = (input: LoginAuthConfigReqObj, context: __SerdeContext): any => { + return { + ...(input.AwsCognitoIdentityPoolId !== undefined && { + aws_cognito_identity_pool_id: input.AwsCognitoIdentityPoolId, + }), + ...(input.AwsCognitoRegion !== undefined && { aws_cognito_region: input.AwsCognitoRegion }), + ...(input.AwsUserPoolsId !== undefined && { aws_user_pools_id: input.AwsUserPoolsId }), + ...(input.AwsUserPoolsWebClientId !== undefined && { aws_user_pools_web_client_id: input.AwsUserPoolsWebClientId }), + }; +}; + +const serializeAws_restJson1ResourceConfig = (input: ResourceConfig, context: __SerdeContext): any => { + return {}; +}; + +const serializeAws_restJson1Settings = (input: Settings, context: __SerdeContext): any => { + return { + ...(input.MfaTypes !== undefined && { + mfaTypes: serializeAws_restJson1ListOfMfaTypesElement(input.MfaTypes, context), + }), + ...(input.SmsMessage !== undefined && { smsMessage: input.SmsMessage }), + }; +}; + +const serializeAws_restJson1SmsSettings = (input: SmsSettings, context: __SerdeContext): any => { + return { + ...(input.SmsMessage !== undefined && { smsMessage: input.SmsMessage }), + }; +}; + +const serializeAws_restJson1SocialProviderSettings = (input: SocialProviderSettings, context: __SerdeContext): any => { + return { + ...(input.Facebook !== undefined && { + Facebook: serializeAws_restJson1BackendAuthSocialProviderConfig(input.Facebook, context), + }), + ...(input.Google !== undefined && { + Google: serializeAws_restJson1BackendAuthSocialProviderConfig(input.Google, context), + }), + ...(input.LoginWithAmazon !== undefined && { + LoginWithAmazon: serializeAws_restJson1BackendAuthSocialProviderConfig(input.LoginWithAmazon, context), + }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthForgotPasswordConfig = ( + input: UpdateBackendAuthForgotPasswordConfig, + context: __SerdeContext +): any => { + return { + ...(input.DeliveryMethod !== undefined && { deliveryMethod: input.DeliveryMethod }), + ...(input.EmailSettings !== undefined && { + emailSettings: serializeAws_restJson1EmailSettings(input.EmailSettings, context), + }), + ...(input.SmsSettings !== undefined && { + smsSettings: serializeAws_restJson1SmsSettings(input.SmsSettings, context), + }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthIdentityPoolConfig = ( + input: UpdateBackendAuthIdentityPoolConfig, + context: __SerdeContext +): any => { + return { + ...(input.UnauthenticatedLogin !== undefined && { unauthenticatedLogin: input.UnauthenticatedLogin }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthMFAConfig = ( + input: UpdateBackendAuthMFAConfig, + context: __SerdeContext +): any => { + return { + ...(input.MFAMode !== undefined && { MFAMode: input.MFAMode }), + ...(input.Settings !== undefined && { settings: serializeAws_restJson1Settings(input.Settings, context) }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthOAuthConfig = ( + input: UpdateBackendAuthOAuthConfig, + context: __SerdeContext +): any => { + return { + ...(input.DomainPrefix !== undefined && { domainPrefix: input.DomainPrefix }), + ...(input.OAuthGrantType !== undefined && { oAuthGrantType: input.OAuthGrantType }), + ...(input.OAuthScopes !== undefined && { + oAuthScopes: serializeAws_restJson1ListOfOAuthScopesElement(input.OAuthScopes, context), + }), + ...(input.RedirectSignInURIs !== undefined && { + redirectSignInURIs: serializeAws_restJson1ListOf__string(input.RedirectSignInURIs, context), + }), + ...(input.RedirectSignOutURIs !== undefined && { + redirectSignOutURIs: serializeAws_restJson1ListOf__string(input.RedirectSignOutURIs, context), + }), + ...(input.SocialProviderSettings !== undefined && { + socialProviderSettings: serializeAws_restJson1SocialProviderSettings(input.SocialProviderSettings, context), + }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthPasswordPolicyConfig = ( + input: UpdateBackendAuthPasswordPolicyConfig, + context: __SerdeContext +): any => { + return { + ...(input.AdditionalConstraints !== undefined && { + additionalConstraints: serializeAws_restJson1ListOfAdditionalConstraintsElement( + input.AdditionalConstraints, + context + ), + }), + ...(input.MinimumLength !== undefined && { minimumLength: input.MinimumLength }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthResourceConfig = ( + input: UpdateBackendAuthResourceConfig, + context: __SerdeContext +): any => { + return { + ...(input.AuthResources !== undefined && { authResources: input.AuthResources }), + ...(input.IdentityPoolConfigs !== undefined && { + identityPoolConfigs: serializeAws_restJson1UpdateBackendAuthIdentityPoolConfig( + input.IdentityPoolConfigs, + context + ), + }), + ...(input.Service !== undefined && { service: input.Service }), + ...(input.UserPoolConfigs !== undefined && { + userPoolConfigs: serializeAws_restJson1UpdateBackendAuthUserPoolConfig(input.UserPoolConfigs, context), + }), + }; +}; + +const serializeAws_restJson1UpdateBackendAuthUserPoolConfig = ( + input: UpdateBackendAuthUserPoolConfig, + context: __SerdeContext +): any => { + return { + ...(input.ForgotPassword !== undefined && { + forgotPassword: serializeAws_restJson1UpdateBackendAuthForgotPasswordConfig(input.ForgotPassword, context), + }), + ...(input.Mfa !== undefined && { mfa: serializeAws_restJson1UpdateBackendAuthMFAConfig(input.Mfa, context) }), + ...(input.OAuth !== undefined && { + oAuth: serializeAws_restJson1UpdateBackendAuthOAuthConfig(input.OAuth, context), + }), + ...(input.PasswordPolicy !== undefined && { + passwordPolicy: serializeAws_restJson1UpdateBackendAuthPasswordPolicyConfig(input.PasswordPolicy, context), + }), + }; +}; + +const deserializeAws_restJson1BackendAPIAppSyncAuthSettings = ( + output: any, + context: __SerdeContext +): BackendAPIAppSyncAuthSettings => { + return { + CognitoUserPoolId: + output.cognitoUserPoolId !== undefined && output.cognitoUserPoolId !== null + ? output.cognitoUserPoolId + : undefined, + Description: output.description !== undefined && output.description !== null ? output.description : undefined, + ExpirationTime: + output.expirationTime !== undefined && output.expirationTime !== null ? output.expirationTime : undefined, + OpenIDAuthTTL: + output.openIDAuthTTL !== undefined && output.openIDAuthTTL !== null ? output.openIDAuthTTL : undefined, + OpenIDClientId: + output.openIDClientId !== undefined && output.openIDClientId !== null ? output.openIDClientId : undefined, + OpenIDIatTTL: output.openIDIatTTL !== undefined && output.openIDIatTTL !== null ? output.openIDIatTTL : undefined, + OpenIDIssueURL: + output.openIDIssueURL !== undefined && output.openIDIssueURL !== null ? output.openIDIssueURL : undefined, + OpenIDProviderName: + output.openIDProviderName !== undefined && output.openIDProviderName !== null + ? output.openIDProviderName + : undefined, + } as any; +}; + +const deserializeAws_restJson1BackendAPIAuthType = (output: any, context: __SerdeContext): BackendAPIAuthType => { + return { + Mode: output.mode !== undefined && output.mode !== null ? output.mode : undefined, + Settings: + output.settings !== undefined && output.settings !== null + ? deserializeAws_restJson1BackendAPIAppSyncAuthSettings(output.settings, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1BackendAPIConflictResolution = ( + output: any, + context: __SerdeContext +): BackendAPIConflictResolution => { + return { + ResolutionStrategy: + output.resolutionStrategy !== undefined && output.resolutionStrategy !== null + ? output.resolutionStrategy + : undefined, + } as any; +}; + +const deserializeAws_restJson1BackendAPIResourceConfig = ( + output: any, + context: __SerdeContext +): BackendAPIResourceConfig => { + return { + AdditionalAuthTypes: + output.additionalAuthTypes !== undefined && output.additionalAuthTypes !== null + ? deserializeAws_restJson1ListOfBackendAPIAuthType(output.additionalAuthTypes, context) + : undefined, + ApiName: output.apiName !== undefined && output.apiName !== null ? output.apiName : undefined, + ConflictResolution: + output.conflictResolution !== undefined && output.conflictResolution !== null + ? deserializeAws_restJson1BackendAPIConflictResolution(output.conflictResolution, context) + : undefined, + DefaultAuthType: + output.defaultAuthType !== undefined && output.defaultAuthType !== null + ? deserializeAws_restJson1BackendAPIAuthType(output.defaultAuthType, context) + : undefined, + Service: output.service !== undefined && output.service !== null ? output.service : undefined, + TransformSchema: + output.transformSchema !== undefined && output.transformSchema !== null ? output.transformSchema : undefined, + } as any; +}; + +const deserializeAws_restJson1BackendAuthSocialProviderConfig = ( + output: any, + context: __SerdeContext +): BackendAuthSocialProviderConfig => { + return { + ClientId: output.client_id !== undefined && output.client_id !== null ? output.client_id : undefined, + ClientSecret: + output.client_secret !== undefined && output.client_secret !== null ? output.client_secret : undefined, + } as any; +}; + +const deserializeAws_restJson1BackendJobRespObj = (output: any, context: __SerdeContext): BackendJobRespObj => { + return { + AppId: output.appId !== undefined && output.appId !== null ? output.appId : undefined, + BackendEnvironmentName: + output.backendEnvironmentName !== undefined && output.backendEnvironmentName !== null + ? output.backendEnvironmentName + : undefined, + CreateTime: output.createTime !== undefined && output.createTime !== null ? output.createTime : undefined, + Error: output.error !== undefined && output.error !== null ? output.error : undefined, + JobId: output.jobId !== undefined && output.jobId !== null ? output.jobId : undefined, + Operation: output.operation !== undefined && output.operation !== null ? output.operation : undefined, + Status: output.status !== undefined && output.status !== null ? output.status : undefined, + UpdateTime: output.updateTime !== undefined && output.updateTime !== null ? output.updateTime : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthForgotPasswordConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthForgotPasswordConfig => { + return { + DeliveryMethod: + output.deliveryMethod !== undefined && output.deliveryMethod !== null ? output.deliveryMethod : undefined, + EmailSettings: + output.emailSettings !== undefined && output.emailSettings !== null + ? deserializeAws_restJson1EmailSettings(output.emailSettings, context) + : undefined, + SmsSettings: + output.smsSettings !== undefined && output.smsSettings !== null + ? deserializeAws_restJson1SmsSettings(output.smsSettings, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthIdentityPoolConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthIdentityPoolConfig => { + return { + IdentityPoolName: + output.identityPoolName !== undefined && output.identityPoolName !== null ? output.identityPoolName : undefined, + UnauthenticatedLogin: + output.unauthenticatedLogin !== undefined && output.unauthenticatedLogin !== null + ? output.unauthenticatedLogin + : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthMFAConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthMFAConfig => { + return { + MFAMode: output.MFAMode !== undefined && output.MFAMode !== null ? output.MFAMode : undefined, + Settings: + output.settings !== undefined && output.settings !== null + ? deserializeAws_restJson1Settings(output.settings, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthOAuthConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthOAuthConfig => { + return { + DomainPrefix: output.domainPrefix !== undefined && output.domainPrefix !== null ? output.domainPrefix : undefined, + OAuthGrantType: + output.oAuthGrantType !== undefined && output.oAuthGrantType !== null ? output.oAuthGrantType : undefined, + OAuthScopes: + output.oAuthScopes !== undefined && output.oAuthScopes !== null + ? deserializeAws_restJson1ListOfOAuthScopesElement(output.oAuthScopes, context) + : undefined, + RedirectSignInURIs: + output.redirectSignInURIs !== undefined && output.redirectSignInURIs !== null + ? deserializeAws_restJson1ListOf__string(output.redirectSignInURIs, context) + : undefined, + RedirectSignOutURIs: + output.redirectSignOutURIs !== undefined && output.redirectSignOutURIs !== null + ? deserializeAws_restJson1ListOf__string(output.redirectSignOutURIs, context) + : undefined, + SocialProviderSettings: + output.socialProviderSettings !== undefined && output.socialProviderSettings !== null + ? deserializeAws_restJson1SocialProviderSettings(output.socialProviderSettings, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthPasswordPolicyConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthPasswordPolicyConfig => { + return { + AdditionalConstraints: + output.additionalConstraints !== undefined && output.additionalConstraints !== null + ? deserializeAws_restJson1ListOfAdditionalConstraintsElement(output.additionalConstraints, context) + : undefined, + MinimumLength: + output.minimumLength !== undefined && output.minimumLength !== null ? output.minimumLength : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthResourceConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthResourceConfig => { + return { + AuthResources: + output.authResources !== undefined && output.authResources !== null ? output.authResources : undefined, + IdentityPoolConfigs: + output.identityPoolConfigs !== undefined && output.identityPoolConfigs !== null + ? deserializeAws_restJson1CreateBackendAuthIdentityPoolConfig(output.identityPoolConfigs, context) + : undefined, + Service: output.service !== undefined && output.service !== null ? output.service : undefined, + UserPoolConfigs: + output.userPoolConfigs !== undefined && output.userPoolConfigs !== null + ? deserializeAws_restJson1CreateBackendAuthUserPoolConfig(output.userPoolConfigs, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CreateBackendAuthUserPoolConfig = ( + output: any, + context: __SerdeContext +): CreateBackendAuthUserPoolConfig => { + return { + ForgotPassword: + output.forgotPassword !== undefined && output.forgotPassword !== null + ? deserializeAws_restJson1CreateBackendAuthForgotPasswordConfig(output.forgotPassword, context) + : undefined, + Mfa: + output.mfa !== undefined && output.mfa !== null + ? deserializeAws_restJson1CreateBackendAuthMFAConfig(output.mfa, context) + : undefined, + OAuth: + output.oAuth !== undefined && output.oAuth !== null + ? deserializeAws_restJson1CreateBackendAuthOAuthConfig(output.oAuth, context) + : undefined, + PasswordPolicy: + output.passwordPolicy !== undefined && output.passwordPolicy !== null + ? deserializeAws_restJson1CreateBackendAuthPasswordPolicyConfig(output.passwordPolicy, context) + : undefined, + RequiredSignUpAttributes: + output.requiredSignUpAttributes !== undefined && output.requiredSignUpAttributes !== null + ? deserializeAws_restJson1ListOfRequiredSignUpAttributesElement(output.requiredSignUpAttributes, context) + : undefined, + SignInMethod: output.signInMethod !== undefined && output.signInMethod !== null ? output.signInMethod : undefined, + UserPoolName: output.userPoolName !== undefined && output.userPoolName !== null ? output.userPoolName : undefined, + } as any; +}; + +const deserializeAws_restJson1EmailSettings = (output: any, context: __SerdeContext): EmailSettings => { + return { + EmailMessage: output.emailMessage !== undefined && output.emailMessage !== null ? output.emailMessage : undefined, + EmailSubject: output.emailSubject !== undefined && output.emailSubject !== null ? output.emailSubject : undefined, + } as any; +}; + +const deserializeAws_restJson1ListOf__string = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1ListOfAdditionalConstraintsElement = ( + output: any, + context: __SerdeContext +): (AdditionalConstraintsElement | string)[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1ListOfBackendAPIAuthType = ( + output: any, + context: __SerdeContext +): BackendAPIAuthType[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1BackendAPIAuthType(entry, context)); +}; + +const deserializeAws_restJson1ListOfBackendJobRespObj = (output: any, context: __SerdeContext): BackendJobRespObj[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1BackendJobRespObj(entry, context)); +}; + +const deserializeAws_restJson1ListOfMfaTypesElement = ( + output: any, + context: __SerdeContext +): (MfaTypesElement | string)[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1ListOfOAuthScopesElement = ( + output: any, + context: __SerdeContext +): (OAuthScopesElement | string)[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1ListOfRequiredSignUpAttributesElement = ( + output: any, + context: __SerdeContext +): (RequiredSignUpAttributesElement | string)[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1LoginAuthConfigReqObj = (output: any, context: __SerdeContext): LoginAuthConfigReqObj => { + return { + AwsCognitoIdentityPoolId: + output.aws_cognito_identity_pool_id !== undefined && output.aws_cognito_identity_pool_id !== null + ? output.aws_cognito_identity_pool_id + : undefined, + AwsCognitoRegion: + output.aws_cognito_region !== undefined && output.aws_cognito_region !== null + ? output.aws_cognito_region + : undefined, + AwsUserPoolsId: + output.aws_user_pools_id !== undefined && output.aws_user_pools_id !== null + ? output.aws_user_pools_id + : undefined, + AwsUserPoolsWebClientId: + output.aws_user_pools_web_client_id !== undefined && output.aws_user_pools_web_client_id !== null + ? output.aws_user_pools_web_client_id + : undefined, + } as any; +}; + +const deserializeAws_restJson1Settings = (output: any, context: __SerdeContext): Settings => { + return { + MfaTypes: + output.mfaTypes !== undefined && output.mfaTypes !== null + ? deserializeAws_restJson1ListOfMfaTypesElement(output.mfaTypes, context) + : undefined, + SmsMessage: output.smsMessage !== undefined && output.smsMessage !== null ? output.smsMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1SmsSettings = (output: any, context: __SerdeContext): SmsSettings => { + return { + SmsMessage: output.smsMessage !== undefined && output.smsMessage !== null ? output.smsMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1SocialProviderSettings = ( + output: any, + context: __SerdeContext +): SocialProviderSettings => { + return { + Facebook: + output.Facebook !== undefined && output.Facebook !== null + ? deserializeAws_restJson1BackendAuthSocialProviderConfig(output.Facebook, context) + : undefined, + Google: + output.Google !== undefined && output.Google !== null + ? deserializeAws_restJson1BackendAuthSocialProviderConfig(output.Google, context) + : undefined, + LoginWithAmazon: + output.LoginWithAmazon !== undefined && output.LoginWithAmazon !== null + ? deserializeAws_restJson1BackendAuthSocialProviderConfig(output.LoginWithAmazon, context) + : undefined, + } as any; +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-amplifybackend/runtimeConfig.browser.ts b/clients/client-amplifybackend/runtimeConfig.browser.ts new file mode 100644 index 000000000000..1ad28c41c63a --- /dev/null +++ b/clients/client-amplifybackend/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./AmplifyBackendClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-amplifybackend/runtimeConfig.native.ts b/clients/client-amplifybackend/runtimeConfig.native.ts new file mode 100644 index 000000000000..56a11bbb199d --- /dev/null +++ b/clients/client-amplifybackend/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./AmplifyBackendClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-amplifybackend/runtimeConfig.shared.ts b/clients/client-amplifybackend/runtimeConfig.shared.ts new file mode 100644 index 000000000000..4557b401d32a --- /dev/null +++ b/clients/client-amplifybackend/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-08-11", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "amplifybackend", +}; diff --git a/clients/client-amplifybackend/runtimeConfig.ts b/clients/client-amplifybackend/runtimeConfig.ts new file mode 100644 index 000000000000..8b2a934698ef --- /dev/null +++ b/clients/client-amplifybackend/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./AmplifyBackendClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-amplifybackend/tsconfig.es.json b/clients/client-amplifybackend/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-amplifybackend/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-amplifybackend/tsconfig.json b/clients/client-amplifybackend/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-amplifybackend/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-appintegrations/.gitignore b/clients/client-appintegrations/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-appintegrations/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-appintegrations/.npmignore b/clients/client-appintegrations/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-appintegrations/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-appintegrations/AppIntegrations.ts b/clients/client-appintegrations/AppIntegrations.ts new file mode 100644 index 000000000000..63ec5edb5cff --- /dev/null +++ b/clients/client-appintegrations/AppIntegrations.ts @@ -0,0 +1,346 @@ +import { AppIntegrationsClient } from "./AppIntegrationsClient"; +import { + CreateEventIntegrationCommand, + CreateEventIntegrationCommandInput, + CreateEventIntegrationCommandOutput, +} from "./commands/CreateEventIntegrationCommand"; +import { + DeleteEventIntegrationCommand, + DeleteEventIntegrationCommandInput, + DeleteEventIntegrationCommandOutput, +} from "./commands/DeleteEventIntegrationCommand"; +import { + GetEventIntegrationCommand, + GetEventIntegrationCommandInput, + GetEventIntegrationCommandOutput, +} from "./commands/GetEventIntegrationCommand"; +import { + ListEventIntegrationAssociationsCommand, + ListEventIntegrationAssociationsCommandInput, + ListEventIntegrationAssociationsCommandOutput, +} from "./commands/ListEventIntegrationAssociationsCommand"; +import { + ListEventIntegrationsCommand, + ListEventIntegrationsCommandInput, + ListEventIntegrationsCommandOutput, +} from "./commands/ListEventIntegrationsCommand"; +import { + ListTagsForResourceCommand, + ListTagsForResourceCommandInput, + ListTagsForResourceCommandOutput, +} from "./commands/ListTagsForResourceCommand"; +import { TagResourceCommand, TagResourceCommandInput, TagResourceCommandOutput } from "./commands/TagResourceCommand"; +import { + UntagResourceCommand, + UntagResourceCommandInput, + UntagResourceCommandOutput, +} from "./commands/UntagResourceCommand"; +import { + UpdateEventIntegrationCommand, + UpdateEventIntegrationCommandInput, + UpdateEventIntegrationCommandOutput, +} from "./commands/UpdateEventIntegrationCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ * + *

The Amazon AppIntegrations service enables you to configure and reuse connections to external applications.

+ *

For information about how you can use external applications with Amazon Connect, see Set up pre-built integrations in the Amazon Connect Administrator Guide.

+ */ +export class AppIntegrations extends AppIntegrationsClient { + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Creates an EventIntegration, given a specified name, description, and a reference to an + * Amazon Eventbridge bus in your account and a partner event source that will push events to that bus. No + * objects are created in the your account, only metadata that is persisted on the EventIntegration + * control plane.

+ */ + public createEventIntegration( + args: CreateEventIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createEventIntegration( + args: CreateEventIntegrationCommandInput, + cb: (err: any, data?: CreateEventIntegrationCommandOutput) => void + ): void; + public createEventIntegration( + args: CreateEventIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateEventIntegrationCommandOutput) => void + ): void; + public createEventIntegration( + args: CreateEventIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateEventIntegrationCommandOutput) => void), + cb?: (err: any, data?: CreateEventIntegrationCommandOutput) => void + ): Promise | void { + const command = new CreateEventIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Deletes the specified existing event integration. If the event integration is associated + * with clients, the request is rejected.

+ */ + public deleteEventIntegration( + args: DeleteEventIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteEventIntegration( + args: DeleteEventIntegrationCommandInput, + cb: (err: any, data?: DeleteEventIntegrationCommandOutput) => void + ): void; + public deleteEventIntegration( + args: DeleteEventIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteEventIntegrationCommandOutput) => void + ): void; + public deleteEventIntegration( + args: DeleteEventIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteEventIntegrationCommandOutput) => void), + cb?: (err: any, data?: DeleteEventIntegrationCommandOutput) => void + ): Promise | void { + const command = new DeleteEventIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Return information about the event integration.

+ */ + public getEventIntegration( + args: GetEventIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getEventIntegration( + args: GetEventIntegrationCommandInput, + cb: (err: any, data?: GetEventIntegrationCommandOutput) => void + ): void; + public getEventIntegration( + args: GetEventIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetEventIntegrationCommandOutput) => void + ): void; + public getEventIntegration( + args: GetEventIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetEventIntegrationCommandOutput) => void), + cb?: (err: any, data?: GetEventIntegrationCommandOutput) => void + ): Promise | void { + const command = new GetEventIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Returns a paginated list of event integration associations in the account.

+ */ + public listEventIntegrationAssociations( + args: ListEventIntegrationAssociationsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listEventIntegrationAssociations( + args: ListEventIntegrationAssociationsCommandInput, + cb: (err: any, data?: ListEventIntegrationAssociationsCommandOutput) => void + ): void; + public listEventIntegrationAssociations( + args: ListEventIntegrationAssociationsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListEventIntegrationAssociationsCommandOutput) => void + ): void; + public listEventIntegrationAssociations( + args: ListEventIntegrationAssociationsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListEventIntegrationAssociationsCommandOutput) => void), + cb?: (err: any, data?: ListEventIntegrationAssociationsCommandOutput) => void + ): Promise | void { + const command = new ListEventIntegrationAssociationsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Returns a paginated list of event integrations in the account.

+ */ + public listEventIntegrations( + args: ListEventIntegrationsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listEventIntegrations( + args: ListEventIntegrationsCommandInput, + cb: (err: any, data?: ListEventIntegrationsCommandOutput) => void + ): void; + public listEventIntegrations( + args: ListEventIntegrationsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListEventIntegrationsCommandOutput) => void + ): void; + public listEventIntegrations( + args: ListEventIntegrationsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListEventIntegrationsCommandOutput) => void), + cb?: (err: any, data?: ListEventIntegrationsCommandOutput) => void + ): Promise | void { + const command = new ListEventIntegrationsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Lists the tags for the specified resource.

+ */ + public listTagsForResource( + args: ListTagsForResourceCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listTagsForResource( + args: ListTagsForResourceCommandInput, + cb: (err: any, data?: ListTagsForResourceCommandOutput) => void + ): void; + public listTagsForResource( + args: ListTagsForResourceCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListTagsForResourceCommandOutput) => void + ): void; + public listTagsForResource( + args: ListTagsForResourceCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListTagsForResourceCommandOutput) => void), + cb?: (err: any, data?: ListTagsForResourceCommandOutput) => void + ): Promise | void { + const command = new ListTagsForResourceCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Adds the specified tags to the specified resource.

+ */ + public tagResource(args: TagResourceCommandInput, options?: __HttpHandlerOptions): Promise; + public tagResource(args: TagResourceCommandInput, cb: (err: any, data?: TagResourceCommandOutput) => void): void; + public tagResource( + args: TagResourceCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: TagResourceCommandOutput) => void + ): void; + public tagResource( + args: TagResourceCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: TagResourceCommandOutput) => void), + cb?: (err: any, data?: TagResourceCommandOutput) => void + ): Promise | void { + const command = new TagResourceCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Removes the specified tags from the specified resource.

+ */ + public untagResource( + args: UntagResourceCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public untagResource( + args: UntagResourceCommandInput, + cb: (err: any, data?: UntagResourceCommandOutput) => void + ): void; + public untagResource( + args: UntagResourceCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UntagResourceCommandOutput) => void + ): void; + public untagResource( + args: UntagResourceCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UntagResourceCommandOutput) => void), + cb?: (err: any, data?: UntagResourceCommandOutput) => void + ): Promise | void { + const command = new UntagResourceCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Updates the description of an event integration.

+ */ + public updateEventIntegration( + args: UpdateEventIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateEventIntegration( + args: UpdateEventIntegrationCommandInput, + cb: (err: any, data?: UpdateEventIntegrationCommandOutput) => void + ): void; + public updateEventIntegration( + args: UpdateEventIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateEventIntegrationCommandOutput) => void + ): void; + public updateEventIntegration( + args: UpdateEventIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateEventIntegrationCommandOutput) => void), + cb?: (err: any, data?: UpdateEventIntegrationCommandOutput) => void + ): Promise | void { + const command = new UpdateEventIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-appintegrations/AppIntegrationsClient.ts b/clients/client-appintegrations/AppIntegrationsClient.ts new file mode 100644 index 000000000000..03ad12c508a0 --- /dev/null +++ b/clients/client-appintegrations/AppIntegrationsClient.ts @@ -0,0 +1,252 @@ +import { + CreateEventIntegrationCommandInput, + CreateEventIntegrationCommandOutput, +} from "./commands/CreateEventIntegrationCommand"; +import { + DeleteEventIntegrationCommandInput, + DeleteEventIntegrationCommandOutput, +} from "./commands/DeleteEventIntegrationCommand"; +import { + GetEventIntegrationCommandInput, + GetEventIntegrationCommandOutput, +} from "./commands/GetEventIntegrationCommand"; +import { + ListEventIntegrationAssociationsCommandInput, + ListEventIntegrationAssociationsCommandOutput, +} from "./commands/ListEventIntegrationAssociationsCommand"; +import { + ListEventIntegrationsCommandInput, + ListEventIntegrationsCommandOutput, +} from "./commands/ListEventIntegrationsCommand"; +import { + ListTagsForResourceCommandInput, + ListTagsForResourceCommandOutput, +} from "./commands/ListTagsForResourceCommand"; +import { TagResourceCommandInput, TagResourceCommandOutput } from "./commands/TagResourceCommand"; +import { UntagResourceCommandInput, UntagResourceCommandOutput } from "./commands/UntagResourceCommand"; +import { + UpdateEventIntegrationCommandInput, + UpdateEventIntegrationCommandOutput, +} from "./commands/UpdateEventIntegrationCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = + | CreateEventIntegrationCommandInput + | DeleteEventIntegrationCommandInput + | GetEventIntegrationCommandInput + | ListEventIntegrationAssociationsCommandInput + | ListEventIntegrationsCommandInput + | ListTagsForResourceCommandInput + | TagResourceCommandInput + | UntagResourceCommandInput + | UpdateEventIntegrationCommandInput; + +export type ServiceOutputTypes = + | CreateEventIntegrationCommandOutput + | DeleteEventIntegrationCommandOutput + | GetEventIntegrationCommandOutput + | ListEventIntegrationAssociationsCommandOutput + | ListEventIntegrationsCommandOutput + | ListTagsForResourceCommandOutput + | TagResourceCommandOutput + | UntagResourceCommandOutput + | UpdateEventIntegrationCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type AppIntegrationsClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type AppIntegrationsClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ * + *

The Amazon AppIntegrations service enables you to configure and reuse connections to external applications.

+ *

For information about how you can use external applications with Amazon Connect, see Set up pre-built integrations in the Amazon Connect Administrator Guide.

+ */ +export class AppIntegrationsClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + AppIntegrationsClientResolvedConfig +> { + readonly config: AppIntegrationsClientResolvedConfig; + + constructor(configuration: AppIntegrationsClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-appintegrations/LICENSE b/clients/client-appintegrations/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-appintegrations/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-appintegrations/README.md b/clients/client-appintegrations/README.md new file mode 100644 index 000000000000..dd1d65f24024 --- /dev/null +++ b/clients/client-appintegrations/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-appintegrations + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-appintegrations/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-appintegrations) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-appintegrations.svg)](https://www.npmjs.com/package/@aws-sdk/client-appintegrations) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-appintegrations/commands/CreateEventIntegrationCommand.ts b/clients/client-appintegrations/commands/CreateEventIntegrationCommand.ts new file mode 100644 index 000000000000..753b4ce15497 --- /dev/null +++ b/clients/client-appintegrations/commands/CreateEventIntegrationCommand.ts @@ -0,0 +1,92 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { CreateEventIntegrationRequest, CreateEventIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateEventIntegrationCommand, + serializeAws_restJson1CreateEventIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateEventIntegrationCommandInput = CreateEventIntegrationRequest; +export type CreateEventIntegrationCommandOutput = CreateEventIntegrationResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Creates an EventIntegration, given a specified name, description, and a reference to an + * Amazon Eventbridge bus in your account and a partner event source that will push events to that bus. No + * objects are created in the your account, only metadata that is persisted on the EventIntegration + * control plane.

+ */ +export class CreateEventIntegrationCommand extends $Command< + CreateEventIntegrationCommandInput, + CreateEventIntegrationCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateEventIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "CreateEventIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateEventIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateEventIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateEventIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateEventIntegrationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateEventIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/DeleteEventIntegrationCommand.ts b/clients/client-appintegrations/commands/DeleteEventIntegrationCommand.ts new file mode 100644 index 000000000000..2c370eeb9ea1 --- /dev/null +++ b/clients/client-appintegrations/commands/DeleteEventIntegrationCommand.ts @@ -0,0 +1,90 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { DeleteEventIntegrationRequest, DeleteEventIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteEventIntegrationCommand, + serializeAws_restJson1DeleteEventIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteEventIntegrationCommandInput = DeleteEventIntegrationRequest; +export type DeleteEventIntegrationCommandOutput = DeleteEventIntegrationResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Deletes the specified existing event integration. If the event integration is associated + * with clients, the request is rejected.

+ */ +export class DeleteEventIntegrationCommand extends $Command< + DeleteEventIntegrationCommandInput, + DeleteEventIntegrationCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteEventIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "DeleteEventIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteEventIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteEventIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteEventIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteEventIntegrationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteEventIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/GetEventIntegrationCommand.ts b/clients/client-appintegrations/commands/GetEventIntegrationCommand.ts new file mode 100644 index 000000000000..be210be4b497 --- /dev/null +++ b/clients/client-appintegrations/commands/GetEventIntegrationCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { GetEventIntegrationRequest, GetEventIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetEventIntegrationCommand, + serializeAws_restJson1GetEventIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetEventIntegrationCommandInput = GetEventIntegrationRequest; +export type GetEventIntegrationCommandOutput = GetEventIntegrationResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Return information about the event integration.

+ */ +export class GetEventIntegrationCommand extends $Command< + GetEventIntegrationCommandInput, + GetEventIntegrationCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetEventIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "GetEventIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetEventIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetEventIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetEventIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetEventIntegrationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetEventIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/ListEventIntegrationAssociationsCommand.ts b/clients/client-appintegrations/commands/ListEventIntegrationAssociationsCommand.ts new file mode 100644 index 000000000000..9b37e1327e57 --- /dev/null +++ b/clients/client-appintegrations/commands/ListEventIntegrationAssociationsCommand.ts @@ -0,0 +1,95 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { ListEventIntegrationAssociationsRequest, ListEventIntegrationAssociationsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListEventIntegrationAssociationsCommand, + serializeAws_restJson1ListEventIntegrationAssociationsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListEventIntegrationAssociationsCommandInput = ListEventIntegrationAssociationsRequest; +export type ListEventIntegrationAssociationsCommandOutput = ListEventIntegrationAssociationsResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Returns a paginated list of event integration associations in the account.

+ */ +export class ListEventIntegrationAssociationsCommand extends $Command< + ListEventIntegrationAssociationsCommandInput, + ListEventIntegrationAssociationsCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListEventIntegrationAssociationsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "ListEventIntegrationAssociationsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListEventIntegrationAssociationsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListEventIntegrationAssociationsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: ListEventIntegrationAssociationsCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_restJson1ListEventIntegrationAssociationsCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1ListEventIntegrationAssociationsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/ListEventIntegrationsCommand.ts b/clients/client-appintegrations/commands/ListEventIntegrationsCommand.ts new file mode 100644 index 000000000000..857d9ad0a92f --- /dev/null +++ b/clients/client-appintegrations/commands/ListEventIntegrationsCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { ListEventIntegrationsRequest, ListEventIntegrationsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListEventIntegrationsCommand, + serializeAws_restJson1ListEventIntegrationsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListEventIntegrationsCommandInput = ListEventIntegrationsRequest; +export type ListEventIntegrationsCommandOutput = ListEventIntegrationsResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Returns a paginated list of event integrations in the account.

+ */ +export class ListEventIntegrationsCommand extends $Command< + ListEventIntegrationsCommandInput, + ListEventIntegrationsCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListEventIntegrationsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "ListEventIntegrationsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListEventIntegrationsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListEventIntegrationsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListEventIntegrationsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListEventIntegrationsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListEventIntegrationsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/ListTagsForResourceCommand.ts b/clients/client-appintegrations/commands/ListTagsForResourceCommand.ts new file mode 100644 index 000000000000..88d38bec15da --- /dev/null +++ b/clients/client-appintegrations/commands/ListTagsForResourceCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { ListTagsForResourceRequest, ListTagsForResourceResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListTagsForResourceCommand, + serializeAws_restJson1ListTagsForResourceCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListTagsForResourceCommandInput = ListTagsForResourceRequest; +export type ListTagsForResourceCommandOutput = ListTagsForResourceResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Lists the tags for the specified resource.

+ */ +export class ListTagsForResourceCommand extends $Command< + ListTagsForResourceCommandInput, + ListTagsForResourceCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListTagsForResourceCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "ListTagsForResourceCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListTagsForResourceRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListTagsForResourceResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListTagsForResourceCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListTagsForResourceCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListTagsForResourceCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/TagResourceCommand.ts b/clients/client-appintegrations/commands/TagResourceCommand.ts new file mode 100644 index 000000000000..941fae040c90 --- /dev/null +++ b/clients/client-appintegrations/commands/TagResourceCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { TagResourceRequest, TagResourceResponse } from "../models/models_0"; +import { + deserializeAws_restJson1TagResourceCommand, + serializeAws_restJson1TagResourceCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type TagResourceCommandInput = TagResourceRequest; +export type TagResourceCommandOutput = TagResourceResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Adds the specified tags to the specified resource.

+ */ +export class TagResourceCommand extends $Command< + TagResourceCommandInput, + TagResourceCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: TagResourceCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "TagResourceCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: TagResourceRequest.filterSensitiveLog, + outputFilterSensitiveLog: TagResourceResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: TagResourceCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1TagResourceCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1TagResourceCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/UntagResourceCommand.ts b/clients/client-appintegrations/commands/UntagResourceCommand.ts new file mode 100644 index 000000000000..c1f54d1ffbbd --- /dev/null +++ b/clients/client-appintegrations/commands/UntagResourceCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { UntagResourceRequest, UntagResourceResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UntagResourceCommand, + serializeAws_restJson1UntagResourceCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UntagResourceCommandInput = UntagResourceRequest; +export type UntagResourceCommandOutput = UntagResourceResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Removes the specified tags from the specified resource.

+ */ +export class UntagResourceCommand extends $Command< + UntagResourceCommandInput, + UntagResourceCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UntagResourceCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "UntagResourceCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UntagResourceRequest.filterSensitiveLog, + outputFilterSensitiveLog: UntagResourceResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UntagResourceCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UntagResourceCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UntagResourceCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/commands/UpdateEventIntegrationCommand.ts b/clients/client-appintegrations/commands/UpdateEventIntegrationCommand.ts new file mode 100644 index 000000000000..50bad5f1ffc3 --- /dev/null +++ b/clients/client-appintegrations/commands/UpdateEventIntegrationCommand.ts @@ -0,0 +1,89 @@ +import { AppIntegrationsClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AppIntegrationsClient"; +import { UpdateEventIntegrationRequest, UpdateEventIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateEventIntegrationCommand, + serializeAws_restJson1UpdateEventIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateEventIntegrationCommandInput = UpdateEventIntegrationRequest; +export type UpdateEventIntegrationCommandOutput = UpdateEventIntegrationResponse & __MetadataBearer; + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

Updates the description of an event integration.

+ */ +export class UpdateEventIntegrationCommand extends $Command< + UpdateEventIntegrationCommandInput, + UpdateEventIntegrationCommandOutput, + AppIntegrationsClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateEventIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: AppIntegrationsClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "AppIntegrationsClient"; + const commandName = "UpdateEventIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateEventIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateEventIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateEventIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateEventIntegrationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateEventIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-appintegrations/endpoints.ts b/clients/client-appintegrations/endpoints.ts new file mode 100644 index 000000000000..60033aa33b5f --- /dev/null +++ b/clients/client-appintegrations/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "app-integrations.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "app-integrations.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "app-integrations.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "app-integrations.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "app-integrations.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-appintegrations/index.ts b/clients/client-appintegrations/index.ts new file mode 100644 index 000000000000..96603420f8cd --- /dev/null +++ b/clients/client-appintegrations/index.ts @@ -0,0 +1,12 @@ +export * from "./AppIntegrationsClient"; +export * from "./AppIntegrations"; +export * from "./commands/CreateEventIntegrationCommand"; +export * from "./commands/DeleteEventIntegrationCommand"; +export * from "./commands/GetEventIntegrationCommand"; +export * from "./commands/ListEventIntegrationAssociationsCommand"; +export * from "./commands/ListEventIntegrationsCommand"; +export * from "./commands/ListTagsForResourceCommand"; +export * from "./commands/TagResourceCommand"; +export * from "./commands/UntagResourceCommand"; +export * from "./commands/UpdateEventIntegrationCommand"; +export * from "./models/index"; diff --git a/clients/client-appintegrations/models/index.ts b/clients/client-appintegrations/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-appintegrations/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-appintegrations/models/models_0.ts b/clients/client-appintegrations/models/models_0.ts new file mode 100644 index 000000000000..424aa1b5ce78 --- /dev/null +++ b/clients/client-appintegrations/models/models_0.ts @@ -0,0 +1,515 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +/** + *

You do not have sufficient access to perform this action.

+ */ +export interface AccessDeniedException extends __SmithyException, $MetadataBearer { + name: "AccessDeniedException"; + $fault: "client"; + Message?: string; +} + +export namespace AccessDeniedException { + export const filterSensitiveLog = (obj: AccessDeniedException): any => ({ + ...obj, + }); +} + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

The event filter.

+ */ +export interface EventFilter { + /** + *

The source of the events.

+ */ + Source: string | undefined; +} + +export namespace EventFilter { + export const filterSensitiveLog = (obj: EventFilter): any => ({ + ...obj, + }); +} + +export interface CreateEventIntegrationRequest { + /** + *

The name of the event integration.

+ */ + Name: string | undefined; + + /** + *

The description of the event integration.

+ */ + Description?: string; + + /** + *

The event filter.

+ */ + EventFilter: EventFilter | undefined; + + /** + *

The Eventbridge bus.

+ */ + EventBridgeBus: string | undefined; + + /** + *

A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

+ */ + ClientToken?: string; + + /** + *

One or more tags.

+ */ + Tags?: { [key: string]: string }; +} + +export namespace CreateEventIntegrationRequest { + export const filterSensitiveLog = (obj: CreateEventIntegrationRequest): any => ({ + ...obj, + }); +} + +export interface CreateEventIntegrationResponse { + /** + *

The Amazon Resource Name (ARN) of the event integration.

+ */ + EventIntegrationArn?: string; +} + +export namespace CreateEventIntegrationResponse { + export const filterSensitiveLog = (obj: CreateEventIntegrationResponse): any => ({ + ...obj, + }); +} + +/** + *

A resource with the specified name already exists.

+ */ +export interface DuplicateResourceException extends __SmithyException, $MetadataBearer { + name: "DuplicateResourceException"; + $fault: "client"; + Message?: string; +} + +export namespace DuplicateResourceException { + export const filterSensitiveLog = (obj: DuplicateResourceException): any => ({ + ...obj, + }); +} + +/** + *

Request processing failed due to an error or failure with the service.

+ */ +export interface InternalServiceError extends __SmithyException, $MetadataBearer { + name: "InternalServiceError"; + $fault: "server"; + Message?: string; +} + +export namespace InternalServiceError { + export const filterSensitiveLog = (obj: InternalServiceError): any => ({ + ...obj, + }); +} + +/** + *

The request is not valid.

+ */ +export interface InvalidRequestException extends __SmithyException, $MetadataBearer { + name: "InvalidRequestException"; + $fault: "client"; + Message?: string; +} + +export namespace InvalidRequestException { + export const filterSensitiveLog = (obj: InvalidRequestException): any => ({ + ...obj, + }); +} + +/** + *

The allowed quota for the resource has been exceeded.

+ */ +export interface ResourceQuotaExceededException extends __SmithyException, $MetadataBearer { + name: "ResourceQuotaExceededException"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceQuotaExceededException { + export const filterSensitiveLog = (obj: ResourceQuotaExceededException): any => ({ + ...obj, + }); +} + +/** + *

The throttling limit has been exceeded.

+ */ +export interface ThrottlingException extends __SmithyException, $MetadataBearer { + name: "ThrottlingException"; + $fault: "client"; + Message?: string; +} + +export namespace ThrottlingException { + export const filterSensitiveLog = (obj: ThrottlingException): any => ({ + ...obj, + }); +} + +export interface DeleteEventIntegrationRequest { + /** + *

The name of the event integration.

+ */ + Name: string | undefined; +} + +export namespace DeleteEventIntegrationRequest { + export const filterSensitiveLog = (obj: DeleteEventIntegrationRequest): any => ({ + ...obj, + }); +} + +export interface DeleteEventIntegrationResponse {} + +export namespace DeleteEventIntegrationResponse { + export const filterSensitiveLog = (obj: DeleteEventIntegrationResponse): any => ({ + ...obj, + }); +} + +/** + *

The specified resource was not found.

+ */ +export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { + name: "ResourceNotFoundException"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceNotFoundException { + export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ + ...obj, + }); +} + +export interface GetEventIntegrationRequest { + /** + *

The name of the event integration.

+ */ + Name: string | undefined; +} + +export namespace GetEventIntegrationRequest { + export const filterSensitiveLog = (obj: GetEventIntegrationRequest): any => ({ + ...obj, + }); +} + +export interface GetEventIntegrationResponse { + /** + *

The name of the event integration.

+ */ + Name?: string; + + /** + *

The description of the event integration.

+ */ + Description?: string; + + /** + *

The Amazon Resource Name (ARN) for the event integration.

+ */ + EventIntegrationArn?: string; + + /** + *

The Eventbridge bus.

+ */ + EventBridgeBus?: string; + + /** + *

The event filter.

+ */ + EventFilter?: EventFilter; + + /** + *

One or more tags.

+ */ + Tags?: { [key: string]: string }; +} + +export namespace GetEventIntegrationResponse { + export const filterSensitiveLog = (obj: GetEventIntegrationResponse): any => ({ + ...obj, + }); +} + +export interface ListEventIntegrationAssociationsRequest { + /** + *

The name of the event integration.

+ */ + EventIntegrationName: string | undefined; + + /** + *

The token for the next set of results. Use the value returned in the previous + * response in the next request to retrieve the next set of results.

+ */ + NextToken?: string; + + /** + *

The maximum number of results to return per page.

+ */ + MaxResults?: number; +} + +export namespace ListEventIntegrationAssociationsRequest { + export const filterSensitiveLog = (obj: ListEventIntegrationAssociationsRequest): any => ({ + ...obj, + }); +} + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

The event integration association.

+ */ +export interface EventIntegrationAssociation { + /** + *

The Amazon Resource Name (ARN) for the event integration association.

+ */ + EventIntegrationAssociationArn?: string; + + /** + *

The identifier for the event integration association.

+ */ + EventIntegrationAssociationId?: string; + + /** + *

The name of the event integration.

+ */ + EventIntegrationName?: string; + + /** + *

The identifier for the client that is associated with the event integration.

+ */ + ClientId?: string; + + /** + *

The name of the Eventbridge rule.

+ */ + EventBridgeRuleName?: string; + + /** + *

The metadata associated with the client.

+ */ + ClientAssociationMetadata?: { [key: string]: string }; +} + +export namespace EventIntegrationAssociation { + export const filterSensitiveLog = (obj: EventIntegrationAssociation): any => ({ + ...obj, + }); +} + +export interface ListEventIntegrationAssociationsResponse { + /** + *

The event integration associations.

+ */ + EventIntegrationAssociations?: EventIntegrationAssociation[]; + + /** + *

If there are additional results, this is the token for the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListEventIntegrationAssociationsResponse { + export const filterSensitiveLog = (obj: ListEventIntegrationAssociationsResponse): any => ({ + ...obj, + }); +} + +export interface ListEventIntegrationsRequest { + /** + *

The token for the next set of results. Use the value returned in the previous + * response in the next request to retrieve the next set of results.

+ */ + NextToken?: string; + + /** + *

The maximum number of results to return per page.

+ */ + MaxResults?: number; +} + +export namespace ListEventIntegrationsRequest { + export const filterSensitiveLog = (obj: ListEventIntegrationsRequest): any => ({ + ...obj, + }); +} + +/** + *

The Amazon AppIntegrations APIs are in preview release and are subject to change.

+ *

The event integration.

+ */ +export interface EventIntegration { + /** + *

The Amazon Resource Name (ARN) of the event integration.

+ */ + EventIntegrationArn?: string; + + /** + *

The name of the event integration.

+ */ + Name?: string; + + /** + *

The event integration description.

+ */ + Description?: string; + + /** + *

The event integration filter.

+ */ + EventFilter?: EventFilter; + + /** + *

The Amazon Eventbridge bus for the event integration.

+ */ + EventBridgeBus?: string; + + /** + *

The tags.

+ */ + Tags?: { [key: string]: string }; +} + +export namespace EventIntegration { + export const filterSensitiveLog = (obj: EventIntegration): any => ({ + ...obj, + }); +} + +export interface ListEventIntegrationsResponse { + /** + *

The event integrations.

+ */ + EventIntegrations?: EventIntegration[]; + + /** + *

If there are additional results, this is the token for the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListEventIntegrationsResponse { + export const filterSensitiveLog = (obj: ListEventIntegrationsResponse): any => ({ + ...obj, + }); +} + +export interface ListTagsForResourceRequest { + /** + *

The Amazon Resource Name (ARN) of the resource.

+ */ + resourceArn: string | undefined; +} + +export namespace ListTagsForResourceRequest { + export const filterSensitiveLog = (obj: ListTagsForResourceRequest): any => ({ + ...obj, + }); +} + +export interface ListTagsForResourceResponse { + /** + *

Information about the tags.

+ */ + tags?: { [key: string]: string }; +} + +export namespace ListTagsForResourceResponse { + export const filterSensitiveLog = (obj: ListTagsForResourceResponse): any => ({ + ...obj, + }); +} + +export interface TagResourceRequest { + /** + *

The Amazon Resource Name (ARN) of the resource.

+ */ + resourceArn: string | undefined; + + /** + *

One or more tags.

+ */ + tags: { [key: string]: string } | undefined; +} + +export namespace TagResourceRequest { + export const filterSensitiveLog = (obj: TagResourceRequest): any => ({ + ...obj, + }); +} + +export interface TagResourceResponse {} + +export namespace TagResourceResponse { + export const filterSensitiveLog = (obj: TagResourceResponse): any => ({ + ...obj, + }); +} + +export interface UntagResourceRequest { + /** + *

The Amazon Resource Name (ARN) of the resource.

+ */ + resourceArn: string | undefined; + + /** + *

The tag keys.

+ */ + tagKeys: string[] | undefined; +} + +export namespace UntagResourceRequest { + export const filterSensitiveLog = (obj: UntagResourceRequest): any => ({ + ...obj, + }); +} + +export interface UntagResourceResponse {} + +export namespace UntagResourceResponse { + export const filterSensitiveLog = (obj: UntagResourceResponse): any => ({ + ...obj, + }); +} + +export interface UpdateEventIntegrationRequest { + /** + *

The name of the event integration.

+ */ + Name: string | undefined; + + /** + *

The description of the event inegration.

+ */ + Description?: string; +} + +export namespace UpdateEventIntegrationRequest { + export const filterSensitiveLog = (obj: UpdateEventIntegrationRequest): any => ({ + ...obj, + }); +} + +export interface UpdateEventIntegrationResponse {} + +export namespace UpdateEventIntegrationResponse { + export const filterSensitiveLog = (obj: UpdateEventIntegrationResponse): any => ({ + ...obj, + }); +} diff --git a/clients/client-appintegrations/package.json b/clients/client-appintegrations/package.json new file mode 100644 index 000000000000..47af5c55d92b --- /dev/null +++ b/clients/client-appintegrations/package.json @@ -0,0 +1,85 @@ +{ + "name": "@aws-sdk/client-appintegrations", + "description": "AWS SDK for JavaScript Appintegrations Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0", + "uuid": "^3.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "@types/uuid": "^3.0.0", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-appintegrations", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-appintegrations" + } +} diff --git a/clients/client-appintegrations/protocols/Aws_restJson1.ts b/clients/client-appintegrations/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..407a556437e3 --- /dev/null +++ b/clients/client-appintegrations/protocols/Aws_restJson1.ts @@ -0,0 +1,1400 @@ +import { + CreateEventIntegrationCommandInput, + CreateEventIntegrationCommandOutput, +} from "../commands/CreateEventIntegrationCommand"; +import { + DeleteEventIntegrationCommandInput, + DeleteEventIntegrationCommandOutput, +} from "../commands/DeleteEventIntegrationCommand"; +import { + GetEventIntegrationCommandInput, + GetEventIntegrationCommandOutput, +} from "../commands/GetEventIntegrationCommand"; +import { + ListEventIntegrationAssociationsCommandInput, + ListEventIntegrationAssociationsCommandOutput, +} from "../commands/ListEventIntegrationAssociationsCommand"; +import { + ListEventIntegrationsCommandInput, + ListEventIntegrationsCommandOutput, +} from "../commands/ListEventIntegrationsCommand"; +import { + ListTagsForResourceCommandInput, + ListTagsForResourceCommandOutput, +} from "../commands/ListTagsForResourceCommand"; +import { TagResourceCommandInput, TagResourceCommandOutput } from "../commands/TagResourceCommand"; +import { UntagResourceCommandInput, UntagResourceCommandOutput } from "../commands/UntagResourceCommand"; +import { + UpdateEventIntegrationCommandInput, + UpdateEventIntegrationCommandOutput, +} from "../commands/UpdateEventIntegrationCommand"; +import { + AccessDeniedException, + DuplicateResourceException, + EventFilter, + EventIntegration, + EventIntegrationAssociation, + InternalServiceError, + InvalidRequestException, + ResourceNotFoundException, + ResourceQuotaExceededException, + ThrottlingException, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { + SmithyException as __SmithyException, + extendedEncodeURIComponent as __extendedEncodeURIComponent, +} from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; +import { v4 as generateIdempotencyToken } from "uuid"; + +export const serializeAws_restJson1CreateEventIntegrationCommand = async ( + input: CreateEventIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/eventIntegrations"; + let body: any; + body = JSON.stringify({ + ClientToken: input.ClientToken ?? generateIdempotencyToken(), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.EventBridgeBus !== undefined && { EventBridgeBus: input.EventBridgeBus }), + ...(input.EventFilter !== undefined && { + EventFilter: serializeAws_restJson1EventFilter(input.EventFilter, context), + }), + ...(input.Name !== undefined && { Name: input.Name }), + ...(input.Tags !== undefined && { Tags: serializeAws_restJson1TagMap(input.Tags, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteEventIntegrationCommand = async ( + input: DeleteEventIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/eventIntegrations/{Name}"; + if (input.Name !== undefined) { + const labelValue: string = input.Name; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Name."); + } + resolvedPath = resolvedPath.replace("{Name}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Name."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetEventIntegrationCommand = async ( + input: GetEventIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/eventIntegrations/{Name}"; + if (input.Name !== undefined) { + const labelValue: string = input.Name; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Name."); + } + resolvedPath = resolvedPath.replace("{Name}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Name."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListEventIntegrationAssociationsCommand = async ( + input: ListEventIntegrationAssociationsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/eventIntegrations/{EventIntegrationName}/associations"; + if (input.EventIntegrationName !== undefined) { + const labelValue: string = input.EventIntegrationName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: EventIntegrationName."); + } + resolvedPath = resolvedPath.replace("{EventIntegrationName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: EventIntegrationName."); + } + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListEventIntegrationsCommand = async ( + input: ListEventIntegrationsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/eventIntegrations"; + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListTagsForResourceCommand = async ( + input: ListTagsForResourceCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/tags/{resourceArn}"; + if (input.resourceArn !== undefined) { + const labelValue: string = input.resourceArn; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: resourceArn."); + } + resolvedPath = resolvedPath.replace("{resourceArn}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: resourceArn."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1TagResourceCommand = async ( + input: TagResourceCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/tags/{resourceArn}"; + if (input.resourceArn !== undefined) { + const labelValue: string = input.resourceArn; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: resourceArn."); + } + resolvedPath = resolvedPath.replace("{resourceArn}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: resourceArn."); + } + let body: any; + body = JSON.stringify({ + ...(input.tags !== undefined && { tags: serializeAws_restJson1TagMap(input.tags, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UntagResourceCommand = async ( + input: UntagResourceCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/tags/{resourceArn}"; + if (input.resourceArn !== undefined) { + const labelValue: string = input.resourceArn; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: resourceArn."); + } + resolvedPath = resolvedPath.replace("{resourceArn}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: resourceArn."); + } + const query: any = { + ...(input.tagKeys !== undefined && { tagKeys: (input.tagKeys || []).map((_entry) => _entry) }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1UpdateEventIntegrationCommand = async ( + input: UpdateEventIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/eventIntegrations/{Name}"; + if (input.Name !== undefined) { + const labelValue: string = input.Name; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Name."); + } + resolvedPath = resolvedPath.replace("{Name}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Name."); + } + let body: any; + body = JSON.stringify({ + ...(input.Description !== undefined && { Description: input.Description }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PATCH", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1CreateEventIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateEventIntegrationCommandError(output, context); + } + const contents: CreateEventIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + EventIntegrationArn: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.EventIntegrationArn !== undefined && data.EventIntegrationArn !== null) { + contents.EventIntegrationArn = data.EventIntegrationArn; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateEventIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "DuplicateResourceException": + case "com.amazonaws.appintegrations#DuplicateResourceException": + response = { + ...(await deserializeAws_restJson1DuplicateResourceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceQuotaExceededException": + case "com.amazonaws.appintegrations#ResourceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ResourceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteEventIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteEventIntegrationCommandError(output, context); + } + const contents: DeleteEventIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteEventIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetEventIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetEventIntegrationCommandError(output, context); + } + const contents: GetEventIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + Description: undefined, + EventBridgeBus: undefined, + EventFilter: undefined, + EventIntegrationArn: undefined, + Name: undefined, + Tags: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Description !== undefined && data.Description !== null) { + contents.Description = data.Description; + } + if (data.EventBridgeBus !== undefined && data.EventBridgeBus !== null) { + contents.EventBridgeBus = data.EventBridgeBus; + } + if (data.EventFilter !== undefined && data.EventFilter !== null) { + contents.EventFilter = deserializeAws_restJson1EventFilter(data.EventFilter, context); + } + if (data.EventIntegrationArn !== undefined && data.EventIntegrationArn !== null) { + contents.EventIntegrationArn = data.EventIntegrationArn; + } + if (data.Name !== undefined && data.Name !== null) { + contents.Name = data.Name; + } + if (data.Tags !== undefined && data.Tags !== null) { + contents.Tags = deserializeAws_restJson1TagMap(data.Tags, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetEventIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListEventIntegrationAssociationsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListEventIntegrationAssociationsCommandError(output, context); + } + const contents: ListEventIntegrationAssociationsCommandOutput = { + $metadata: deserializeMetadata(output), + EventIntegrationAssociations: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.EventIntegrationAssociations !== undefined && data.EventIntegrationAssociations !== null) { + contents.EventIntegrationAssociations = deserializeAws_restJson1EventIntegrationAssociationsList( + data.EventIntegrationAssociations, + context + ); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListEventIntegrationAssociationsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListEventIntegrationsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListEventIntegrationsCommandError(output, context); + } + const contents: ListEventIntegrationsCommandOutput = { + $metadata: deserializeMetadata(output), + EventIntegrations: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.EventIntegrations !== undefined && data.EventIntegrations !== null) { + contents.EventIntegrations = deserializeAws_restJson1EventIntegrationsList(data.EventIntegrations, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListEventIntegrationsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListTagsForResourceCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListTagsForResourceCommandError(output, context); + } + const contents: ListTagsForResourceCommandOutput = { + $metadata: deserializeMetadata(output), + tags: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.tags !== undefined && data.tags !== null) { + contents.tags = deserializeAws_restJson1TagMap(data.tags, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListTagsForResourceCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1TagResourceCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1TagResourceCommandError(output, context); + } + const contents: TagResourceCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1TagResourceCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UntagResourceCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UntagResourceCommandError(output, context); + } + const contents: UntagResourceCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UntagResourceCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateEventIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateEventIntegrationCommandError(output, context); + } + const contents: UpdateEventIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateEventIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.appintegrations#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceError": + case "com.amazonaws.appintegrations#InternalServiceError": + response = { + ...(await deserializeAws_restJson1InternalServiceErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.appintegrations#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.appintegrations#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.appintegrations#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1AccessDeniedExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: AccessDeniedException = { + name: "AccessDeniedException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1DuplicateResourceExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: DuplicateResourceException = { + name: "DuplicateResourceException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1InternalServiceErrorResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InternalServiceError = { + name: "InternalServiceError", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1InvalidRequestExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InvalidRequestException = { + name: "InvalidRequestException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceNotFoundException = { + name: "ResourceNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceQuotaExceededExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceQuotaExceededException = { + name: "ResourceQuotaExceededException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ThrottlingExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ThrottlingException = { + name: "ThrottlingException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const serializeAws_restJson1EventFilter = (input: EventFilter, context: __SerdeContext): any => { + return { + ...(input.Source !== undefined && { Source: input.Source }), + }; +}; + +const serializeAws_restJson1TagMap = (input: { [key: string]: string }, context: __SerdeContext): any => { + return Object.entries(input).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + +const deserializeAws_restJson1ClientAssociationMetadata = ( + output: any, + context: __SerdeContext +): { [key: string]: string } => { + return Object.entries(output).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + +const deserializeAws_restJson1EventFilter = (output: any, context: __SerdeContext): EventFilter => { + return { + Source: output.Source !== undefined && output.Source !== null ? output.Source : undefined, + } as any; +}; + +const deserializeAws_restJson1EventIntegration = (output: any, context: __SerdeContext): EventIntegration => { + return { + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + EventBridgeBus: + output.EventBridgeBus !== undefined && output.EventBridgeBus !== null ? output.EventBridgeBus : undefined, + EventFilter: + output.EventFilter !== undefined && output.EventFilter !== null + ? deserializeAws_restJson1EventFilter(output.EventFilter, context) + : undefined, + EventIntegrationArn: + output.EventIntegrationArn !== undefined && output.EventIntegrationArn !== null + ? output.EventIntegrationArn + : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_restJson1TagMap(output.Tags, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1EventIntegrationAssociation = ( + output: any, + context: __SerdeContext +): EventIntegrationAssociation => { + return { + ClientAssociationMetadata: + output.ClientAssociationMetadata !== undefined && output.ClientAssociationMetadata !== null + ? deserializeAws_restJson1ClientAssociationMetadata(output.ClientAssociationMetadata, context) + : undefined, + ClientId: output.ClientId !== undefined && output.ClientId !== null ? output.ClientId : undefined, + EventBridgeRuleName: + output.EventBridgeRuleName !== undefined && output.EventBridgeRuleName !== null + ? output.EventBridgeRuleName + : undefined, + EventIntegrationAssociationArn: + output.EventIntegrationAssociationArn !== undefined && output.EventIntegrationAssociationArn !== null + ? output.EventIntegrationAssociationArn + : undefined, + EventIntegrationAssociationId: + output.EventIntegrationAssociationId !== undefined && output.EventIntegrationAssociationId !== null + ? output.EventIntegrationAssociationId + : undefined, + EventIntegrationName: + output.EventIntegrationName !== undefined && output.EventIntegrationName !== null + ? output.EventIntegrationName + : undefined, + } as any; +}; + +const deserializeAws_restJson1EventIntegrationAssociationsList = ( + output: any, + context: __SerdeContext +): EventIntegrationAssociation[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1EventIntegrationAssociation(entry, context)); +}; + +const deserializeAws_restJson1EventIntegrationsList = (output: any, context: __SerdeContext): EventIntegration[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1EventIntegration(entry, context)); +}; + +const deserializeAws_restJson1TagMap = (output: any, context: __SerdeContext): { [key: string]: string } => { + return Object.entries(output).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-appintegrations/runtimeConfig.browser.ts b/clients/client-appintegrations/runtimeConfig.browser.ts new file mode 100644 index 000000000000..f8911bb4e730 --- /dev/null +++ b/clients/client-appintegrations/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./AppIntegrationsClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-appintegrations/runtimeConfig.native.ts b/clients/client-appintegrations/runtimeConfig.native.ts new file mode 100644 index 000000000000..9dddd1281d4e --- /dev/null +++ b/clients/client-appintegrations/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./AppIntegrationsClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-appintegrations/runtimeConfig.shared.ts b/clients/client-appintegrations/runtimeConfig.shared.ts new file mode 100644 index 000000000000..ac0aeac465bf --- /dev/null +++ b/clients/client-appintegrations/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-07-29", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "app-integrations", +}; diff --git a/clients/client-appintegrations/runtimeConfig.ts b/clients/client-appintegrations/runtimeConfig.ts new file mode 100644 index 000000000000..facdeb033815 --- /dev/null +++ b/clients/client-appintegrations/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./AppIntegrationsClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-appintegrations/tsconfig.es.json b/clients/client-appintegrations/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-appintegrations/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-appintegrations/tsconfig.json b/clients/client-appintegrations/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-appintegrations/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-connect-contact-lens/.gitignore b/clients/client-connect-contact-lens/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-connect-contact-lens/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-connect-contact-lens/.npmignore b/clients/client-connect-contact-lens/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-connect-contact-lens/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-connect-contact-lens/ConnectContactLens.ts b/clients/client-connect-contact-lens/ConnectContactLens.ts new file mode 100644 index 000000000000..d9c85852eb4c --- /dev/null +++ b/clients/client-connect-contact-lens/ConnectContactLens.ts @@ -0,0 +1,50 @@ +import { ConnectContactLensClient } from "./ConnectContactLensClient"; +import { + ListRealtimeContactAnalysisSegmentsCommand, + ListRealtimeContactAnalysisSegmentsCommandInput, + ListRealtimeContactAnalysisSegmentsCommandOutput, +} from "./commands/ListRealtimeContactAnalysisSegmentsCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

Contact Lens for Amazon Connect enables you to analyze conversations between customer and agents, + * by using speech transcription, natural language processing, and intelligent search + * capabilities. It performs sentiment analysis, detects issues, and enables you to automatically + * categorize contacts.

+ *

Contact Lens for Amazon Connect provides both real-time and post-call analytics of customer-agent + * conversations. For more information, see Analyze conversations using + * Contact Lens in the Amazon Connect Administrator Guide.

+ */ +export class ConnectContactLens extends ConnectContactLensClient { + /** + *

Provides a list of analysis segments for a real-time analysis session.

+ */ + public listRealtimeContactAnalysisSegments( + args: ListRealtimeContactAnalysisSegmentsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listRealtimeContactAnalysisSegments( + args: ListRealtimeContactAnalysisSegmentsCommandInput, + cb: (err: any, data?: ListRealtimeContactAnalysisSegmentsCommandOutput) => void + ): void; + public listRealtimeContactAnalysisSegments( + args: ListRealtimeContactAnalysisSegmentsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListRealtimeContactAnalysisSegmentsCommandOutput) => void + ): void; + public listRealtimeContactAnalysisSegments( + args: ListRealtimeContactAnalysisSegmentsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListRealtimeContactAnalysisSegmentsCommandOutput) => void), + cb?: (err: any, data?: ListRealtimeContactAnalysisSegmentsCommandOutput) => void + ): Promise | void { + const command = new ListRealtimeContactAnalysisSegmentsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-connect-contact-lens/ConnectContactLensClient.ts b/clients/client-connect-contact-lens/ConnectContactLensClient.ts new file mode 100644 index 000000000000..0254a045bedd --- /dev/null +++ b/clients/client-connect-contact-lens/ConnectContactLensClient.ts @@ -0,0 +1,211 @@ +import { + ListRealtimeContactAnalysisSegmentsCommandInput, + ListRealtimeContactAnalysisSegmentsCommandOutput, +} from "./commands/ListRealtimeContactAnalysisSegmentsCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = ListRealtimeContactAnalysisSegmentsCommandInput; + +export type ServiceOutputTypes = ListRealtimeContactAnalysisSegmentsCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type ConnectContactLensClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type ConnectContactLensClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

Contact Lens for Amazon Connect enables you to analyze conversations between customer and agents, + * by using speech transcription, natural language processing, and intelligent search + * capabilities. It performs sentiment analysis, detects issues, and enables you to automatically + * categorize contacts.

+ *

Contact Lens for Amazon Connect provides both real-time and post-call analytics of customer-agent + * conversations. For more information, see Analyze conversations using + * Contact Lens in the Amazon Connect Administrator Guide.

+ */ +export class ConnectContactLensClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + ConnectContactLensClientResolvedConfig +> { + readonly config: ConnectContactLensClientResolvedConfig; + + constructor(configuration: ConnectContactLensClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-connect-contact-lens/LICENSE b/clients/client-connect-contact-lens/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-connect-contact-lens/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-connect-contact-lens/README.md b/clients/client-connect-contact-lens/README.md new file mode 100644 index 000000000000..71fc4101f654 --- /dev/null +++ b/clients/client-connect-contact-lens/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-connect-contact-lens + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-connect-contact-lens/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-connect-contact-lens) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-connect-contact-lens.svg)](https://www.npmjs.com/package/@aws-sdk/client-connect-contact-lens) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-connect-contact-lens/commands/ListRealtimeContactAnalysisSegmentsCommand.ts b/clients/client-connect-contact-lens/commands/ListRealtimeContactAnalysisSegmentsCommand.ts new file mode 100644 index 000000000000..83c5870bf494 --- /dev/null +++ b/clients/client-connect-contact-lens/commands/ListRealtimeContactAnalysisSegmentsCommand.ts @@ -0,0 +1,102 @@ +import { + ConnectContactLensClientResolvedConfig, + ServiceInputTypes, + ServiceOutputTypes, +} from "../ConnectContactLensClient"; +import { + ListRealtimeContactAnalysisSegmentsRequest, + ListRealtimeContactAnalysisSegmentsResponse, +} from "../models/models_0"; +import { + deserializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand, + serializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListRealtimeContactAnalysisSegmentsCommandInput = ListRealtimeContactAnalysisSegmentsRequest; +export type ListRealtimeContactAnalysisSegmentsCommandOutput = ListRealtimeContactAnalysisSegmentsResponse & + __MetadataBearer; + +/** + *

Provides a list of analysis segments for a real-time analysis session.

+ */ +export class ListRealtimeContactAnalysisSegmentsCommand extends $Command< + ListRealtimeContactAnalysisSegmentsCommandInput, + ListRealtimeContactAnalysisSegmentsCommandOutput, + ConnectContactLensClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListRealtimeContactAnalysisSegmentsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectContactLensClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectContactLensClient"; + const commandName = "ListRealtimeContactAnalysisSegmentsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListRealtimeContactAnalysisSegmentsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListRealtimeContactAnalysisSegmentsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: ListRealtimeContactAnalysisSegmentsCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect-contact-lens/endpoints.ts b/clients/client-connect-contact-lens/endpoints.ts new file mode 100644 index 000000000000..5c3a02886cb0 --- /dev/null +++ b/clients/client-connect-contact-lens/endpoints.ts @@ -0,0 +1,111 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "connect.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "connect.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "connect.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "connect.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "connect.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + case "ap-northeast-1": + regionInfo = { + hostname: "connect.ap-northeast-1.amazonaws.com", + partition: "aws", + }; + break; + case "ap-southeast-2": + regionInfo = { + hostname: "connect.ap-southeast-2.amazonaws.com", + partition: "aws", + }; + break; + case "eu-central-1": + regionInfo = { + hostname: "connect.eu-central-1.amazonaws.com", + partition: "aws", + }; + break; + case "us-east-1": + regionInfo = { + hostname: "connect.us-east-1.amazonaws.com", + partition: "aws", + }; + break; + case "us-west-2": + regionInfo = { + hostname: "connect.us-west-2.amazonaws.com", + partition: "aws", + }; + break; + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-connect-contact-lens/index.ts b/clients/client-connect-contact-lens/index.ts new file mode 100644 index 000000000000..afb1f98c053b --- /dev/null +++ b/clients/client-connect-contact-lens/index.ts @@ -0,0 +1,6 @@ +export * from "./ConnectContactLensClient"; +export * from "./ConnectContactLens"; +export * from "./commands/ListRealtimeContactAnalysisSegmentsCommand"; +export * from "./pagination/ListRealtimeContactAnalysisSegmentsPaginator"; +export * from "./pagination/Interfaces"; +export * from "./models/index"; diff --git a/clients/client-connect-contact-lens/models/index.ts b/clients/client-connect-contact-lens/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-connect-contact-lens/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-connect-contact-lens/models/models_0.ts b/clients/client-connect-contact-lens/models/models_0.ts new file mode 100644 index 000000000000..04e3961e5ac6 --- /dev/null +++ b/clients/client-connect-contact-lens/models/models_0.ts @@ -0,0 +1,310 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +/** + *

You do not have sufficient access to perform this action.

+ */ +export interface AccessDeniedException extends __SmithyException, $MetadataBearer { + name: "AccessDeniedException"; + $fault: "client"; + Message: string | undefined; +} + +export namespace AccessDeniedException { + export const filterSensitiveLog = (obj: AccessDeniedException): any => ({ + ...obj, + }); +} + +/** + *

Request processing failed due to an error or failure with the service.

+ */ +export interface InternalServiceException extends __SmithyException, $MetadataBearer { + name: "InternalServiceException"; + $fault: "server"; + Message?: string; +} + +export namespace InternalServiceException { + export const filterSensitiveLog = (obj: InternalServiceException): any => ({ + ...obj, + }); +} + +/** + *

The request is not valid.

+ */ +export interface InvalidRequestException extends __SmithyException, $MetadataBearer { + name: "InvalidRequestException"; + $fault: "client"; + Message?: string; +} + +export namespace InvalidRequestException { + export const filterSensitiveLog = (obj: InvalidRequestException): any => ({ + ...obj, + }); +} + +export interface ListRealtimeContactAnalysisSegmentsRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier of the contact.

+ */ + ContactId: string | undefined; + + /** + *

The maximimum number of results to return per page.

+ */ + MaxResults?: number; + + /** + *

The token for the next set of results. Use the value returned in the previous + * response in the next request to retrieve the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListRealtimeContactAnalysisSegmentsRequest { + export const filterSensitiveLog = (obj: ListRealtimeContactAnalysisSegmentsRequest): any => ({ + ...obj, + }); +} + +/** + *

The section of the contact audio where that category rule was detected.

+ */ +export interface PointOfInterest { + /** + *

The beginning offset in milliseconds where the category rule was detected.

+ */ + BeginOffsetMillis: number | undefined; + + /** + *

The ending offset in milliseconds where the category rule was detected.

+ */ + EndOffsetMillis: number | undefined; +} + +export namespace PointOfInterest { + export const filterSensitiveLog = (obj: PointOfInterest): any => ({ + ...obj, + }); +} + +/** + *

Provides information about the category rule that was matched.

+ */ +export interface CategoryDetails { + /** + *

The section of audio where the category rule was detected.

+ */ + PointsOfInterest: PointOfInterest[] | undefined; +} + +export namespace CategoryDetails { + export const filterSensitiveLog = (obj: CategoryDetails): any => ({ + ...obj, + }); +} + +/** + *

Provides the category rules that are used to automatically categorize contacts based on + * uttered keywords and phrases.

+ */ +export interface Categories { + /** + *

The category rules that have been matched in the analyzed segment.

+ */ + MatchedCategories: string[] | undefined; + + /** + *

The category rule that was matched and when it occurred in the transcript.

+ */ + MatchedDetails: { [key: string]: CategoryDetails } | undefined; +} + +export namespace Categories { + export const filterSensitiveLog = (obj: Categories): any => ({ + ...obj, + }); +} + +/** + *

For characters that were detected as issues, where they occur in the transcript.

+ */ +export interface CharacterOffsets { + /** + *

The beginning of the issue.

+ */ + BeginOffsetChar: number | undefined; + + /** + *

The end of the issue.

+ */ + EndOffsetChar: number | undefined; +} + +export namespace CharacterOffsets { + export const filterSensitiveLog = (obj: CharacterOffsets): any => ({ + ...obj, + }); +} + +/** + *

Potential issues that are detected based on an artificial intelligence analysis of each + * turn in the conversation.

+ */ +export interface IssueDetected { + /** + *

The offset for when the issue was detected in the segment.

+ */ + CharacterOffsets: CharacterOffsets | undefined; +} + +export namespace IssueDetected { + export const filterSensitiveLog = (obj: IssueDetected): any => ({ + ...obj, + }); +} + +export enum SentimentValue { + NEGATIVE = "NEGATIVE", + NEUTRAL = "NEUTRAL", + POSITIVE = "POSITIVE", +} + +/** + *

A list of messages in the session.

+ */ +export interface Transcript { + /** + *

The identifier of the transcript.

+ */ + Id: string | undefined; + + /** + *

The identifier of the participant.

+ */ + ParticipantId: string | undefined; + + /** + *

The role of participant. For example, is it a customer, agent, or system.

+ */ + ParticipantRole: string | undefined; + + /** + *

The content of the transcript.

+ */ + Content: string | undefined; + + /** + *

The beginning offset in the contact for this transcript.

+ */ + BeginOffsetMillis: number | undefined; + + /** + *

The end offset in the contact for this transcript.

+ */ + EndOffsetMillis: number | undefined; + + /** + *

The sentiment of the detected for this piece of transcript.

+ */ + Sentiment: SentimentValue | string | undefined; + + /** + *

List of positions where issues were detected on the transcript.

+ */ + IssuesDetected?: IssueDetected[]; +} + +export namespace Transcript { + export const filterSensitiveLog = (obj: Transcript): any => ({ + ...obj, + }); +} + +/** + *

An analyzed segment for a real-time analysis session.

+ */ +export interface RealtimeContactAnalysisSegment { + /** + *

The analyzed transcript.

+ */ + Transcript?: Transcript; + + /** + *

The matched category rules.

+ */ + Categories?: Categories; +} + +export namespace RealtimeContactAnalysisSegment { + export const filterSensitiveLog = (obj: RealtimeContactAnalysisSegment): any => ({ + ...obj, + }); +} + +export interface ListRealtimeContactAnalysisSegmentsResponse { + /** + *

An analyzed transcript or category.

+ */ + Segments: RealtimeContactAnalysisSegment[] | undefined; + + /** + *

If there are additional results, this is the token for the next set of results. If response includes nextToken there are two possible scenarios:

+ *
    + *
  • + *

    There are more segments so another call is required to get them.

    + *
  • + *
  • + *

    There are no more segments at this time, but more may be available later (real-time + * analysis is in progress) so the client should call the operation again to get new + * segments.

    + *
  • + *
+ *

If response does not include nextToken, the analysis is completed (successfully or failed) and there are no more segments to retrieve.

+ */ + NextToken?: string; +} + +export namespace ListRealtimeContactAnalysisSegmentsResponse { + export const filterSensitiveLog = (obj: ListRealtimeContactAnalysisSegmentsResponse): any => ({ + ...obj, + }); +} + +/** + *

The specified resource was not found.

+ */ +export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { + name: "ResourceNotFoundException"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceNotFoundException { + export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

The throttling limit has been exceeded.

+ */ +export interface ThrottlingException extends __SmithyException, $MetadataBearer { + name: "ThrottlingException"; + $fault: "client"; + Message: string | undefined; +} + +export namespace ThrottlingException { + export const filterSensitiveLog = (obj: ThrottlingException): any => ({ + ...obj, + }); +} diff --git a/clients/client-connect-contact-lens/package.json b/clients/client-connect-contact-lens/package.json new file mode 100644 index 000000000000..61d4249eb2b8 --- /dev/null +++ b/clients/client-connect-contact-lens/package.json @@ -0,0 +1,83 @@ +{ + "name": "@aws-sdk/client-connect-contact-lens", + "description": "AWS SDK for JavaScript Connect Contact Lens Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-connect-contact-lens", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-connect-contact-lens" + } +} diff --git a/clients/client-connect-contact-lens/pagination/Interfaces.ts b/clients/client-connect-contact-lens/pagination/Interfaces.ts new file mode 100644 index 000000000000..d300a961c6aa --- /dev/null +++ b/clients/client-connect-contact-lens/pagination/Interfaces.ts @@ -0,0 +1,7 @@ +import { ConnectContactLens } from "../ConnectContactLens"; +import { ConnectContactLensClient } from "../ConnectContactLensClient"; +import { PaginationConfiguration } from "@aws-sdk/types"; + +export interface ConnectContactLensPaginationConfiguration extends PaginationConfiguration { + client: ConnectContactLens | ConnectContactLensClient; +} diff --git a/clients/client-connect-contact-lens/pagination/ListRealtimeContactAnalysisSegmentsPaginator.ts b/clients/client-connect-contact-lens/pagination/ListRealtimeContactAnalysisSegmentsPaginator.ts new file mode 100644 index 000000000000..5bc4b718f83b --- /dev/null +++ b/clients/client-connect-contact-lens/pagination/ListRealtimeContactAnalysisSegmentsPaginator.ts @@ -0,0 +1,57 @@ +import { ConnectContactLens } from "../ConnectContactLens"; +import { ConnectContactLensClient } from "../ConnectContactLensClient"; +import { + ListRealtimeContactAnalysisSegmentsCommand, + ListRealtimeContactAnalysisSegmentsCommandInput, + ListRealtimeContactAnalysisSegmentsCommandOutput, +} from "../commands/ListRealtimeContactAnalysisSegmentsCommand"; +import { ConnectContactLensPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ConnectContactLensClient, + input: ListRealtimeContactAnalysisSegmentsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListRealtimeContactAnalysisSegmentsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: ConnectContactLens, + input: ListRealtimeContactAnalysisSegmentsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listRealtimeContactAnalysisSegments(input, ...args); +}; +export async function* paginateListRealtimeContactAnalysisSegments( + config: ConnectContactLensPaginationConfiguration, + input: ListRealtimeContactAnalysisSegmentsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListRealtimeContactAnalysisSegmentsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof ConnectContactLens) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ConnectContactLensClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected ConnectContactLens | ConnectContactLensClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-connect-contact-lens/protocols/Aws_restJson1.ts b/clients/client-connect-contact-lens/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..4218c5f1a95b --- /dev/null +++ b/clients/client-connect-contact-lens/protocols/Aws_restJson1.ts @@ -0,0 +1,415 @@ +import { + ListRealtimeContactAnalysisSegmentsCommandInput, + ListRealtimeContactAnalysisSegmentsCommandOutput, +} from "../commands/ListRealtimeContactAnalysisSegmentsCommand"; +import { + AccessDeniedException, + Categories, + CategoryDetails, + CharacterOffsets, + InternalServiceException, + InvalidRequestException, + IssueDetected, + PointOfInterest, + RealtimeContactAnalysisSegment, + ResourceNotFoundException, + ThrottlingException, + Transcript, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export const serializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand = async ( + input: ListRealtimeContactAnalysisSegmentsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/realtime-contact-analysis/analysis-segments"; + let body: any; + body = JSON.stringify({ + ...(input.ContactId !== undefined && { ContactId: input.ContactId }), + ...(input.InstanceId !== undefined && { InstanceId: input.InstanceId }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommandError(output, context); + } + const contents: ListRealtimeContactAnalysisSegmentsCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + Segments: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.Segments !== undefined && data.Segments !== null) { + contents.Segments = deserializeAws_restJson1RealtimeContactAnalysisSegments(data.Segments, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListRealtimeContactAnalysisSegmentsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.connectcontactlens#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceException": + case "com.amazonaws.connectcontactlens#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connectcontactlens#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connectcontactlens#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connectcontactlens#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1AccessDeniedExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: AccessDeniedException = { + name: "AccessDeniedException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1InternalServiceExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InternalServiceException = { + name: "InternalServiceException", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1InvalidRequestExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InvalidRequestException = { + name: "InvalidRequestException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceNotFoundException = { + name: "ResourceNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ThrottlingExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ThrottlingException = { + name: "ThrottlingException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1Categories = (output: any, context: __SerdeContext): Categories => { + return { + MatchedCategories: + output.MatchedCategories !== undefined && output.MatchedCategories !== null + ? deserializeAws_restJson1MatchedCategories(output.MatchedCategories, context) + : undefined, + MatchedDetails: + output.MatchedDetails !== undefined && output.MatchedDetails !== null + ? deserializeAws_restJson1MatchedDetails(output.MatchedDetails, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CategoryDetails = (output: any, context: __SerdeContext): CategoryDetails => { + return { + PointsOfInterest: + output.PointsOfInterest !== undefined && output.PointsOfInterest !== null + ? deserializeAws_restJson1PointsOfInterest(output.PointsOfInterest, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CharacterOffsets = (output: any, context: __SerdeContext): CharacterOffsets => { + return { + BeginOffsetChar: + output.BeginOffsetChar !== undefined && output.BeginOffsetChar !== null ? output.BeginOffsetChar : undefined, + EndOffsetChar: + output.EndOffsetChar !== undefined && output.EndOffsetChar !== null ? output.EndOffsetChar : undefined, + } as any; +}; + +const deserializeAws_restJson1IssueDetected = (output: any, context: __SerdeContext): IssueDetected => { + return { + CharacterOffsets: + output.CharacterOffsets !== undefined && output.CharacterOffsets !== null + ? deserializeAws_restJson1CharacterOffsets(output.CharacterOffsets, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1IssuesDetected = (output: any, context: __SerdeContext): IssueDetected[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1IssueDetected(entry, context)); +}; + +const deserializeAws_restJson1MatchedCategories = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1MatchedDetails = ( + output: any, + context: __SerdeContext +): { [key: string]: CategoryDetails } => { + return Object.entries(output).reduce( + (acc: { [key: string]: CategoryDetails }, [key, value]: [string, any]) => ({ + ...acc, + [key]: deserializeAws_restJson1CategoryDetails(value, context), + }), + {} + ); +}; + +const deserializeAws_restJson1PointOfInterest = (output: any, context: __SerdeContext): PointOfInterest => { + return { + BeginOffsetMillis: + output.BeginOffsetMillis !== undefined && output.BeginOffsetMillis !== null + ? output.BeginOffsetMillis + : undefined, + EndOffsetMillis: + output.EndOffsetMillis !== undefined && output.EndOffsetMillis !== null ? output.EndOffsetMillis : undefined, + } as any; +}; + +const deserializeAws_restJson1PointsOfInterest = (output: any, context: __SerdeContext): PointOfInterest[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1PointOfInterest(entry, context)); +}; + +const deserializeAws_restJson1RealtimeContactAnalysisSegment = ( + output: any, + context: __SerdeContext +): RealtimeContactAnalysisSegment => { + return { + Categories: + output.Categories !== undefined && output.Categories !== null + ? deserializeAws_restJson1Categories(output.Categories, context) + : undefined, + Transcript: + output.Transcript !== undefined && output.Transcript !== null + ? deserializeAws_restJson1Transcript(output.Transcript, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1RealtimeContactAnalysisSegments = ( + output: any, + context: __SerdeContext +): RealtimeContactAnalysisSegment[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1RealtimeContactAnalysisSegment(entry, context)); +}; + +const deserializeAws_restJson1Transcript = (output: any, context: __SerdeContext): Transcript => { + return { + BeginOffsetMillis: + output.BeginOffsetMillis !== undefined && output.BeginOffsetMillis !== null + ? output.BeginOffsetMillis + : undefined, + Content: output.Content !== undefined && output.Content !== null ? output.Content : undefined, + EndOffsetMillis: + output.EndOffsetMillis !== undefined && output.EndOffsetMillis !== null ? output.EndOffsetMillis : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + IssuesDetected: + output.IssuesDetected !== undefined && output.IssuesDetected !== null + ? deserializeAws_restJson1IssuesDetected(output.IssuesDetected, context) + : undefined, + ParticipantId: + output.ParticipantId !== undefined && output.ParticipantId !== null ? output.ParticipantId : undefined, + ParticipantRole: + output.ParticipantRole !== undefined && output.ParticipantRole !== null ? output.ParticipantRole : undefined, + Sentiment: output.Sentiment !== undefined && output.Sentiment !== null ? output.Sentiment : undefined, + } as any; +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-connect-contact-lens/runtimeConfig.browser.ts b/clients/client-connect-contact-lens/runtimeConfig.browser.ts new file mode 100644 index 000000000000..55336fef5a8e --- /dev/null +++ b/clients/client-connect-contact-lens/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./ConnectContactLensClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-connect-contact-lens/runtimeConfig.native.ts b/clients/client-connect-contact-lens/runtimeConfig.native.ts new file mode 100644 index 000000000000..0bfb0e7b05cd --- /dev/null +++ b/clients/client-connect-contact-lens/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./ConnectContactLensClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-connect-contact-lens/runtimeConfig.shared.ts b/clients/client-connect-contact-lens/runtimeConfig.shared.ts new file mode 100644 index 000000000000..98bf3ed1c4a8 --- /dev/null +++ b/clients/client-connect-contact-lens/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-08-21", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "connect", +}; diff --git a/clients/client-connect-contact-lens/runtimeConfig.ts b/clients/client-connect-contact-lens/runtimeConfig.ts new file mode 100644 index 000000000000..7e47a19f4ce0 --- /dev/null +++ b/clients/client-connect-contact-lens/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./ConnectContactLensClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-connect-contact-lens/tsconfig.es.json b/clients/client-connect-contact-lens/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-connect-contact-lens/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-connect-contact-lens/tsconfig.json b/clients/client-connect-contact-lens/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-connect-contact-lens/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-connect/Connect.ts b/clients/client-connect/Connect.ts index ec99b7eff4d5..d75b3bb25024 100644 --- a/clients/client-connect/Connect.ts +++ b/clients/client-connect/Connect.ts @@ -39,11 +39,21 @@ import { CreateInstanceCommandInput, CreateInstanceCommandOutput, } from "./commands/CreateInstanceCommand"; +import { + CreateIntegrationAssociationCommand, + CreateIntegrationAssociationCommandInput, + CreateIntegrationAssociationCommandOutput, +} from "./commands/CreateIntegrationAssociationCommand"; import { CreateRoutingProfileCommand, CreateRoutingProfileCommandInput, CreateRoutingProfileCommandOutput, } from "./commands/CreateRoutingProfileCommand"; +import { + CreateUseCaseCommand, + CreateUseCaseCommandInput, + CreateUseCaseCommandOutput, +} from "./commands/CreateUseCaseCommand"; import { CreateUserCommand, CreateUserCommandInput, CreateUserCommandOutput } from "./commands/CreateUserCommand"; import { CreateUserHierarchyGroupCommand, @@ -55,6 +65,16 @@ import { DeleteInstanceCommandInput, DeleteInstanceCommandOutput, } from "./commands/DeleteInstanceCommand"; +import { + DeleteIntegrationAssociationCommand, + DeleteIntegrationAssociationCommandInput, + DeleteIntegrationAssociationCommandOutput, +} from "./commands/DeleteIntegrationAssociationCommand"; +import { + DeleteUseCaseCommand, + DeleteUseCaseCommandInput, + DeleteUseCaseCommandOutput, +} from "./commands/DeleteUseCaseCommand"; import { DeleteUserCommand, DeleteUserCommandInput, DeleteUserCommandOutput } from "./commands/DeleteUserCommand"; import { DeleteUserHierarchyGroupCommand, @@ -181,6 +201,11 @@ import { ListInstancesCommandInput, ListInstancesCommandOutput, } from "./commands/ListInstancesCommand"; +import { + ListIntegrationAssociationsCommand, + ListIntegrationAssociationsCommandInput, + ListIntegrationAssociationsCommandOutput, +} from "./commands/ListIntegrationAssociationsCommand"; import { ListLambdaFunctionsCommand, ListLambdaFunctionsCommandInput, @@ -219,6 +244,11 @@ import { ListTagsForResourceCommandInput, ListTagsForResourceCommandOutput, } from "./commands/ListTagsForResourceCommand"; +import { + ListUseCasesCommand, + ListUseCasesCommandInput, + ListUseCasesCommandOutput, +} from "./commands/ListUseCasesCommand"; import { ListUserHierarchyGroupsCommand, ListUserHierarchyGroupsCommandInput, @@ -245,6 +275,11 @@ import { StartOutboundVoiceContactCommandInput, StartOutboundVoiceContactCommandOutput, } from "./commands/StartOutboundVoiceContactCommand"; +import { + StartTaskContactCommand, + StartTaskContactCommandInput, + StartTaskContactCommandOutput, +} from "./commands/StartTaskContactCommand"; import { StopContactCommand, StopContactCommandInput, StopContactCommandOutput } from "./commands/StopContactCommand"; import { StopContactRecordingCommand, @@ -357,8 +392,7 @@ import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; * endpoints, see Amazon Connect * Endpoints.

* - *

Working with contact flows? Check out the Amazon Connect - * Flow language.

+ *

Working with contact flows? Check out the Amazon Connect Flow language.

*
*/ export class Connect extends ConnectClient { @@ -396,12 +430,11 @@ export class Connect extends ConnectClient { /** *

Associates a storage resource type for the first time. You can only associate one type of - * storage configuration in a single call. This means, for example, that you can't define an - * instance with multiple S3 buckets for storing chat transcripts.

- * + * storage configuration in a single call. This means, for example, that you can't define an + * instance with multiple S3 buckets for storing chat transcripts.

*

This API does not create a resource that doesn't exist. It only associates it to the - * instance. Ensure that the resource being specified in the storage configuration, like an Amazon - * S3 bucket, exists when being used for association.

+ * instance. Ensure that the resource being specified in the storage configuration, like an Amazon + * S3 bucket, exists when being used for association.

*/ public associateInstanceStorageConfig( args: AssociateInstanceStorageConfigCommandInput, @@ -595,7 +628,8 @@ export class Connect extends ConnectClient { } /** - *

Initiates an Amazon Connect instance with all the supported channels enabled. It does not attach any + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Initiates an Amazon Connect instance with all the supported channels enabled. It does not attach any * storage (such as Amazon S3, or Kinesis) or allow for any configurations on features such as * Contact Lens for Amazon Connect.

*/ @@ -628,6 +662,39 @@ export class Connect extends ConnectClient { } } + /** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Create an AppIntegration association with anAmazon Connect instance.

+ */ + public createIntegrationAssociation( + args: CreateIntegrationAssociationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createIntegrationAssociation( + args: CreateIntegrationAssociationCommandInput, + cb: (err: any, data?: CreateIntegrationAssociationCommandOutput) => void + ): void; + public createIntegrationAssociation( + args: CreateIntegrationAssociationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateIntegrationAssociationCommandOutput) => void + ): void; + public createIntegrationAssociation( + args: CreateIntegrationAssociationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateIntegrationAssociationCommandOutput) => void), + cb?: (err: any, data?: CreateIntegrationAssociationCommandOutput) => void + ): Promise | void { + const command = new CreateIntegrationAssociationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Creates a new routing profile.

*/ @@ -660,6 +727,39 @@ export class Connect extends ConnectClient { } } + /** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Creates a use case for an AppIntegration association.

+ */ + public createUseCase( + args: CreateUseCaseCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createUseCase( + args: CreateUseCaseCommandInput, + cb: (err: any, data?: CreateUseCaseCommandOutput) => void + ): void; + public createUseCase( + args: CreateUseCaseCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateUseCaseCommandOutput) => void + ): void; + public createUseCase( + args: CreateUseCaseCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateUseCaseCommandOutput) => void), + cb?: (err: any, data?: CreateUseCaseCommandOutput) => void + ): Promise | void { + const command = new CreateUseCaseCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Creates a user account for the specified Amazon Connect instance.

*

For information about how to create user accounts using the Amazon Connect console, see Add Users in @@ -721,7 +821,8 @@ export class Connect extends ConnectClient { } /** - *

Deletes the Amazon Connect instance.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes the Amazon Connect instance.

*/ public deleteInstance( args: DeleteInstanceCommandInput, @@ -752,12 +853,78 @@ export class Connect extends ConnectClient { } } + /** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes an AppIntegration association from an Amazon Connect instance. The association must not have + * any use cases associated with it.

+ */ + public deleteIntegrationAssociation( + args: DeleteIntegrationAssociationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteIntegrationAssociation( + args: DeleteIntegrationAssociationCommandInput, + cb: (err: any, data?: DeleteIntegrationAssociationCommandOutput) => void + ): void; + public deleteIntegrationAssociation( + args: DeleteIntegrationAssociationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteIntegrationAssociationCommandOutput) => void + ): void; + public deleteIntegrationAssociation( + args: DeleteIntegrationAssociationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteIntegrationAssociationCommandOutput) => void), + cb?: (err: any, data?: DeleteIntegrationAssociationCommandOutput) => void + ): Promise | void { + const command = new DeleteIntegrationAssociationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes a use case from an AppIntegration association.

+ */ + public deleteUseCase( + args: DeleteUseCaseCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteUseCase( + args: DeleteUseCaseCommandInput, + cb: (err: any, data?: DeleteUseCaseCommandOutput) => void + ): void; + public deleteUseCase( + args: DeleteUseCaseCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteUseCaseCommandOutput) => void + ): void; + public deleteUseCase( + args: DeleteUseCaseCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteUseCaseCommandOutput) => void), + cb?: (err: any, data?: DeleteUseCaseCommandOutput) => void + ): Promise | void { + const command = new DeleteUseCaseCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Deletes a user account from the specified Amazon Connect instance.

*

For information about what happens to a user's data when their account is deleted, see * Delete Users from - * Your Amazon Connect Instance in the Amazon Connect Administrator - * Guide.

+ * Your Amazon Connect Instance in the Amazon Connect Administrator Guide.

*/ public deleteUser(args: DeleteUserCommandInput, options?: __HttpHandlerOptions): Promise; public deleteUser(args: DeleteUserCommandInput, cb: (err: any, data?: DeleteUserCommandOutput) => void): void; @@ -783,7 +950,8 @@ export class Connect extends ConnectClient { } /** - *

Deletes an existing user hierarchy group. It must not be associated with any agents or have any active child groups.

+ *

Deletes an existing user hierarchy group. It must not be associated with any agents or have + * any active child groups.

*/ public deleteUserHierarchyGroup( args: DeleteUserHierarchyGroupCommandInput, @@ -849,12 +1017,11 @@ export class Connect extends ConnectClient { } /** - *

Returns the current state of the specified instance identifier. It tracks the instance while it is - * being created and returns an error status if applicable.

- *

If an instance is not created - * successfully, the instance status reason field returns details relevant to the reason. The instance - * in a failed state is returned only for 24 hours after - * the CreateInstance API was invoked.

+ *

Returns the current state of the specified instance identifier. It tracks the instance while + * it is being created and returns an error status if applicable.

+ *

If an instance is not created successfully, the instance status reason field returns details + * relevant to the reason. The instance in a failed state is returned only for 24 hours after the + * CreateInstance API was invoked.

*/ public describeInstance( args: DescribeInstanceCommandInput, @@ -918,7 +1085,8 @@ export class Connect extends ConnectClient { } /** - *

Retrieves the current storage configurations for the specified resource type, association ID, and instance ID.

+ *

Retrieves the current storage configurations for the specified resource type, association + * ID, and instance ID.

*/ public describeInstanceStorageConfig( args: DescribeInstanceStorageConfigCommandInput, @@ -1109,7 +1277,8 @@ export class Connect extends ConnectClient { } /** - *

Removes the storage type configurations for the specified resource type and association ID.

+ *

Removes the storage type configurations for the specified resource type and association + * ID.

*/ public disassociateInstanceStorageConfig( args: DisassociateInstanceStorageConfigCommandInput, @@ -1504,7 +1673,8 @@ export class Connect extends ConnectClient { } /** - *

Returns a paginated list of all attribute types for the given instance.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Returns a paginated list of all attribute types for the given instance.

*/ public listInstanceAttributes( args: ListInstanceAttributesCommandInput, @@ -1536,7 +1706,8 @@ export class Connect extends ConnectClient { } /** - *

Return a list of instances which are in active state, creation-in-progress state, and failed + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Return a list of instances which are in active state, creation-in-progress state, and failed * state. Instances that aren't successfully created (they are in a failed state) are returned only * for 24 hours after the CreateInstance API was invoked.

*/ @@ -1570,7 +1741,9 @@ export class Connect extends ConnectClient { } /** - *

Returns a paginated list of storage configs for the identified instance and resource + *

This API is in preview release for Amazon Connect and is subject to change.

+ * + *

Returns a paginated list of storage configs for the identified instance and resource * type.

*/ public listInstanceStorageConfigs( @@ -1603,7 +1776,42 @@ export class Connect extends ConnectClient { } /** - *

Returns a paginated list of all the Lambda functions that show up in the drop-down options in the relevant contact flow blocks.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Provides summary information about the AppIntegration associations for the specified Amazon Connect + * instance.

+ */ + public listIntegrationAssociations( + args: ListIntegrationAssociationsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listIntegrationAssociations( + args: ListIntegrationAssociationsCommandInput, + cb: (err: any, data?: ListIntegrationAssociationsCommandOutput) => void + ): void; + public listIntegrationAssociations( + args: ListIntegrationAssociationsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListIntegrationAssociationsCommandOutput) => void + ): void; + public listIntegrationAssociations( + args: ListIntegrationAssociationsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListIntegrationAssociationsCommandOutput) => void), + cb?: (err: any, data?: ListIntegrationAssociationsCommandOutput) => void + ): Promise | void { + const command = new ListIntegrationAssociationsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Returns a paginated list of all the Lambda functions that show up in the drop-down options + * in the relevant contact flow blocks.

*/ public listLambdaFunctions( args: ListLambdaFunctionsCommandInput, @@ -1635,7 +1843,8 @@ export class Connect extends ConnectClient { } /** - *

Returns a paginated list of all the Amazon Lex bots currently associated with the instance.

+ *

Returns a paginated list of all the Amazon Lex bots currently associated with the + * instance.

*/ public listLexBots(args: ListLexBotsCommandInput, options?: __HttpHandlerOptions): Promise; public listLexBots(args: ListLexBotsCommandInput, cb: (err: any, data?: ListLexBotsCommandOutput) => void): void; @@ -1695,8 +1904,7 @@ export class Connect extends ConnectClient { } /** - *

Provides information about the prompts for the specified Amazon Connect - * instance.

+ *

Provides information about the prompts for the specified Amazon Connect instance.

*/ public listPrompts(args: ListPromptsCommandInput, options?: __HttpHandlerOptions): Promise; public listPrompts(args: ListPromptsCommandInput, cb: (err: any, data?: ListPromptsCommandOutput) => void): void; @@ -1917,6 +2125,36 @@ export class Connect extends ConnectClient { } } + /** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

List the use cases.

+ */ + public listUseCases( + args: ListUseCasesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listUseCases(args: ListUseCasesCommandInput, cb: (err: any, data?: ListUseCasesCommandOutput) => void): void; + public listUseCases( + args: ListUseCasesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListUseCasesCommandOutput) => void + ): void; + public listUseCases( + args: ListUseCasesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListUseCasesCommandOutput) => void), + cb?: (err: any, data?: ListUseCasesCommandOutput) => void + ): Promise | void { + const command = new ListUseCasesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Provides summary information about the hierarchy groups for the specified Amazon Connect * instance.

@@ -2073,7 +2311,7 @@ export class Connect extends ConnectClient { * started and you want to suspend and resume it, such as when collecting sensitive information (for * example, a credit card number), use SuspendContactRecording and ResumeContactRecording.

*

You can use this API to override the recording behavior configured in the Set recording - * behavior block.

+ * behavior block.

*

Only voice recordings are supported at this time.

*/ public startContactRecording( @@ -2118,7 +2356,7 @@ export class Connect extends ConnectClient { * *

UK numbers with a 447 prefix are not allowed by default. Before you can dial these UK * mobile numbers, you must submit a service quota increase request. For more information, see - * Amazon Connect Service Quotas in the Amazon Connect Administrator Guide.

+ * Amazon Connect Service Quotas in the Amazon Connect Administrator Guide.

*
*/ public startOutboundVoiceContact( @@ -2150,6 +2388,38 @@ export class Connect extends ConnectClient { } } + /** + *

Initiates a contact flow to start a new task.

+ */ + public startTaskContact( + args: StartTaskContactCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public startTaskContact( + args: StartTaskContactCommandInput, + cb: (err: any, data?: StartTaskContactCommandOutput) => void + ): void; + public startTaskContact( + args: StartTaskContactCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StartTaskContactCommandOutput) => void + ): void; + public startTaskContact( + args: StartTaskContactCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StartTaskContactCommandOutput) => void), + cb?: (err: any, data?: StartTaskContactCommandOutput) => void + ): Promise | void { + const command = new StartTaskContactCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Ends the specified contact.

*/ @@ -2428,7 +2698,8 @@ export class Connect extends ConnectClient { } /** - *

Updates the value for the specified attribute type.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Updates the value for the specified attribute type.

*/ public updateInstanceAttribute( args: UpdateInstanceAttributeCommandInput, @@ -2460,7 +2731,8 @@ export class Connect extends ConnectClient { } /** - *

Updates an existing configuration for a resource type. This API is idempotent.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Updates an existing configuration for a resource type. This API is idempotent.

*/ public updateInstanceStorageConfig( args: UpdateInstanceStorageConfigCommandInput, @@ -2492,7 +2764,8 @@ export class Connect extends ConnectClient { } /** - *

Updates the channels that agents can handle in the Contact Control Panel (CCP) for a routing profile.

+ *

Updates the channels that agents can handle in the Contact Control Panel (CCP) for a routing + * profile.

*/ public updateRoutingProfileConcurrency( args: UpdateRoutingProfileConcurrencyCommandInput, @@ -2558,7 +2831,9 @@ export class Connect extends ConnectClient { } /** - *

Updates the name and description of a routing profile. The request accepts the following data in JSON format. At least Name or Description must be provided.

+ *

Updates the name and description of a routing profile. The request accepts the following + * data in JSON format. At least Name or Description must be + * provided.

*/ public updateRoutingProfileName( args: UpdateRoutingProfileNameCommandInput, diff --git a/clients/client-connect/ConnectClient.ts b/clients/client-connect/ConnectClient.ts index c8341380f5bf..5c8ea77da4eb 100644 --- a/clients/client-connect/ConnectClient.ts +++ b/clients/client-connect/ConnectClient.ts @@ -21,16 +21,26 @@ import { } from "./commands/AssociateSecurityKeyCommand"; import { CreateContactFlowCommandInput, CreateContactFlowCommandOutput } from "./commands/CreateContactFlowCommand"; import { CreateInstanceCommandInput, CreateInstanceCommandOutput } from "./commands/CreateInstanceCommand"; +import { + CreateIntegrationAssociationCommandInput, + CreateIntegrationAssociationCommandOutput, +} from "./commands/CreateIntegrationAssociationCommand"; import { CreateRoutingProfileCommandInput, CreateRoutingProfileCommandOutput, } from "./commands/CreateRoutingProfileCommand"; +import { CreateUseCaseCommandInput, CreateUseCaseCommandOutput } from "./commands/CreateUseCaseCommand"; import { CreateUserCommandInput, CreateUserCommandOutput } from "./commands/CreateUserCommand"; import { CreateUserHierarchyGroupCommandInput, CreateUserHierarchyGroupCommandOutput, } from "./commands/CreateUserHierarchyGroupCommand"; import { DeleteInstanceCommandInput, DeleteInstanceCommandOutput } from "./commands/DeleteInstanceCommand"; +import { + DeleteIntegrationAssociationCommandInput, + DeleteIntegrationAssociationCommandOutput, +} from "./commands/DeleteIntegrationAssociationCommand"; +import { DeleteUseCaseCommandInput, DeleteUseCaseCommandOutput } from "./commands/DeleteUseCaseCommand"; import { DeleteUserCommandInput, DeleteUserCommandOutput } from "./commands/DeleteUserCommand"; import { DeleteUserHierarchyGroupCommandInput, @@ -111,6 +121,10 @@ import { ListInstanceStorageConfigsCommandOutput, } from "./commands/ListInstanceStorageConfigsCommand"; import { ListInstancesCommandInput, ListInstancesCommandOutput } from "./commands/ListInstancesCommand"; +import { + ListIntegrationAssociationsCommandInput, + ListIntegrationAssociationsCommandOutput, +} from "./commands/ListIntegrationAssociationsCommand"; import { ListLambdaFunctionsCommandInput, ListLambdaFunctionsCommandOutput, @@ -136,6 +150,7 @@ import { ListTagsForResourceCommandInput, ListTagsForResourceCommandOutput, } from "./commands/ListTagsForResourceCommand"; +import { ListUseCasesCommandInput, ListUseCasesCommandOutput } from "./commands/ListUseCasesCommand"; import { ListUserHierarchyGroupsCommandInput, ListUserHierarchyGroupsCommandOutput, @@ -154,6 +169,7 @@ import { StartOutboundVoiceContactCommandInput, StartOutboundVoiceContactCommandOutput, } from "./commands/StartOutboundVoiceContactCommand"; +import { StartTaskContactCommandInput, StartTaskContactCommandOutput } from "./commands/StartTaskContactCommand"; import { StopContactCommandInput, StopContactCommandOutput } from "./commands/StopContactCommand"; import { StopContactRecordingCommandInput, @@ -287,10 +303,14 @@ export type ServiceInputTypes = | AssociateSecurityKeyCommandInput | CreateContactFlowCommandInput | CreateInstanceCommandInput + | CreateIntegrationAssociationCommandInput | CreateRoutingProfileCommandInput + | CreateUseCaseCommandInput | CreateUserCommandInput | CreateUserHierarchyGroupCommandInput | DeleteInstanceCommandInput + | DeleteIntegrationAssociationCommandInput + | DeleteUseCaseCommandInput | DeleteUserCommandInput | DeleteUserHierarchyGroupCommandInput | DescribeContactFlowCommandInput @@ -317,6 +337,7 @@ export type ServiceInputTypes = | ListInstanceAttributesCommandInput | ListInstanceStorageConfigsCommandInput | ListInstancesCommandInput + | ListIntegrationAssociationsCommandInput | ListLambdaFunctionsCommandInput | ListLexBotsCommandInput | ListPhoneNumbersCommandInput @@ -327,12 +348,14 @@ export type ServiceInputTypes = | ListSecurityKeysCommandInput | ListSecurityProfilesCommandInput | ListTagsForResourceCommandInput + | ListUseCasesCommandInput | ListUserHierarchyGroupsCommandInput | ListUsersCommandInput | ResumeContactRecordingCommandInput | StartChatContactCommandInput | StartContactRecordingCommandInput | StartOutboundVoiceContactCommandInput + | StartTaskContactCommandInput | StopContactCommandInput | StopContactRecordingCommandInput | SuspendContactRecordingCommandInput @@ -364,10 +387,14 @@ export type ServiceOutputTypes = | AssociateSecurityKeyCommandOutput | CreateContactFlowCommandOutput | CreateInstanceCommandOutput + | CreateIntegrationAssociationCommandOutput | CreateRoutingProfileCommandOutput + | CreateUseCaseCommandOutput | CreateUserCommandOutput | CreateUserHierarchyGroupCommandOutput | DeleteInstanceCommandOutput + | DeleteIntegrationAssociationCommandOutput + | DeleteUseCaseCommandOutput | DeleteUserCommandOutput | DeleteUserHierarchyGroupCommandOutput | DescribeContactFlowCommandOutput @@ -394,6 +421,7 @@ export type ServiceOutputTypes = | ListInstanceAttributesCommandOutput | ListInstanceStorageConfigsCommandOutput | ListInstancesCommandOutput + | ListIntegrationAssociationsCommandOutput | ListLambdaFunctionsCommandOutput | ListLexBotsCommandOutput | ListPhoneNumbersCommandOutput @@ -404,12 +432,14 @@ export type ServiceOutputTypes = | ListSecurityKeysCommandOutput | ListSecurityProfilesCommandOutput | ListTagsForResourceCommandOutput + | ListUseCasesCommandOutput | ListUserHierarchyGroupsCommandOutput | ListUsersCommandOutput | ResumeContactRecordingCommandOutput | StartChatContactCommandOutput | StartContactRecordingCommandOutput | StartOutboundVoiceContactCommandOutput + | StartTaskContactCommandOutput | StopContactCommandOutput | StopContactRecordingCommandOutput | SuspendContactRecordingCommandOutput @@ -557,8 +587,7 @@ export type ConnectClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHa * endpoints, see Amazon Connect * Endpoints.

* - *

Working with contact flows? Check out the Amazon Connect - * Flow language.

+ *

Working with contact flows? Check out the Amazon Connect Flow language.

*
*/ export class ConnectClient extends __Client< diff --git a/clients/client-connect/commands/AssociateInstanceStorageConfigCommand.ts b/clients/client-connect/commands/AssociateInstanceStorageConfigCommand.ts index 0274525445e2..3c18b7bee754 100644 --- a/clients/client-connect/commands/AssociateInstanceStorageConfigCommand.ts +++ b/clients/client-connect/commands/AssociateInstanceStorageConfigCommand.ts @@ -22,12 +22,11 @@ export type AssociateInstanceStorageConfigCommandOutput = AssociateInstanceStora /** *

Associates a storage resource type for the first time. You can only associate one type of - * storage configuration in a single call. This means, for example, that you can't define an - * instance with multiple S3 buckets for storing chat transcripts.

- * + * storage configuration in a single call. This means, for example, that you can't define an + * instance with multiple S3 buckets for storing chat transcripts.

*

This API does not create a resource that doesn't exist. It only associates it to the - * instance. Ensure that the resource being specified in the storage configuration, like an Amazon - * S3 bucket, exists when being used for association.

+ * instance. Ensure that the resource being specified in the storage configuration, like an Amazon + * S3 bucket, exists when being used for association.

*/ export class AssociateInstanceStorageConfigCommand extends $Command< AssociateInstanceStorageConfigCommandInput, diff --git a/clients/client-connect/commands/CreateInstanceCommand.ts b/clients/client-connect/commands/CreateInstanceCommand.ts index 23d19fd73f8a..413615284914 100644 --- a/clients/client-connect/commands/CreateInstanceCommand.ts +++ b/clients/client-connect/commands/CreateInstanceCommand.ts @@ -21,7 +21,8 @@ export type CreateInstanceCommandInput = CreateInstanceRequest; export type CreateInstanceCommandOutput = CreateInstanceResponse & __MetadataBearer; /** - *

Initiates an Amazon Connect instance with all the supported channels enabled. It does not attach any + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Initiates an Amazon Connect instance with all the supported channels enabled. It does not attach any * storage (such as Amazon S3, or Kinesis) or allow for any configurations on features such as * Contact Lens for Amazon Connect.

*/ diff --git a/clients/client-connect/commands/CreateIntegrationAssociationCommand.ts b/clients/client-connect/commands/CreateIntegrationAssociationCommand.ts new file mode 100644 index 000000000000..0de136487714 --- /dev/null +++ b/clients/client-connect/commands/CreateIntegrationAssociationCommand.ts @@ -0,0 +1,92 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { CreateIntegrationAssociationRequest, CreateIntegrationAssociationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateIntegrationAssociationCommand, + serializeAws_restJson1CreateIntegrationAssociationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateIntegrationAssociationCommandInput = CreateIntegrationAssociationRequest; +export type CreateIntegrationAssociationCommandOutput = CreateIntegrationAssociationResponse & __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Create an AppIntegration association with anAmazon Connect instance.

+ */ +export class CreateIntegrationAssociationCommand extends $Command< + CreateIntegrationAssociationCommandInput, + CreateIntegrationAssociationCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateIntegrationAssociationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "CreateIntegrationAssociationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateIntegrationAssociationRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateIntegrationAssociationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateIntegrationAssociationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateIntegrationAssociationCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1CreateIntegrationAssociationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/CreateUseCaseCommand.ts b/clients/client-connect/commands/CreateUseCaseCommand.ts new file mode 100644 index 000000000000..f15655654e73 --- /dev/null +++ b/clients/client-connect/commands/CreateUseCaseCommand.ts @@ -0,0 +1,89 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { CreateUseCaseRequest, CreateUseCaseResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateUseCaseCommand, + serializeAws_restJson1CreateUseCaseCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateUseCaseCommandInput = CreateUseCaseRequest; +export type CreateUseCaseCommandOutput = CreateUseCaseResponse & __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Creates a use case for an AppIntegration association.

+ */ +export class CreateUseCaseCommand extends $Command< + CreateUseCaseCommandInput, + CreateUseCaseCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateUseCaseCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "CreateUseCaseCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateUseCaseRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateUseCaseResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateUseCaseCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateUseCaseCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateUseCaseCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/DeleteInstanceCommand.ts b/clients/client-connect/commands/DeleteInstanceCommand.ts index fc6f53c99d93..8fab17676523 100644 --- a/clients/client-connect/commands/DeleteInstanceCommand.ts +++ b/clients/client-connect/commands/DeleteInstanceCommand.ts @@ -21,7 +21,8 @@ export type DeleteInstanceCommandInput = DeleteInstanceRequest; export type DeleteInstanceCommandOutput = __MetadataBearer; /** - *

Deletes the Amazon Connect instance.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes the Amazon Connect instance.

*/ export class DeleteInstanceCommand extends $Command< DeleteInstanceCommandInput, diff --git a/clients/client-connect/commands/DeleteIntegrationAssociationCommand.ts b/clients/client-connect/commands/DeleteIntegrationAssociationCommand.ts new file mode 100644 index 000000000000..7e55a96678d3 --- /dev/null +++ b/clients/client-connect/commands/DeleteIntegrationAssociationCommand.ts @@ -0,0 +1,93 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { DeleteIntegrationAssociationRequest } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteIntegrationAssociationCommand, + serializeAws_restJson1DeleteIntegrationAssociationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteIntegrationAssociationCommandInput = DeleteIntegrationAssociationRequest; +export type DeleteIntegrationAssociationCommandOutput = __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes an AppIntegration association from an Amazon Connect instance. The association must not have + * any use cases associated with it.

+ */ +export class DeleteIntegrationAssociationCommand extends $Command< + DeleteIntegrationAssociationCommandInput, + DeleteIntegrationAssociationCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteIntegrationAssociationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "DeleteIntegrationAssociationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteIntegrationAssociationRequest.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteIntegrationAssociationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteIntegrationAssociationCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1DeleteIntegrationAssociationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/DeleteUseCaseCommand.ts b/clients/client-connect/commands/DeleteUseCaseCommand.ts new file mode 100644 index 000000000000..d5fc3199f209 --- /dev/null +++ b/clients/client-connect/commands/DeleteUseCaseCommand.ts @@ -0,0 +1,89 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { DeleteUseCaseRequest } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteUseCaseCommand, + serializeAws_restJson1DeleteUseCaseCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteUseCaseCommandInput = DeleteUseCaseRequest; +export type DeleteUseCaseCommandOutput = __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Deletes a use case from an AppIntegration association.

+ */ +export class DeleteUseCaseCommand extends $Command< + DeleteUseCaseCommandInput, + DeleteUseCaseCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteUseCaseCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "DeleteUseCaseCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteUseCaseRequest.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteUseCaseCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteUseCaseCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteUseCaseCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/DeleteUserCommand.ts b/clients/client-connect/commands/DeleteUserCommand.ts index 94f7df1c13c6..c9a7588e827b 100644 --- a/clients/client-connect/commands/DeleteUserCommand.ts +++ b/clients/client-connect/commands/DeleteUserCommand.ts @@ -24,8 +24,7 @@ export type DeleteUserCommandOutput = __MetadataBearer; *

Deletes a user account from the specified Amazon Connect instance.

*

For information about what happens to a user's data when their account is deleted, see * Delete Users from - * Your Amazon Connect Instance in the Amazon Connect Administrator - * Guide.

+ * Your Amazon Connect Instance in the Amazon Connect Administrator Guide.

*/ export class DeleteUserCommand extends $Command< DeleteUserCommandInput, diff --git a/clients/client-connect/commands/DeleteUserHierarchyGroupCommand.ts b/clients/client-connect/commands/DeleteUserHierarchyGroupCommand.ts index d4835d4f43e2..b62e70ede8f8 100644 --- a/clients/client-connect/commands/DeleteUserHierarchyGroupCommand.ts +++ b/clients/client-connect/commands/DeleteUserHierarchyGroupCommand.ts @@ -21,7 +21,8 @@ export type DeleteUserHierarchyGroupCommandInput = DeleteUserHierarchyGroupReque export type DeleteUserHierarchyGroupCommandOutput = __MetadataBearer; /** - *

Deletes an existing user hierarchy group. It must not be associated with any agents or have any active child groups.

+ *

Deletes an existing user hierarchy group. It must not be associated with any agents or have + * any active child groups.

*/ export class DeleteUserHierarchyGroupCommand extends $Command< DeleteUserHierarchyGroupCommandInput, diff --git a/clients/client-connect/commands/DescribeInstanceCommand.ts b/clients/client-connect/commands/DescribeInstanceCommand.ts index 7f3020815da1..e1247b2d64bb 100644 --- a/clients/client-connect/commands/DescribeInstanceCommand.ts +++ b/clients/client-connect/commands/DescribeInstanceCommand.ts @@ -21,12 +21,11 @@ export type DescribeInstanceCommandInput = DescribeInstanceRequest; export type DescribeInstanceCommandOutput = DescribeInstanceResponse & __MetadataBearer; /** - *

Returns the current state of the specified instance identifier. It tracks the instance while it is - * being created and returns an error status if applicable.

- *

If an instance is not created - * successfully, the instance status reason field returns details relevant to the reason. The instance - * in a failed state is returned only for 24 hours after - * the CreateInstance API was invoked.

+ *

Returns the current state of the specified instance identifier. It tracks the instance while + * it is being created and returns an error status if applicable.

+ *

If an instance is not created successfully, the instance status reason field returns details + * relevant to the reason. The instance in a failed state is returned only for 24 hours after the + * CreateInstance API was invoked.

*/ export class DescribeInstanceCommand extends $Command< DescribeInstanceCommandInput, diff --git a/clients/client-connect/commands/DescribeInstanceStorageConfigCommand.ts b/clients/client-connect/commands/DescribeInstanceStorageConfigCommand.ts index 9b6a62913650..060572bdeaed 100644 --- a/clients/client-connect/commands/DescribeInstanceStorageConfigCommand.ts +++ b/clients/client-connect/commands/DescribeInstanceStorageConfigCommand.ts @@ -21,7 +21,8 @@ export type DescribeInstanceStorageConfigCommandInput = DescribeInstanceStorageC export type DescribeInstanceStorageConfigCommandOutput = DescribeInstanceStorageConfigResponse & __MetadataBearer; /** - *

Retrieves the current storage configurations for the specified resource type, association ID, and instance ID.

+ *

Retrieves the current storage configurations for the specified resource type, association + * ID, and instance ID.

*/ export class DescribeInstanceStorageConfigCommand extends $Command< DescribeInstanceStorageConfigCommandInput, diff --git a/clients/client-connect/commands/DisassociateInstanceStorageConfigCommand.ts b/clients/client-connect/commands/DisassociateInstanceStorageConfigCommand.ts index 084edcabc76b..d0cd3e0c7e6c 100644 --- a/clients/client-connect/commands/DisassociateInstanceStorageConfigCommand.ts +++ b/clients/client-connect/commands/DisassociateInstanceStorageConfigCommand.ts @@ -21,7 +21,8 @@ export type DisassociateInstanceStorageConfigCommandInput = DisassociateInstance export type DisassociateInstanceStorageConfigCommandOutput = __MetadataBearer; /** - *

Removes the storage type configurations for the specified resource type and association ID.

+ *

Removes the storage type configurations for the specified resource type and association + * ID.

*/ export class DisassociateInstanceStorageConfigCommand extends $Command< DisassociateInstanceStorageConfigCommandInput, diff --git a/clients/client-connect/commands/ListInstanceAttributesCommand.ts b/clients/client-connect/commands/ListInstanceAttributesCommand.ts index 9622d6bd85cc..09a425e2ac73 100644 --- a/clients/client-connect/commands/ListInstanceAttributesCommand.ts +++ b/clients/client-connect/commands/ListInstanceAttributesCommand.ts @@ -21,7 +21,8 @@ export type ListInstanceAttributesCommandInput = ListInstanceAttributesRequest; export type ListInstanceAttributesCommandOutput = ListInstanceAttributesResponse & __MetadataBearer; /** - *

Returns a paginated list of all attribute types for the given instance.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Returns a paginated list of all attribute types for the given instance.

*/ export class ListInstanceAttributesCommand extends $Command< ListInstanceAttributesCommandInput, diff --git a/clients/client-connect/commands/ListInstanceStorageConfigsCommand.ts b/clients/client-connect/commands/ListInstanceStorageConfigsCommand.ts index a5ba3dcba577..b5b1b8d71080 100644 --- a/clients/client-connect/commands/ListInstanceStorageConfigsCommand.ts +++ b/clients/client-connect/commands/ListInstanceStorageConfigsCommand.ts @@ -21,7 +21,9 @@ export type ListInstanceStorageConfigsCommandInput = ListInstanceStorageConfigsR export type ListInstanceStorageConfigsCommandOutput = ListInstanceStorageConfigsResponse & __MetadataBearer; /** - *

Returns a paginated list of storage configs for the identified instance and resource + *

This API is in preview release for Amazon Connect and is subject to change.

+ * + *

Returns a paginated list of storage configs for the identified instance and resource * type.

*/ export class ListInstanceStorageConfigsCommand extends $Command< diff --git a/clients/client-connect/commands/ListInstancesCommand.ts b/clients/client-connect/commands/ListInstancesCommand.ts index 11f56373a12c..b4d1ac499a6a 100644 --- a/clients/client-connect/commands/ListInstancesCommand.ts +++ b/clients/client-connect/commands/ListInstancesCommand.ts @@ -21,7 +21,8 @@ export type ListInstancesCommandInput = ListInstancesRequest; export type ListInstancesCommandOutput = ListInstancesResponse & __MetadataBearer; /** - *

Return a list of instances which are in active state, creation-in-progress state, and failed + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Return a list of instances which are in active state, creation-in-progress state, and failed * state. Instances that aren't successfully created (they are in a failed state) are returned only * for 24 hours after the CreateInstance API was invoked.

*/ diff --git a/clients/client-connect/commands/ListIntegrationAssociationsCommand.ts b/clients/client-connect/commands/ListIntegrationAssociationsCommand.ts new file mode 100644 index 000000000000..b5db1386033c --- /dev/null +++ b/clients/client-connect/commands/ListIntegrationAssociationsCommand.ts @@ -0,0 +1,93 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { ListIntegrationAssociationsRequest, ListIntegrationAssociationsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListIntegrationAssociationsCommand, + serializeAws_restJson1ListIntegrationAssociationsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListIntegrationAssociationsCommandInput = ListIntegrationAssociationsRequest; +export type ListIntegrationAssociationsCommandOutput = ListIntegrationAssociationsResponse & __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Provides summary information about the AppIntegration associations for the specified Amazon Connect + * instance.

+ */ +export class ListIntegrationAssociationsCommand extends $Command< + ListIntegrationAssociationsCommandInput, + ListIntegrationAssociationsCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListIntegrationAssociationsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "ListIntegrationAssociationsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListIntegrationAssociationsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListIntegrationAssociationsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListIntegrationAssociationsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListIntegrationAssociationsCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1ListIntegrationAssociationsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/ListLambdaFunctionsCommand.ts b/clients/client-connect/commands/ListLambdaFunctionsCommand.ts index 126a08fd1a6f..89c2ff8f2ad3 100644 --- a/clients/client-connect/commands/ListLambdaFunctionsCommand.ts +++ b/clients/client-connect/commands/ListLambdaFunctionsCommand.ts @@ -21,7 +21,8 @@ export type ListLambdaFunctionsCommandInput = ListLambdaFunctionsRequest; export type ListLambdaFunctionsCommandOutput = ListLambdaFunctionsResponse & __MetadataBearer; /** - *

Returns a paginated list of all the Lambda functions that show up in the drop-down options in the relevant contact flow blocks.

+ *

Returns a paginated list of all the Lambda functions that show up in the drop-down options + * in the relevant contact flow blocks.

*/ export class ListLambdaFunctionsCommand extends $Command< ListLambdaFunctionsCommandInput, diff --git a/clients/client-connect/commands/ListLexBotsCommand.ts b/clients/client-connect/commands/ListLexBotsCommand.ts index 5eef6e238815..454dd645ea12 100644 --- a/clients/client-connect/commands/ListLexBotsCommand.ts +++ b/clients/client-connect/commands/ListLexBotsCommand.ts @@ -21,7 +21,8 @@ export type ListLexBotsCommandInput = ListLexBotsRequest; export type ListLexBotsCommandOutput = ListLexBotsResponse & __MetadataBearer; /** - *

Returns a paginated list of all the Amazon Lex bots currently associated with the instance.

+ *

Returns a paginated list of all the Amazon Lex bots currently associated with the + * instance.

*/ export class ListLexBotsCommand extends $Command< ListLexBotsCommandInput, diff --git a/clients/client-connect/commands/ListPromptsCommand.ts b/clients/client-connect/commands/ListPromptsCommand.ts index 3aeb59edaed9..7ce141566423 100644 --- a/clients/client-connect/commands/ListPromptsCommand.ts +++ b/clients/client-connect/commands/ListPromptsCommand.ts @@ -21,8 +21,7 @@ export type ListPromptsCommandInput = ListPromptsRequest; export type ListPromptsCommandOutput = ListPromptsResponse & __MetadataBearer; /** - *

Provides information about the prompts for the specified Amazon Connect - * instance.

+ *

Provides information about the prompts for the specified Amazon Connect instance.

*/ export class ListPromptsCommand extends $Command< ListPromptsCommandInput, diff --git a/clients/client-connect/commands/ListUseCasesCommand.ts b/clients/client-connect/commands/ListUseCasesCommand.ts new file mode 100644 index 000000000000..c83d32eca194 --- /dev/null +++ b/clients/client-connect/commands/ListUseCasesCommand.ts @@ -0,0 +1,89 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { ListUseCasesRequest, ListUseCasesResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListUseCasesCommand, + serializeAws_restJson1ListUseCasesCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListUseCasesCommandInput = ListUseCasesRequest; +export type ListUseCasesCommandOutput = ListUseCasesResponse & __MetadataBearer; + +/** + *

This API is in preview release for Amazon Connect and is subject to change.

+ *

List the use cases.

+ */ +export class ListUseCasesCommand extends $Command< + ListUseCasesCommandInput, + ListUseCasesCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListUseCasesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "ListUseCasesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListUseCasesRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListUseCasesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListUseCasesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListUseCasesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListUseCasesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/StartContactRecordingCommand.ts b/clients/client-connect/commands/StartContactRecordingCommand.ts index 953e612d154c..aea2ea382386 100644 --- a/clients/client-connect/commands/StartContactRecordingCommand.ts +++ b/clients/client-connect/commands/StartContactRecordingCommand.ts @@ -27,7 +27,7 @@ export type StartContactRecordingCommandOutput = StartContactRecordingResponse & * started and you want to suspend and resume it, such as when collecting sensitive information (for * example, a credit card number), use SuspendContactRecording and ResumeContactRecording.

*

You can use this API to override the recording behavior configured in the Set recording - * behavior block.

+ * behavior block.

*

Only voice recordings are supported at this time.

*/ export class StartContactRecordingCommand extends $Command< diff --git a/clients/client-connect/commands/StartOutboundVoiceContactCommand.ts b/clients/client-connect/commands/StartOutboundVoiceContactCommand.ts index c8df7bfbde8c..bad94ac87d54 100644 --- a/clients/client-connect/commands/StartOutboundVoiceContactCommand.ts +++ b/clients/client-connect/commands/StartOutboundVoiceContactCommand.ts @@ -33,7 +33,7 @@ export type StartOutboundVoiceContactCommandOutput = StartOutboundVoiceContactRe * *

UK numbers with a 447 prefix are not allowed by default. Before you can dial these UK * mobile numbers, you must submit a service quota increase request. For more information, see - * Amazon Connect Service Quotas in the Amazon Connect Administrator Guide.

+ * Amazon Connect Service Quotas in the Amazon Connect Administrator Guide.

*
*/ export class StartOutboundVoiceContactCommand extends $Command< diff --git a/clients/client-connect/commands/StartTaskContactCommand.ts b/clients/client-connect/commands/StartTaskContactCommand.ts new file mode 100644 index 000000000000..8c4bff404c29 --- /dev/null +++ b/clients/client-connect/commands/StartTaskContactCommand.ts @@ -0,0 +1,88 @@ +import { ConnectClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ConnectClient"; +import { StartTaskContactRequest, StartTaskContactResponse } from "../models/models_0"; +import { + deserializeAws_restJson1StartTaskContactCommand, + serializeAws_restJson1StartTaskContactCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StartTaskContactCommandInput = StartTaskContactRequest; +export type StartTaskContactCommandOutput = StartTaskContactResponse & __MetadataBearer; + +/** + *

Initiates a contact flow to start a new task.

+ */ +export class StartTaskContactCommand extends $Command< + StartTaskContactCommandInput, + StartTaskContactCommandOutput, + ConnectClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StartTaskContactCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ConnectClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ConnectClient"; + const commandName = "StartTaskContactCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StartTaskContactRequest.filterSensitiveLog, + outputFilterSensitiveLog: StartTaskContactResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StartTaskContactCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1StartTaskContactCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1StartTaskContactCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-connect/commands/UpdateInstanceAttributeCommand.ts b/clients/client-connect/commands/UpdateInstanceAttributeCommand.ts index 8c2555c96423..b64a0ce72607 100644 --- a/clients/client-connect/commands/UpdateInstanceAttributeCommand.ts +++ b/clients/client-connect/commands/UpdateInstanceAttributeCommand.ts @@ -21,7 +21,8 @@ export type UpdateInstanceAttributeCommandInput = UpdateInstanceAttributeRequest export type UpdateInstanceAttributeCommandOutput = __MetadataBearer; /** - *

Updates the value for the specified attribute type.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Updates the value for the specified attribute type.

*/ export class UpdateInstanceAttributeCommand extends $Command< UpdateInstanceAttributeCommandInput, diff --git a/clients/client-connect/commands/UpdateInstanceStorageConfigCommand.ts b/clients/client-connect/commands/UpdateInstanceStorageConfigCommand.ts index 142b6e2b3c8e..7cb436ac5a0f 100644 --- a/clients/client-connect/commands/UpdateInstanceStorageConfigCommand.ts +++ b/clients/client-connect/commands/UpdateInstanceStorageConfigCommand.ts @@ -21,7 +21,8 @@ export type UpdateInstanceStorageConfigCommandInput = UpdateInstanceStorageConfi export type UpdateInstanceStorageConfigCommandOutput = __MetadataBearer; /** - *

Updates an existing configuration for a resource type. This API is idempotent.

+ *

This API is in preview release for Amazon Connect and is subject to change.

+ *

Updates an existing configuration for a resource type. This API is idempotent.

*/ export class UpdateInstanceStorageConfigCommand extends $Command< UpdateInstanceStorageConfigCommandInput, diff --git a/clients/client-connect/commands/UpdateRoutingProfileConcurrencyCommand.ts b/clients/client-connect/commands/UpdateRoutingProfileConcurrencyCommand.ts index a9047800dc2b..19851c95d85d 100644 --- a/clients/client-connect/commands/UpdateRoutingProfileConcurrencyCommand.ts +++ b/clients/client-connect/commands/UpdateRoutingProfileConcurrencyCommand.ts @@ -21,7 +21,8 @@ export type UpdateRoutingProfileConcurrencyCommandInput = UpdateRoutingProfileCo export type UpdateRoutingProfileConcurrencyCommandOutput = __MetadataBearer; /** - *

Updates the channels that agents can handle in the Contact Control Panel (CCP) for a routing profile.

+ *

Updates the channels that agents can handle in the Contact Control Panel (CCP) for a routing + * profile.

*/ export class UpdateRoutingProfileConcurrencyCommand extends $Command< UpdateRoutingProfileConcurrencyCommandInput, diff --git a/clients/client-connect/commands/UpdateRoutingProfileNameCommand.ts b/clients/client-connect/commands/UpdateRoutingProfileNameCommand.ts index 7c210c9b4ffa..d0eb6590ae04 100644 --- a/clients/client-connect/commands/UpdateRoutingProfileNameCommand.ts +++ b/clients/client-connect/commands/UpdateRoutingProfileNameCommand.ts @@ -21,7 +21,9 @@ export type UpdateRoutingProfileNameCommandInput = UpdateRoutingProfileNameReque export type UpdateRoutingProfileNameCommandOutput = __MetadataBearer; /** - *

Updates the name and description of a routing profile. The request accepts the following data in JSON format. At least Name or Description must be provided.

+ *

Updates the name and description of a routing profile. The request accepts the following + * data in JSON format. At least Name or Description must be + * provided.

*/ export class UpdateRoutingProfileNameCommand extends $Command< UpdateRoutingProfileNameCommandInput, diff --git a/clients/client-connect/index.ts b/clients/client-connect/index.ts index f7993eb53005..0eb770929476 100644 --- a/clients/client-connect/index.ts +++ b/clients/client-connect/index.ts @@ -8,10 +8,14 @@ export * from "./commands/AssociateRoutingProfileQueuesCommand"; export * from "./commands/AssociateSecurityKeyCommand"; export * from "./commands/CreateContactFlowCommand"; export * from "./commands/CreateInstanceCommand"; +export * from "./commands/CreateIntegrationAssociationCommand"; export * from "./commands/CreateRoutingProfileCommand"; +export * from "./commands/CreateUseCaseCommand"; export * from "./commands/CreateUserCommand"; export * from "./commands/CreateUserHierarchyGroupCommand"; export * from "./commands/DeleteInstanceCommand"; +export * from "./commands/DeleteIntegrationAssociationCommand"; +export * from "./commands/DeleteUseCaseCommand"; export * from "./commands/DeleteUserCommand"; export * from "./commands/DeleteUserHierarchyGroupCommand"; export * from "./commands/DescribeContactFlowCommand"; @@ -46,6 +50,8 @@ export * from "./commands/ListInstancesCommand"; export * from "./pagination/ListInstancesPaginator"; export * from "./commands/ListInstanceStorageConfigsCommand"; export * from "./pagination/ListInstanceStorageConfigsPaginator"; +export * from "./commands/ListIntegrationAssociationsCommand"; +export * from "./pagination/ListIntegrationAssociationsPaginator"; export * from "./commands/ListLambdaFunctionsCommand"; export * from "./pagination/ListLambdaFunctionsPaginator"; export * from "./commands/ListLexBotsCommand"; @@ -65,6 +71,8 @@ export * from "./pagination/ListSecurityKeysPaginator"; export * from "./commands/ListSecurityProfilesCommand"; export * from "./pagination/ListSecurityProfilesPaginator"; export * from "./commands/ListTagsForResourceCommand"; +export * from "./commands/ListUseCasesCommand"; +export * from "./pagination/ListUseCasesPaginator"; export * from "./commands/ListUserHierarchyGroupsCommand"; export * from "./pagination/ListUserHierarchyGroupsPaginator"; export * from "./commands/ListUsersCommand"; @@ -73,6 +81,7 @@ export * from "./commands/ResumeContactRecordingCommand"; export * from "./commands/StartChatContactCommand"; export * from "./commands/StartContactRecordingCommand"; export * from "./commands/StartOutboundVoiceContactCommand"; +export * from "./commands/StartTaskContactCommand"; export * from "./commands/StopContactCommand"; export * from "./commands/StopContactRecordingCommand"; export * from "./commands/SuspendContactRecordingCommand"; diff --git a/clients/client-connect/models/models_0.ts b/clients/client-connect/models/models_0.ts index 1a6d4d94b7ed..62fc24a3e578 100644 --- a/clients/client-connect/models/models_0.ts +++ b/clients/client-connect/models/models_0.ts @@ -214,7 +214,6 @@ export interface KinesisVideoStreamConfig { /** *

The number of hours data is retained in the stream. Kinesis Video Streams retains the data * in a data store that is associated with the stream.

- * *

The default value is 0, indicating that the stream does not persist data.

*/ RetentionPeriodHours: number | undefined; @@ -401,6 +400,7 @@ export namespace AssociateLexBotRequest { export enum Channel { CHAT = "CHAT", + TASK = "TASK", VOICE = "VOICE", } @@ -427,7 +427,8 @@ export namespace RoutingProfileQueueReference { } /** - *

Contains information about the queue and channel for which priority and delay can be set.

+ *

Contains information about the queue and channel for which priority and delay can be + * set.

*/ export interface RoutingProfileQueueConfig { /** @@ -436,8 +437,9 @@ export interface RoutingProfileQueueConfig { QueueReference: RoutingProfileQueueReference | undefined; /** - *

The order in which contacts are to be handled for the queue. For more information, see Queues: priority and - * delay.

+ *

The order in which contacts are to be handled for the queue. For more information, see + * Queues: priority and + * delay.

*/ Priority: number | undefined; @@ -534,7 +536,7 @@ export interface CreateContactFlowRequest { /** *

The type of the contact flow. For descriptions of the available types, see Choose a Contact Flow Type in the Amazon Connect Administrator - * Guide.

+ * Guide.

*/ Type: ContactFlowType | string | undefined; @@ -544,9 +546,7 @@ export interface CreateContactFlowRequest { Description?: string; /** - *

The content of the contact flow. - * - *

+ *

The content of the contact flow.

*/ Content: string | undefined; @@ -710,6 +710,71 @@ export namespace CreateInstanceResponse { }); } +export enum IntegrationType { + EVENT = "EVENT", +} + +export enum SourceType { + SALESFORCE = "SALESFORCE", + ZENDESK = "ZENDESK", +} + +export interface CreateIntegrationAssociationRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The type of information to be ingested.

+ */ + IntegrationType: IntegrationType | string | undefined; + + /** + *

The Amazon Resource Name (ARN) of the integration.

+ */ + IntegrationArn: string | undefined; + + /** + *

The URL for the external application.

+ */ + SourceApplicationUrl: string | undefined; + + /** + *

The name of the external application.

+ */ + SourceApplicationName: string | undefined; + + /** + *

The type of the data source.

+ */ + SourceType: SourceType | string | undefined; +} + +export namespace CreateIntegrationAssociationRequest { + export const filterSensitiveLog = (obj: CreateIntegrationAssociationRequest): any => ({ + ...obj, + }); +} + +export interface CreateIntegrationAssociationResponse { + /** + *

The identifier for the association.

+ */ + IntegrationAssociationId?: string; + + /** + *

The Amazon Resource Name (ARN) for the association.

+ */ + IntegrationAssociationArn?: string; +} + +export namespace CreateIntegrationAssociationResponse { + export const filterSensitiveLog = (obj: CreateIntegrationAssociationResponse): any => ({ + ...obj, + }); +} + /** *

Contains information about which channels are supported, and how many contacts an agent can * have on a channel simultaneously.

@@ -795,6 +860,52 @@ export namespace CreateRoutingProfileResponse { }); } +export enum UseCaseType { + RULES_EVALUATION = "RULES_EVALUATION", +} + +export interface CreateUseCaseRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier for the AppIntegration association.

+ */ + IntegrationAssociationId: string | undefined; + + /** + *

The type of use case to associate to the AppIntegration association. Each AppIntegration + * association can have only one of each use case type.

+ */ + UseCaseType: UseCaseType | string | undefined; +} + +export namespace CreateUseCaseRequest { + export const filterSensitiveLog = (obj: CreateUseCaseRequest): any => ({ + ...obj, + }); +} + +export interface CreateUseCaseResponse { + /** + *

The identifier of the use case.

+ */ + UseCaseId?: string; + + /** + *

The Amazon Resource Name (ARN) for the use case.

+ */ + UseCaseArn?: string; +} + +export namespace CreateUseCaseResponse { + export const filterSensitiveLog = (obj: CreateUseCaseResponse): any => ({ + ...obj, + }); +} + /** *

Contains information about the identity of a user.

*/ @@ -952,7 +1063,8 @@ export interface CreateUserHierarchyGroupRequest { Name: string | undefined; /** - *

The identifier for the parent hierarchy group. The user hierarchy is created at level one if the parent group ID is null.

+ *

The identifier for the parent hierarchy group. The user hierarchy is created at level one if + * the parent group ID is null.

*/ ParentGroupId?: string; @@ -999,6 +1111,47 @@ export namespace DeleteInstanceRequest { }); } +export interface DeleteIntegrationAssociationRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier for the AppIntegration association.

+ */ + IntegrationAssociationId: string | undefined; +} + +export namespace DeleteIntegrationAssociationRequest { + export const filterSensitiveLog = (obj: DeleteIntegrationAssociationRequest): any => ({ + ...obj, + }); +} + +export interface DeleteUseCaseRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier for the AppIntegration association.

+ */ + IntegrationAssociationId: string | undefined; + + /** + *

The identifier for the use case.

+ */ + UseCaseId: string | undefined; +} + +export namespace DeleteUseCaseRequest { + export const filterSensitiveLog = (obj: DeleteUseCaseRequest): any => ({ + ...obj, + }); +} + export interface DeleteUserRequest { /** *

The identifier of the Amazon Connect instance.

@@ -1123,7 +1276,7 @@ export interface ContactFlow { /** *

The type of the contact flow. For descriptions of the available types, see Choose a Contact Flow Type in the Amazon Connect Administrator - * Guide.

+ * Guide.

*/ Type?: ContactFlowType | string; @@ -1419,7 +1572,8 @@ export interface RoutingProfile { Description?: string; /** - *

The channels agents can handle in the Contact Control Panel (CCP) for this routing profile.

+ *

The channels agents can handle in the Contact Control Panel (CCP) for this routing + * profile.

*/ MediaConcurrencies?: MediaConcurrency[]; @@ -1996,14 +2150,15 @@ export interface GetCurrentMetricDataRequest { /** *

The queues, up to 100, or channels, to use to filter the metrics returned. Metric data is * retrieved only for the resources associated with the queues or channels included in the filter. - * You can include both queue IDs and queue ARNs in the same request. Both VOICE and CHAT channels are supported.

+ * You can include both queue IDs and queue ARNs in the same request. VOICE, CHAT, and TASK channels are supported.

*/ Filters: Filters | undefined; /** *

The grouping applied to the metrics returned. For example, when grouped by * QUEUE, the metrics returned apply to each queue rather than aggregated for all - * queues. If you group by CHANNEL, you should include a Channels filter. Both VOICE and CHAT channels are supported.

+ * queues. If you group by CHANNEL, you should include a Channels filter. + * VOICE, CHAT, and TASK channels are supported.

*

If no Grouping is included in the request, a summary of metrics is * returned.

*/ @@ -2081,8 +2236,8 @@ export interface GetCurrentMetricDataRequest { *
OLDEST_CONTACT_AGE
*
*

Unit: SECONDS

- *

When you use groupings, Unit says SECONDS but the Value is returned in MILLISECONDS. For example, if you get a - * response like this:

+ *

When you use groupings, Unit says SECONDS but the Value is returned in MILLISECONDS. For + * example, if you get a response like this:

*

* { "Metric": { "Name": "OLDEST_CONTACT_AGE", "Unit": "SECONDS" }, "Value": 24113.0 * }

@@ -2429,7 +2584,7 @@ export interface GetMetricDataRequest { /** *

The queues, up to 100, or channels, to use to filter the metrics returned. Metric data is * retrieved only for the resources associated with the queues or channels included in the filter. - * You can include both queue IDs and queue ARNs in the same request. Both VOICE and CHAT channels are supported.

+ * You can include both queue IDs and queue ARNs in the same request. VOICE, CHAT, and TASK channels are supported.

*/ Filters: Filters | undefined; @@ -3035,6 +3190,99 @@ export namespace ListInstanceStorageConfigsResponse { }); } +export interface ListIntegrationAssociationsRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The token for the next set of results. Use the value returned in the previous + * response in the next request to retrieve the next set of results.

+ */ + NextToken?: string; + + /** + *

The maximimum number of results to return per page.

+ */ + MaxResults?: number; +} + +export namespace ListIntegrationAssociationsRequest { + export const filterSensitiveLog = (obj: ListIntegrationAssociationsRequest): any => ({ + ...obj, + }); +} + +/** + *

Contains summary information about the associated AppIntegrations.

+ */ +export interface IntegrationAssociationSummary { + /** + *

The identifier for the AppIntegration association.

+ */ + IntegrationAssociationId?: string; + + /** + *

The Amazon Resource Name (ARN) for the AppIntegration association.

+ */ + IntegrationAssociationArn?: string; + + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId?: string; + + /** + *

The integration type.

+ */ + IntegrationType?: IntegrationType | string; + + /** + *

The Amazon Resource Name (ARN) for the AppIntegration.

+ */ + IntegrationArn?: string; + + /** + *

The URL for the external application.

+ */ + SourceApplicationUrl?: string; + + /** + *

The user-provided, friendly name for the external application.

+ */ + SourceApplicationName?: string; + + /** + *

The name of the source.

+ */ + SourceType?: SourceType | string; +} + +export namespace IntegrationAssociationSummary { + export const filterSensitiveLog = (obj: IntegrationAssociationSummary): any => ({ + ...obj, + }); +} + +export interface ListIntegrationAssociationsResponse { + /** + *

The AppIntegration associations.

+ */ + IntegrationAssociationSummaryList?: IntegrationAssociationSummary[]; + + /** + *

If there are additional results, this is the token for the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListIntegrationAssociationsResponse { + export const filterSensitiveLog = (obj: ListIntegrationAssociationsResponse): any => ({ + ...obj, + }); +} + export interface ListLambdaFunctionsRequest { /** *

The identifier of the Amazon Connect instance.

@@ -3652,8 +3900,9 @@ export interface RoutingProfileQueueConfigSummary { QueueName: string | undefined; /** - *

The order in which contacts are to be handled for the queue. For more information, see Queues: priority and - * delay.

+ *

The order in which contacts are to be handled for the queue. For more information, see + * Queues: priority and + * delay.

*/ Priority: number | undefined; @@ -3924,6 +4173,84 @@ export namespace ListTagsForResourceResponse { }); } +/** + *

Provides summary information about the use cases for the specified Amazon Connect AppIntegration + * association.

+ */ +export interface ListUseCasesRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier for the integration association.

+ */ + IntegrationAssociationId: string | undefined; + + /** + *

The token for the next set of results. Use the value returned in the previous + * response in the next request to retrieve the next set of results.

+ */ + NextToken?: string; + + /** + *

The maximimum number of results to return per page.

+ */ + MaxResults?: number; +} + +export namespace ListUseCasesRequest { + export const filterSensitiveLog = (obj: ListUseCasesRequest): any => ({ + ...obj, + }); +} + +/** + *

Contains the use case.

+ */ +export interface UseCase { + /** + *

The identifier for the use case.

+ */ + UseCaseId?: string; + + /** + *

The Amazon Resource Name (ARN) for the use case.

+ */ + UseCaseArn?: string; + + /** + *

The type of use case to associate to the AppIntegration association. Each AppIntegration + * association can have only one of each use case type.

+ */ + UseCaseType?: UseCaseType | string; +} + +export namespace UseCase { + export const filterSensitiveLog = (obj: UseCase): any => ({ + ...obj, + }); +} + +export interface ListUseCasesResponse { + /** + *

The use cases.

+ */ + UseCaseSummaryList?: UseCase[]; + + /** + *

If there are additional results, this is the token for the next set of results.

+ */ + NextToken?: string; +} + +export namespace ListUseCasesResponse { + export const filterSensitiveLog = (obj: ListUseCasesResponse): any => ({ + ...obj, + }); +} + export interface ListUserHierarchyGroupsRequest { /** *

The identifier of the Amazon Connect instance.

@@ -4342,6 +4669,104 @@ export namespace StartOutboundVoiceContactResponse { }); } +export enum ReferenceType { + URL = "URL", +} + +/** + *

A link that an agent selects to complete a given task. You can have up to 4,096 UTF-8 bytes + * across all references for a contact.

+ */ +export interface Reference { + /** + *

A formatted URL that will be shown to an agent in the Contact Control Panel (CCP)

+ */ + Value: string | undefined; + + /** + *

A valid URL.

+ */ + Type: ReferenceType | string | undefined; +} + +export namespace Reference { + export const filterSensitiveLog = (obj: Reference): any => ({ + ...obj, + }); +} + +export interface StartTaskContactRequest { + /** + *

The identifier of the Amazon Connect instance.

+ */ + InstanceId: string | undefined; + + /** + *

The identifier of the previous chat, voice, or task contact.

+ */ + PreviousContactId?: string; + + /** + *

The identifier of the contact flow for initiating the tasks. To see the ContactFlowId in the + * Amazon Connect console user interface, on the navigation menu go to Routing, Contact Flows. Choose the contact flow. On + * the contact flow page, under the name of the contact flow, choose Show + * additional flow information. The ContactFlowId is the last part of the ARN, shown + * here in bold:

+ *

arn:aws:connect:us-west-2:xxxxxxxxxxxx:instance/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/contact-flow/846ec553-a005-41c0-8341-xxxxxxxxxxxx + *

+ */ + ContactFlowId: string | undefined; + + /** + *

A custom key-value pair using an attribute map. The attributes are standard Amazon Connect + * attributes, and can be accessed in contact flows just like any other contact attributes.

+ *

There can be up to 32,768 UTF-8 bytes across all key-value pairs per contact. Attribute keys + * can include only alphanumeric, dash, and underscore characters.

+ */ + Attributes?: { [key: string]: string }; + + /** + *

The name of a task that is shown to an agent in the Contact Control Panel (CCP).

+ */ + Name: string | undefined; + + /** + *

A formatted URL that is shown to an agent in the Contact Control Panel (CCP).

+ */ + References?: { [key: string]: Reference }; + + /** + *

A description of the task that is shown to an agent in the Contact Control Panel + * (CCP).

+ */ + Description?: string; + + /** + *

A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

+ */ + ClientToken?: string; +} + +export namespace StartTaskContactRequest { + export const filterSensitiveLog = (obj: StartTaskContactRequest): any => ({ + ...obj, + }); +} + +export interface StartTaskContactResponse { + /** + *

The identifier of this contact within the Amazon Connect instance.

+ */ + ContactId?: string; +} + +export namespace StartTaskContactResponse { + export const filterSensitiveLog = (obj: StartTaskContactResponse): any => ({ + ...obj, + }); +} + /** *

The contact with the specified ID is not active or does not exist.

*/ @@ -4533,7 +4958,9 @@ export interface UpdateContactFlowContentRequest { ContactFlowId: string | undefined; /** - *

The JSON string that represents contact flow’s content. For an example, see Example contact flow in Amazon Connect Flow language in the Amazon Connect Administrator Guide.

+ *

The JSON string that represents contact flow’s content. For an example, see Example contact + * flow in Amazon Connect Flow language in the Amazon Connect Administrator Guide. + *

*/ Content: string | undefined; } @@ -4709,7 +5136,8 @@ export interface UpdateRoutingProfileQueuesRequest { RoutingProfileId: string | undefined; /** - *

The queues to be updated for this routing profile.

+ *

The queues to be updated for this routing profile. Queues must first be associated to the + * routing profile. You can do this using AssociateRoutingProfileQueues.

*/ QueueConfigs: RoutingProfileQueueConfig[] | undefined; } diff --git a/clients/client-connect/pagination/ListIntegrationAssociationsPaginator.ts b/clients/client-connect/pagination/ListIntegrationAssociationsPaginator.ts new file mode 100644 index 000000000000..3e51b4c29667 --- /dev/null +++ b/clients/client-connect/pagination/ListIntegrationAssociationsPaginator.ts @@ -0,0 +1,57 @@ +import { Connect } from "../Connect"; +import { ConnectClient } from "../ConnectClient"; +import { + ListIntegrationAssociationsCommand, + ListIntegrationAssociationsCommandInput, + ListIntegrationAssociationsCommandOutput, +} from "../commands/ListIntegrationAssociationsCommand"; +import { ConnectPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ConnectClient, + input: ListIntegrationAssociationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListIntegrationAssociationsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Connect, + input: ListIntegrationAssociationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listIntegrationAssociations(input, ...args); +}; +export async function* paginateListIntegrationAssociations( + config: ConnectPaginationConfiguration, + input: ListIntegrationAssociationsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListIntegrationAssociationsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof Connect) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ConnectClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Connect | ConnectClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-connect/pagination/ListUseCasesPaginator.ts b/clients/client-connect/pagination/ListUseCasesPaginator.ts new file mode 100644 index 000000000000..c69c6be952de --- /dev/null +++ b/clients/client-connect/pagination/ListUseCasesPaginator.ts @@ -0,0 +1,57 @@ +import { Connect } from "../Connect"; +import { ConnectClient } from "../ConnectClient"; +import { + ListUseCasesCommand, + ListUseCasesCommandInput, + ListUseCasesCommandOutput, +} from "../commands/ListUseCasesCommand"; +import { ConnectPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ConnectClient, + input: ListUseCasesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListUseCasesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Connect, + input: ListUseCasesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listUseCases(input, ...args); +}; +export async function* paginateListUseCases( + config: ConnectPaginationConfiguration, + input: ListUseCasesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListUseCasesCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof Connect) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ConnectClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Connect | ConnectClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-connect/protocols/Aws_restJson1.ts b/clients/client-connect/protocols/Aws_restJson1.ts index a8d5047aa205..30efa51287ee 100644 --- a/clients/client-connect/protocols/Aws_restJson1.ts +++ b/clients/client-connect/protocols/Aws_restJson1.ts @@ -21,16 +21,26 @@ import { } from "../commands/AssociateSecurityKeyCommand"; import { CreateContactFlowCommandInput, CreateContactFlowCommandOutput } from "../commands/CreateContactFlowCommand"; import { CreateInstanceCommandInput, CreateInstanceCommandOutput } from "../commands/CreateInstanceCommand"; +import { + CreateIntegrationAssociationCommandInput, + CreateIntegrationAssociationCommandOutput, +} from "../commands/CreateIntegrationAssociationCommand"; import { CreateRoutingProfileCommandInput, CreateRoutingProfileCommandOutput, } from "../commands/CreateRoutingProfileCommand"; +import { CreateUseCaseCommandInput, CreateUseCaseCommandOutput } from "../commands/CreateUseCaseCommand"; import { CreateUserCommandInput, CreateUserCommandOutput } from "../commands/CreateUserCommand"; import { CreateUserHierarchyGroupCommandInput, CreateUserHierarchyGroupCommandOutput, } from "../commands/CreateUserHierarchyGroupCommand"; import { DeleteInstanceCommandInput, DeleteInstanceCommandOutput } from "../commands/DeleteInstanceCommand"; +import { + DeleteIntegrationAssociationCommandInput, + DeleteIntegrationAssociationCommandOutput, +} from "../commands/DeleteIntegrationAssociationCommand"; +import { DeleteUseCaseCommandInput, DeleteUseCaseCommandOutput } from "../commands/DeleteUseCaseCommand"; import { DeleteUserCommandInput, DeleteUserCommandOutput } from "../commands/DeleteUserCommand"; import { DeleteUserHierarchyGroupCommandInput, @@ -111,6 +121,10 @@ import { ListInstanceStorageConfigsCommandOutput, } from "../commands/ListInstanceStorageConfigsCommand"; import { ListInstancesCommandInput, ListInstancesCommandOutput } from "../commands/ListInstancesCommand"; +import { + ListIntegrationAssociationsCommandInput, + ListIntegrationAssociationsCommandOutput, +} from "../commands/ListIntegrationAssociationsCommand"; import { ListLambdaFunctionsCommandInput, ListLambdaFunctionsCommandOutput, @@ -136,6 +150,7 @@ import { ListTagsForResourceCommandInput, ListTagsForResourceCommandOutput, } from "../commands/ListTagsForResourceCommand"; +import { ListUseCasesCommandInput, ListUseCasesCommandOutput } from "../commands/ListUseCasesCommand"; import { ListUserHierarchyGroupsCommandInput, ListUserHierarchyGroupsCommandOutput, @@ -154,6 +169,7 @@ import { StartOutboundVoiceContactCommandInput, StartOutboundVoiceContactCommandOutput, } from "../commands/StartOutboundVoiceContactCommand"; +import { StartTaskContactCommandInput, StartTaskContactCommandOutput } from "../commands/StartTaskContactCommand"; import { StopContactCommandInput, StopContactCommandOutput } from "../commands/StopContactCommand"; import { StopContactRecordingCommandInput, @@ -262,6 +278,7 @@ import { InstanceStatusReason, InstanceStorageConfig, InstanceSummary, + IntegrationAssociationSummary, InternalServiceException, InvalidContactFlowException, InvalidParameterException, @@ -279,6 +296,7 @@ import { PromptSummary, QueueReference, QueueSummary, + Reference, ResourceConflictException, ResourceInUseException, ResourceNotFoundException, @@ -293,6 +311,7 @@ import { ServiceQuotaExceededException, Threshold, ThrottlingException, + UseCase, User, UserIdentityInfo, UserNotFoundException, @@ -591,6 +610,43 @@ export const serializeAws_restJson1CreateInstanceCommand = async ( }); }; +export const serializeAws_restJson1CreateIntegrationAssociationCommand = async ( + input: CreateIntegrationAssociationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + let body: any; + body = JSON.stringify({ + ...(input.IntegrationArn !== undefined && { IntegrationArn: input.IntegrationArn }), + ...(input.IntegrationType !== undefined && { IntegrationType: input.IntegrationType }), + ...(input.SourceApplicationName !== undefined && { SourceApplicationName: input.SourceApplicationName }), + ...(input.SourceApplicationUrl !== undefined && { SourceApplicationUrl: input.SourceApplicationUrl }), + ...(input.SourceType !== undefined && { SourceType: input.SourceType }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1CreateRoutingProfileCommand = async ( input: CreateRoutingProfileCommandInput, context: __SerdeContext @@ -633,6 +689,48 @@ export const serializeAws_restJson1CreateRoutingProfileCommand = async ( }); }; +export const serializeAws_restJson1CreateUseCaseCommand = async ( + input: CreateUseCaseCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations/{IntegrationAssociationId}/use-cases"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + if (input.IntegrationAssociationId !== undefined) { + const labelValue: string = input.IntegrationAssociationId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: IntegrationAssociationId."); + } + resolvedPath = resolvedPath.replace("{IntegrationAssociationId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: IntegrationAssociationId."); + } + let body: any; + body = JSON.stringify({ + ...(input.UseCaseType !== undefined && { UseCaseType: input.UseCaseType }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1CreateUserCommand = async ( input: CreateUserCommandInput, context: __SerdeContext @@ -744,6 +842,93 @@ export const serializeAws_restJson1DeleteInstanceCommand = async ( }); }; +export const serializeAws_restJson1DeleteIntegrationAssociationCommand = async ( + input: DeleteIntegrationAssociationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations/{IntegrationAssociationId}"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + if (input.IntegrationAssociationId !== undefined) { + const labelValue: string = input.IntegrationAssociationId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: IntegrationAssociationId."); + } + resolvedPath = resolvedPath.replace("{IntegrationAssociationId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: IntegrationAssociationId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteUseCaseCommand = async ( + input: DeleteUseCaseCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations/{IntegrationAssociationId}/use-cases/{UseCaseId}"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + if (input.IntegrationAssociationId !== undefined) { + const labelValue: string = input.IntegrationAssociationId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: IntegrationAssociationId."); + } + resolvedPath = resolvedPath.replace("{IntegrationAssociationId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: IntegrationAssociationId."); + } + if (input.UseCaseId !== undefined) { + const labelValue: string = input.UseCaseId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: UseCaseId."); + } + resolvedPath = resolvedPath.replace("{UseCaseId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: UseCaseId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1DeleteUserCommand = async ( input: DeleteUserCommandInput, context: __SerdeContext @@ -1703,6 +1888,41 @@ export const serializeAws_restJson1ListInstanceStorageConfigsCommand = async ( }); }; +export const serializeAws_restJson1ListIntegrationAssociationsCommand = async ( + input: ListIntegrationAssociationsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + export const serializeAws_restJson1ListLambdaFunctionsCommand = async ( input: ListLambdaFunctionsCommandInput, context: __SerdeContext @@ -2064,6 +2284,50 @@ export const serializeAws_restJson1ListTagsForResourceCommand = async ( }); }; +export const serializeAws_restJson1ListUseCasesCommand = async ( + input: ListUseCasesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/instance/{InstanceId}/integration-associations/{IntegrationAssociationId}/use-cases"; + if (input.InstanceId !== undefined) { + const labelValue: string = input.InstanceId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InstanceId."); + } + resolvedPath = resolvedPath.replace("{InstanceId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InstanceId."); + } + if (input.IntegrationAssociationId !== undefined) { + const labelValue: string = input.IntegrationAssociationId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: IntegrationAssociationId."); + } + resolvedPath = resolvedPath.replace("{IntegrationAssociationId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: IntegrationAssociationId."); + } + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + export const serializeAws_restJson1ListUserHierarchyGroupsCommand = async ( input: ListUserHierarchyGroupsCommandInput, context: __SerdeContext @@ -2255,6 +2519,39 @@ export const serializeAws_restJson1StartOutboundVoiceContactCommand = async ( }); }; +export const serializeAws_restJson1StartTaskContactCommand = async ( + input: StartTaskContactCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/contact/task"; + let body: any; + body = JSON.stringify({ + ...(input.Attributes !== undefined && { Attributes: serializeAws_restJson1Attributes(input.Attributes, context) }), + ClientToken: input.ClientToken ?? generateIdempotencyToken(), + ...(input.ContactFlowId !== undefined && { ContactFlowId: input.ContactFlowId }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.InstanceId !== undefined && { InstanceId: input.InstanceId }), + ...(input.Name !== undefined && { Name: input.Name }), + ...(input.PreviousContactId !== undefined && { PreviousContactId: input.PreviousContactId }), + ...(input.References !== undefined && { + References: serializeAws_restJson1ContactReferences(input.References, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1StopContactCommand = async ( input: StopContactCommandInput, context: __SerdeContext @@ -3850,32 +4147,32 @@ const deserializeAws_restJson1CreateInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_restJson1CreateRoutingProfileCommand = async ( +export const deserializeAws_restJson1CreateIntegrationAssociationCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode !== 200 && output.statusCode >= 300) { - return deserializeAws_restJson1CreateRoutingProfileCommandError(output, context); + return deserializeAws_restJson1CreateIntegrationAssociationCommandError(output, context); } - const contents: CreateRoutingProfileCommandOutput = { + const contents: CreateIntegrationAssociationCommandOutput = { $metadata: deserializeMetadata(output), - RoutingProfileArn: undefined, - RoutingProfileId: undefined, + IntegrationAssociationArn: undefined, + IntegrationAssociationId: undefined, }; const data: any = await parseBody(output.body, context); - if (data.RoutingProfileArn !== undefined && data.RoutingProfileArn !== null) { - contents.RoutingProfileArn = data.RoutingProfileArn; + if (data.IntegrationAssociationArn !== undefined && data.IntegrationAssociationArn !== null) { + contents.IntegrationAssociationArn = data.IntegrationAssociationArn; } - if (data.RoutingProfileId !== undefined && data.RoutingProfileId !== null) { - contents.RoutingProfileId = data.RoutingProfileId; + if (data.IntegrationAssociationId !== undefined && data.IntegrationAssociationId !== null) { + contents.IntegrationAssociationId = data.IntegrationAssociationId; } return Promise.resolve(contents); }; -const deserializeAws_restJson1CreateRoutingProfileCommandError = async ( +const deserializeAws_restJson1CreateIntegrationAssociationCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -3900,14 +4197,6 @@ const deserializeAws_restJson1CreateRoutingProfileCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "InvalidParameterException": - case "com.amazonaws.connect#InvalidParameterException": - response = { - ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "InvalidRequestException": case "com.amazonaws.connect#InvalidRequestException": response = { @@ -3916,14 +4205,6 @@ const deserializeAws_restJson1CreateRoutingProfileCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "LimitExceededException": - case "com.amazonaws.connect#LimitExceededException": - response = { - ...(await deserializeAws_restJson1LimitExceededExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "ResourceNotFoundException": case "com.amazonaws.connect#ResourceNotFoundException": response = { @@ -3957,7 +4238,205 @@ const deserializeAws_restJson1CreateRoutingProfileCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_restJson1CreateUserCommand = async ( +export const deserializeAws_restJson1CreateRoutingProfileCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateRoutingProfileCommandError(output, context); + } + const contents: CreateRoutingProfileCommandOutput = { + $metadata: deserializeMetadata(output), + RoutingProfileArn: undefined, + RoutingProfileId: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.RoutingProfileArn !== undefined && data.RoutingProfileArn !== null) { + contents.RoutingProfileArn = data.RoutingProfileArn; + } + if (data.RoutingProfileId !== undefined && data.RoutingProfileId !== null) { + contents.RoutingProfileId = data.RoutingProfileId; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateRoutingProfileCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "DuplicateResourceException": + case "com.amazonaws.connect#DuplicateResourceException": + response = { + ...(await deserializeAws_restJson1DuplicateResourceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.connect#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LimitExceededException": + case "com.amazonaws.connect#LimitExceededException": + response = { + ...(await deserializeAws_restJson1LimitExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateUseCaseCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateUseCaseCommandError(output, context); + } + const contents: CreateUseCaseCommandOutput = { + $metadata: deserializeMetadata(output), + UseCaseArn: undefined, + UseCaseId: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.UseCaseArn !== undefined && data.UseCaseArn !== null) { + contents.UseCaseArn = data.UseCaseArn; + } + if (data.UseCaseId !== undefined && data.UseCaseId !== null) { + contents.UseCaseId = data.UseCaseId; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateUseCaseCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "DuplicateResourceException": + case "com.amazonaws.connect#DuplicateResourceException": + response = { + ...(await deserializeAws_restJson1DuplicateResourceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateUserCommand = async ( output: __HttpResponse, context: __SerdeContext ): Promise => { @@ -4238,6 +4717,156 @@ const deserializeAws_restJson1DeleteInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1DeleteIntegrationAssociationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteIntegrationAssociationCommandError(output, context); + } + const contents: DeleteIntegrationAssociationCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteIntegrationAssociationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteUseCaseCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteUseCaseCommandError(output, context); + } + const contents: DeleteUseCaseCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteUseCaseCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1DeleteUserCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -6327,25 +6956,92 @@ export const deserializeAws_restJson1ListInstancesCommand = async ( if (output.statusCode !== 200 && output.statusCode >= 300) { return deserializeAws_restJson1ListInstancesCommandError(output, context); } - const contents: ListInstancesCommandOutput = { + const contents: ListInstancesCommandOutput = { + $metadata: deserializeMetadata(output), + InstanceSummaryList: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.InstanceSummaryList !== undefined && data.InstanceSummaryList !== null) { + contents.InstanceSummaryList = deserializeAws_restJson1InstanceSummaryList(data.InstanceSummaryList, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListInstancesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListInstanceStorageConfigsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListInstanceStorageConfigsCommandError(output, context); + } + const contents: ListInstanceStorageConfigsCommandOutput = { $metadata: deserializeMetadata(output), - InstanceSummaryList: undefined, NextToken: undefined, + StorageConfigs: undefined, }; const data: any = await parseBody(output.body, context); - if (data.InstanceSummaryList !== undefined && data.InstanceSummaryList !== null) { - contents.InstanceSummaryList = deserializeAws_restJson1InstanceSummaryList(data.InstanceSummaryList, context); - } if (data.NextToken !== undefined && data.NextToken !== null) { contents.NextToken = data.NextToken; } + if (data.StorageConfigs !== undefined && data.StorageConfigs !== null) { + contents.StorageConfigs = deserializeAws_restJson1InstanceStorageConfigs(data.StorageConfigs, context); + } return Promise.resolve(contents); }; -const deserializeAws_restJson1ListInstancesCommandError = async ( +const deserializeAws_restJson1ListInstanceStorageConfigsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6362,6 +7058,14 @@ const deserializeAws_restJson1ListInstancesCommandError = async ( $metadata: deserializeMetadata(output), }; break; + case "InvalidParameterException": + case "com.amazonaws.connect#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "InvalidRequestException": case "com.amazonaws.connect#InvalidRequestException": response = { @@ -6370,6 +7074,22 @@ const deserializeAws_restJson1ListInstancesCommandError = async ( $metadata: deserializeMetadata(output), }; break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6387,32 +7107,35 @@ const deserializeAws_restJson1ListInstancesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_restJson1ListInstanceStorageConfigsCommand = async ( +export const deserializeAws_restJson1ListIntegrationAssociationsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode !== 200 && output.statusCode >= 300) { - return deserializeAws_restJson1ListInstanceStorageConfigsCommandError(output, context); + return deserializeAws_restJson1ListIntegrationAssociationsCommandError(output, context); } - const contents: ListInstanceStorageConfigsCommandOutput = { + const contents: ListIntegrationAssociationsCommandOutput = { $metadata: deserializeMetadata(output), + IntegrationAssociationSummaryList: undefined, NextToken: undefined, - StorageConfigs: undefined, }; const data: any = await parseBody(output.body, context); + if (data.IntegrationAssociationSummaryList !== undefined && data.IntegrationAssociationSummaryList !== null) { + contents.IntegrationAssociationSummaryList = deserializeAws_restJson1IntegrationAssociationSummaryList( + data.IntegrationAssociationSummaryList, + context + ); + } if (data.NextToken !== undefined && data.NextToken !== null) { contents.NextToken = data.NextToken; } - if (data.StorageConfigs !== undefined && data.StorageConfigs !== null) { - contents.StorageConfigs = deserializeAws_restJson1InstanceStorageConfigs(data.StorageConfigs, context); - } return Promise.resolve(contents); }; -const deserializeAws_restJson1ListInstanceStorageConfigsCommandError = async ( +const deserializeAws_restJson1ListIntegrationAssociationsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6429,14 +7152,6 @@ const deserializeAws_restJson1ListInstanceStorageConfigsCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "InvalidParameterException": - case "com.amazonaws.connect#InvalidParameterException": - response = { - ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "InvalidRequestException": case "com.amazonaws.connect#InvalidRequestException": response = { @@ -7396,6 +8111,89 @@ const deserializeAws_restJson1ListTagsForResourceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1ListUseCasesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListUseCasesCommandError(output, context); + } + const contents: ListUseCasesCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + UseCaseSummaryList: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.UseCaseSummaryList !== undefined && data.UseCaseSummaryList !== null) { + contents.UseCaseSummaryList = deserializeAws_restJson1UseCaseSummaryList(data.UseCaseSummaryList, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListUseCasesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1ListUserHierarchyGroupsCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -7921,6 +8719,101 @@ const deserializeAws_restJson1StartOutboundVoiceContactCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1StartTaskContactCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1StartTaskContactCommandError(output, context); + } + const contents: StartTaskContactCommandOutput = { + $metadata: deserializeMetadata(output), + ContactId: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ContactId !== undefined && data.ContactId !== null) { + contents.ContactId = data.ContactId; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1StartTaskContactCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InternalServiceException": + case "com.amazonaws.connect#InternalServiceException": + response = { + ...(await deserializeAws_restJson1InternalServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.connect#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.connect#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.connect#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.connect#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.connect#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1StopContactCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -9965,6 +10858,16 @@ const serializeAws_restJson1ChatMessage = (input: ChatMessage, context: __SerdeC }; }; +const serializeAws_restJson1ContactReferences = (input: { [key: string]: Reference }, context: __SerdeContext): any => { + return Object.entries(input).reduce( + (acc: { [key: string]: Reference }, [key, value]: [string, any]) => ({ + ...acc, + [key]: serializeAws_restJson1Reference(value, context), + }), + {} + ); +}; + const serializeAws_restJson1CurrentMetric = (input: CurrentMetric, context: __SerdeContext): any => { return { ...(input.Name !== undefined && { Name: input.Name }), @@ -10106,6 +11009,13 @@ const serializeAws_restJson1Queues = (input: string[], context: __SerdeContext): return input.map((entry) => entry); }; +const serializeAws_restJson1Reference = (input: Reference, context: __SerdeContext): any => { + return { + ...(input.Type !== undefined && { Type: input.Type }), + ...(input.Value !== undefined && { Value: input.Value }), + }; +}; + const serializeAws_restJson1RoutingProfileQueueConfig = ( input: RoutingProfileQueueConfig, context: __SerdeContext @@ -10588,6 +11498,43 @@ const deserializeAws_restJson1InstanceSummaryList = (output: any, context: __Ser return (output || []).map((entry: any) => deserializeAws_restJson1InstanceSummary(entry, context)); }; +const deserializeAws_restJson1IntegrationAssociationSummary = ( + output: any, + context: __SerdeContext +): IntegrationAssociationSummary => { + return { + InstanceId: output.InstanceId !== undefined && output.InstanceId !== null ? output.InstanceId : undefined, + IntegrationArn: + output.IntegrationArn !== undefined && output.IntegrationArn !== null ? output.IntegrationArn : undefined, + IntegrationAssociationArn: + output.IntegrationAssociationArn !== undefined && output.IntegrationAssociationArn !== null + ? output.IntegrationAssociationArn + : undefined, + IntegrationAssociationId: + output.IntegrationAssociationId !== undefined && output.IntegrationAssociationId !== null + ? output.IntegrationAssociationId + : undefined, + IntegrationType: + output.IntegrationType !== undefined && output.IntegrationType !== null ? output.IntegrationType : undefined, + SourceApplicationName: + output.SourceApplicationName !== undefined && output.SourceApplicationName !== null + ? output.SourceApplicationName + : undefined, + SourceApplicationUrl: + output.SourceApplicationUrl !== undefined && output.SourceApplicationUrl !== null + ? output.SourceApplicationUrl + : undefined, + SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, + } as any; +}; + +const deserializeAws_restJson1IntegrationAssociationSummaryList = ( + output: any, + context: __SerdeContext +): IntegrationAssociationSummary[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1IntegrationAssociationSummary(entry, context)); +}; + const deserializeAws_restJson1KinesisFirehoseConfig = (output: any, context: __SerdeContext): KinesisFirehoseConfig => { return { FirehoseArn: output.FirehoseArn !== undefined && output.FirehoseArn !== null ? output.FirehoseArn : undefined, @@ -10832,6 +11779,18 @@ const deserializeAws_restJson1Threshold = (output: any, context: __SerdeContext) } as any; }; +const deserializeAws_restJson1UseCase = (output: any, context: __SerdeContext): UseCase => { + return { + UseCaseArn: output.UseCaseArn !== undefined && output.UseCaseArn !== null ? output.UseCaseArn : undefined, + UseCaseId: output.UseCaseId !== undefined && output.UseCaseId !== null ? output.UseCaseId : undefined, + UseCaseType: output.UseCaseType !== undefined && output.UseCaseType !== null ? output.UseCaseType : undefined, + } as any; +}; + +const deserializeAws_restJson1UseCaseSummaryList = (output: any, context: __SerdeContext): UseCase[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1UseCase(entry, context)); +}; + const deserializeAws_restJson1User = (output: any, context: __SerdeContext): User => { return { Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, diff --git a/clients/client-devops-guru/.gitignore b/clients/client-devops-guru/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-devops-guru/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-devops-guru/.npmignore b/clients/client-devops-guru/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-devops-guru/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-devops-guru/DevOpsGuru.ts b/clients/client-devops-guru/DevOpsGuru.ts new file mode 100644 index 000000000000..d68485eb7c3a --- /dev/null +++ b/clients/client-devops-guru/DevOpsGuru.ts @@ -0,0 +1,720 @@ +import { DevOpsGuruClient } from "./DevOpsGuruClient"; +import { + AddNotificationChannelCommand, + AddNotificationChannelCommandInput, + AddNotificationChannelCommandOutput, +} from "./commands/AddNotificationChannelCommand"; +import { + DescribeAccountHealthCommand, + DescribeAccountHealthCommandInput, + DescribeAccountHealthCommandOutput, +} from "./commands/DescribeAccountHealthCommand"; +import { + DescribeAccountOverviewCommand, + DescribeAccountOverviewCommandInput, + DescribeAccountOverviewCommandOutput, +} from "./commands/DescribeAccountOverviewCommand"; +import { + DescribeAnomalyCommand, + DescribeAnomalyCommandInput, + DescribeAnomalyCommandOutput, +} from "./commands/DescribeAnomalyCommand"; +import { + DescribeInsightCommand, + DescribeInsightCommandInput, + DescribeInsightCommandOutput, +} from "./commands/DescribeInsightCommand"; +import { + DescribeResourceCollectionHealthCommand, + DescribeResourceCollectionHealthCommandInput, + DescribeResourceCollectionHealthCommandOutput, +} from "./commands/DescribeResourceCollectionHealthCommand"; +import { + DescribeServiceIntegrationCommand, + DescribeServiceIntegrationCommandInput, + DescribeServiceIntegrationCommandOutput, +} from "./commands/DescribeServiceIntegrationCommand"; +import { + GetResourceCollectionCommand, + GetResourceCollectionCommandInput, + GetResourceCollectionCommandOutput, +} from "./commands/GetResourceCollectionCommand"; +import { + ListAnomaliesForInsightCommand, + ListAnomaliesForInsightCommandInput, + ListAnomaliesForInsightCommandOutput, +} from "./commands/ListAnomaliesForInsightCommand"; +import { ListEventsCommand, ListEventsCommandInput, ListEventsCommandOutput } from "./commands/ListEventsCommand"; +import { + ListInsightsCommand, + ListInsightsCommandInput, + ListInsightsCommandOutput, +} from "./commands/ListInsightsCommand"; +import { + ListNotificationChannelsCommand, + ListNotificationChannelsCommandInput, + ListNotificationChannelsCommandOutput, +} from "./commands/ListNotificationChannelsCommand"; +import { + ListRecommendationsCommand, + ListRecommendationsCommandInput, + ListRecommendationsCommandOutput, +} from "./commands/ListRecommendationsCommand"; +import { PutFeedbackCommand, PutFeedbackCommandInput, PutFeedbackCommandOutput } from "./commands/PutFeedbackCommand"; +import { + RemoveNotificationChannelCommand, + RemoveNotificationChannelCommandInput, + RemoveNotificationChannelCommandOutput, +} from "./commands/RemoveNotificationChannelCommand"; +import { + SearchInsightsCommand, + SearchInsightsCommandInput, + SearchInsightsCommandOutput, +} from "./commands/SearchInsightsCommand"; +import { + UpdateResourceCollectionCommand, + UpdateResourceCollectionCommandInput, + UpdateResourceCollectionCommandOutput, +} from "./commands/UpdateResourceCollectionCommand"; +import { + UpdateServiceIntegrationCommand, + UpdateServiceIntegrationCommandInput, + UpdateServiceIntegrationCommandOutput, +} from "./commands/UpdateServiceIntegrationCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

Amazon DevOps Guru is a fully managed service that helps you identify anomalous behavior in business + * critical operational applications. You specify the AWS resources that you want DevOps Guru to cover, + * then the Amazon CloudWatch metrics and AWS CloudTrail events related to those resources are analyzed. When + * anomalous behavior is detected, DevOps Guru creates an insight that includes + * recommendations, related events, and related metrics that can help you improve your + * operational applications. For more information, see What is Amazon DevOps Guru.

+ * + *

+ * You can specify 1 or 2 Amazon Simple Notification Service topics so you are notified every time a new insight is created. You can also enable DevOps Guru to generate + * an OpsItem in AWS Systems Manager for each insight to help you manage and track your work addressing insights. + *

+ * + *

+ * To learn about the DevOps Guru workflow, see How DevOps Guru works. To + * learn about DevOps Guru concepts, see Concepts in DevOps Guru. + *

+ */ +export class DevOpsGuru extends DevOpsGuruClient { + /** + *

+ * Adds a notification channel to DevOps Guru. A notification channel is used to notify you about important DevOps Guru events, such as when an insight is generated. + *

+ */ + public addNotificationChannel( + args: AddNotificationChannelCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public addNotificationChannel( + args: AddNotificationChannelCommandInput, + cb: (err: any, data?: AddNotificationChannelCommandOutput) => void + ): void; + public addNotificationChannel( + args: AddNotificationChannelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: AddNotificationChannelCommandOutput) => void + ): void; + public addNotificationChannel( + args: AddNotificationChannelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: AddNotificationChannelCommandOutput) => void), + cb?: (err: any, data?: AddNotificationChannelCommandOutput) => void + ): Promise | void { + const command = new AddNotificationChannelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns the number of open reactive insights, the number of open proactive insights, and the number of metrics analyzed in your AWS account. + * Use these numbers to gauge the health of operations in your AWS account. + *

+ */ + public describeAccountHealth( + args: DescribeAccountHealthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAccountHealth( + args: DescribeAccountHealthCommandInput, + cb: (err: any, data?: DescribeAccountHealthCommandOutput) => void + ): void; + public describeAccountHealth( + args: DescribeAccountHealthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeAccountHealthCommandOutput) => void + ): void; + public describeAccountHealth( + args: DescribeAccountHealthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeAccountHealthCommandOutput) => void), + cb?: (err: any, data?: DescribeAccountHealthCommandOutput) => void + ): Promise | void { + const command = new DescribeAccountHealthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * For the time range passed in, returns the number of open reactive insight that were created, the number of open proactive insights + * that were created, and the Mean Time to Recover (MTTR) for all closed reactive insights. + *

+ */ + public describeAccountOverview( + args: DescribeAccountOverviewCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAccountOverview( + args: DescribeAccountOverviewCommandInput, + cb: (err: any, data?: DescribeAccountOverviewCommandOutput) => void + ): void; + public describeAccountOverview( + args: DescribeAccountOverviewCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeAccountOverviewCommandOutput) => void + ): void; + public describeAccountOverview( + args: DescribeAccountOverviewCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeAccountOverviewCommandOutput) => void), + cb?: (err: any, data?: DescribeAccountOverviewCommandOutput) => void + ): Promise | void { + const command = new DescribeAccountOverviewCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns details about an anomaly that you specify using its ID. + *

+ */ + public describeAnomaly( + args: DescribeAnomalyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAnomaly( + args: DescribeAnomalyCommandInput, + cb: (err: any, data?: DescribeAnomalyCommandOutput) => void + ): void; + public describeAnomaly( + args: DescribeAnomalyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeAnomalyCommandOutput) => void + ): void; + public describeAnomaly( + args: DescribeAnomalyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeAnomalyCommandOutput) => void), + cb?: (err: any, data?: DescribeAnomalyCommandOutput) => void + ): Promise | void { + const command = new DescribeAnomalyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns details about an insight that you specify using its ID. + *

+ */ + public describeInsight( + args: DescribeInsightCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeInsight( + args: DescribeInsightCommandInput, + cb: (err: any, data?: DescribeInsightCommandOutput) => void + ): void; + public describeInsight( + args: DescribeInsightCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeInsightCommandOutput) => void + ): void; + public describeInsight( + args: DescribeInsightCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeInsightCommandOutput) => void), + cb?: (err: any, data?: DescribeInsightCommandOutput) => void + ): Promise | void { + const command = new DescribeInsightCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns the number of open proactive insights, open reactive insights, and the Mean Time to Recover (MTTR) for all closed insights in + * resource collections in your account. You specify the type of AWS resources collection. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + public describeResourceCollectionHealth( + args: DescribeResourceCollectionHealthCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeResourceCollectionHealth( + args: DescribeResourceCollectionHealthCommandInput, + cb: (err: any, data?: DescribeResourceCollectionHealthCommandOutput) => void + ): void; + public describeResourceCollectionHealth( + args: DescribeResourceCollectionHealthCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeResourceCollectionHealthCommandOutput) => void + ): void; + public describeResourceCollectionHealth( + args: DescribeResourceCollectionHealthCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeResourceCollectionHealthCommandOutput) => void), + cb?: (err: any, data?: DescribeResourceCollectionHealthCommandOutput) => void + ): Promise | void { + const command = new DescribeResourceCollectionHealthCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns the integration status of services that are integrated with DevOps Guru. + * The one service that can be integrated with DevOps Guru + * is AWS Systems Manager, which can be used to create an OpsItem for each generated insight. + *

+ */ + public describeServiceIntegration( + args: DescribeServiceIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeServiceIntegration( + args: DescribeServiceIntegrationCommandInput, + cb: (err: any, data?: DescribeServiceIntegrationCommandOutput) => void + ): void; + public describeServiceIntegration( + args: DescribeServiceIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeServiceIntegrationCommandOutput) => void + ): void; + public describeServiceIntegration( + args: DescribeServiceIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeServiceIntegrationCommandOutput) => void), + cb?: (err: any, data?: DescribeServiceIntegrationCommandOutput) => void + ): Promise | void { + const command = new DescribeServiceIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns lists AWS resources that are of the specified resource collection type. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + public getResourceCollection( + args: GetResourceCollectionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getResourceCollection( + args: GetResourceCollectionCommandInput, + cb: (err: any, data?: GetResourceCollectionCommandOutput) => void + ): void; + public getResourceCollection( + args: GetResourceCollectionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetResourceCollectionCommandOutput) => void + ): void; + public getResourceCollection( + args: GetResourceCollectionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetResourceCollectionCommandOutput) => void), + cb?: (err: any, data?: GetResourceCollectionCommandOutput) => void + ): Promise | void { + const command = new GetResourceCollectionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of the anomalies that belong to an insight that you specify using its ID. + *

+ */ + public listAnomaliesForInsight( + args: ListAnomaliesForInsightCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listAnomaliesForInsight( + args: ListAnomaliesForInsightCommandInput, + cb: (err: any, data?: ListAnomaliesForInsightCommandOutput) => void + ): void; + public listAnomaliesForInsight( + args: ListAnomaliesForInsightCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListAnomaliesForInsightCommandOutput) => void + ): void; + public listAnomaliesForInsight( + args: ListAnomaliesForInsightCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListAnomaliesForInsightCommandOutput) => void), + cb?: (err: any, data?: ListAnomaliesForInsightCommandOutput) => void + ): Promise | void { + const command = new ListAnomaliesForInsightCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of the events emitted by the resources that are evaluated by DevOps Guru. You can use filters to specify which events are returned. + *

+ */ + public listEvents(args: ListEventsCommandInput, options?: __HttpHandlerOptions): Promise; + public listEvents(args: ListEventsCommandInput, cb: (err: any, data?: ListEventsCommandOutput) => void): void; + public listEvents( + args: ListEventsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListEventsCommandOutput) => void + ): void; + public listEvents( + args: ListEventsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListEventsCommandOutput) => void), + cb?: (err: any, data?: ListEventsCommandOutput) => void + ): Promise | void { + const command = new ListEventsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of insights in your AWS account. You can specify which insights are returned by their start time and + * status (ONGOING, CLOSED, or ANY). + *

+ */ + public listInsights( + args: ListInsightsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listInsights(args: ListInsightsCommandInput, cb: (err: any, data?: ListInsightsCommandOutput) => void): void; + public listInsights( + args: ListInsightsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListInsightsCommandOutput) => void + ): void; + public listInsights( + args: ListInsightsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListInsightsCommandOutput) => void), + cb?: (err: any, data?: ListInsightsCommandOutput) => void + ): Promise | void { + const command = new ListInsightsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of notification channels configured for DevOps Guru. Each notification channel is used to notify you when + * DevOps Guru generates an insight that contains information about how to improve your operations. The one + * supported notification channel is Amazon Simple Notification Service (Amazon SNS). + *

+ */ + public listNotificationChannels( + args: ListNotificationChannelsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listNotificationChannels( + args: ListNotificationChannelsCommandInput, + cb: (err: any, data?: ListNotificationChannelsCommandOutput) => void + ): void; + public listNotificationChannels( + args: ListNotificationChannelsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListNotificationChannelsCommandOutput) => void + ): void; + public listNotificationChannels( + args: ListNotificationChannelsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListNotificationChannelsCommandOutput) => void), + cb?: (err: any, data?: ListNotificationChannelsCommandOutput) => void + ): Promise | void { + const command = new ListNotificationChannelsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of a specified insight's recommendations. Each recommendation includes a list of related metrics and a list of related events. + *

+ */ + public listRecommendations( + args: ListRecommendationsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listRecommendations( + args: ListRecommendationsCommandInput, + cb: (err: any, data?: ListRecommendationsCommandOutput) => void + ): void; + public listRecommendations( + args: ListRecommendationsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListRecommendationsCommandOutput) => void + ): void; + public listRecommendations( + args: ListRecommendationsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListRecommendationsCommandOutput) => void), + cb?: (err: any, data?: ListRecommendationsCommandOutput) => void + ): Promise | void { + const command = new ListRecommendationsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Collects customer feedback about the specified insight. + *

+ */ + public putFeedback(args: PutFeedbackCommandInput, options?: __HttpHandlerOptions): Promise; + public putFeedback(args: PutFeedbackCommandInput, cb: (err: any, data?: PutFeedbackCommandOutput) => void): void; + public putFeedback( + args: PutFeedbackCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutFeedbackCommandOutput) => void + ): void; + public putFeedback( + args: PutFeedbackCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutFeedbackCommandOutput) => void), + cb?: (err: any, data?: PutFeedbackCommandOutput) => void + ): Promise | void { + const command = new PutFeedbackCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Removes a notification channel from DevOps Guru. A notification channel is used to notify you when DevOps Guru generates an insight + * that contains information about how to improve your operations. + *

+ */ + public removeNotificationChannel( + args: RemoveNotificationChannelCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public removeNotificationChannel( + args: RemoveNotificationChannelCommandInput, + cb: (err: any, data?: RemoveNotificationChannelCommandOutput) => void + ): void; + public removeNotificationChannel( + args: RemoveNotificationChannelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: RemoveNotificationChannelCommandOutput) => void + ): void; + public removeNotificationChannel( + args: RemoveNotificationChannelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: RemoveNotificationChannelCommandOutput) => void), + cb?: (err: any, data?: RemoveNotificationChannelCommandOutput) => void + ): Promise | void { + const command = new RemoveNotificationChannelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Returns a list of insights in your AWS account. You can specify which insights are returned by their start time, one or more statuses + * (ONGOING, CLOSED, and CLOSED), one or more severities (LOW, MEDIUM, + * and HIGH), and type (REACTIVE or PROACTIVE). + *

+ *

+ * Use the Filters parameter to specify status and severity + * search parameters. Use the Type parameter to specify REACTIVE or PROACTIVE in your search. + *

+ */ + public searchInsights( + args: SearchInsightsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public searchInsights( + args: SearchInsightsCommandInput, + cb: (err: any, data?: SearchInsightsCommandOutput) => void + ): void; + public searchInsights( + args: SearchInsightsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: SearchInsightsCommandOutput) => void + ): void; + public searchInsights( + args: SearchInsightsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: SearchInsightsCommandOutput) => void), + cb?: (err: any, data?: SearchInsightsCommandOutput) => void + ): Promise | void { + const command = new SearchInsightsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

Updates the collection of resources that DevOps Guru analyzes. + * The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. This method also creates the IAM role required for you + * to use DevOps Guru.

+ */ + public updateResourceCollection( + args: UpdateResourceCollectionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateResourceCollection( + args: UpdateResourceCollectionCommandInput, + cb: (err: any, data?: UpdateResourceCollectionCommandOutput) => void + ): void; + public updateResourceCollection( + args: UpdateResourceCollectionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateResourceCollectionCommandOutput) => void + ): void; + public updateResourceCollection( + args: UpdateResourceCollectionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateResourceCollectionCommandOutput) => void), + cb?: (err: any, data?: UpdateResourceCollectionCommandOutput) => void + ): Promise | void { + const command = new UpdateResourceCollectionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

+ * Enables or disables integration with a service that can be integrated with DevOps Guru. The one service that can be integrated with + * DevOps Guru is AWS Systems Manager, which can be used to create an OpsItem for each generated insight. + *

+ */ + public updateServiceIntegration( + args: UpdateServiceIntegrationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateServiceIntegration( + args: UpdateServiceIntegrationCommandInput, + cb: (err: any, data?: UpdateServiceIntegrationCommandOutput) => void + ): void; + public updateServiceIntegration( + args: UpdateServiceIntegrationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateServiceIntegrationCommandOutput) => void + ): void; + public updateServiceIntegration( + args: UpdateServiceIntegrationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateServiceIntegrationCommandOutput) => void), + cb?: (err: any, data?: UpdateServiceIntegrationCommandOutput) => void + ): Promise | void { + const command = new UpdateServiceIntegrationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-devops-guru/DevOpsGuruClient.ts b/clients/client-devops-guru/DevOpsGuruClient.ts new file mode 100644 index 000000000000..176dfaff77e7 --- /dev/null +++ b/clients/client-devops-guru/DevOpsGuruClient.ts @@ -0,0 +1,306 @@ +import { + AddNotificationChannelCommandInput, + AddNotificationChannelCommandOutput, +} from "./commands/AddNotificationChannelCommand"; +import { + DescribeAccountHealthCommandInput, + DescribeAccountHealthCommandOutput, +} from "./commands/DescribeAccountHealthCommand"; +import { + DescribeAccountOverviewCommandInput, + DescribeAccountOverviewCommandOutput, +} from "./commands/DescribeAccountOverviewCommand"; +import { DescribeAnomalyCommandInput, DescribeAnomalyCommandOutput } from "./commands/DescribeAnomalyCommand"; +import { DescribeInsightCommandInput, DescribeInsightCommandOutput } from "./commands/DescribeInsightCommand"; +import { + DescribeResourceCollectionHealthCommandInput, + DescribeResourceCollectionHealthCommandOutput, +} from "./commands/DescribeResourceCollectionHealthCommand"; +import { + DescribeServiceIntegrationCommandInput, + DescribeServiceIntegrationCommandOutput, +} from "./commands/DescribeServiceIntegrationCommand"; +import { + GetResourceCollectionCommandInput, + GetResourceCollectionCommandOutput, +} from "./commands/GetResourceCollectionCommand"; +import { + ListAnomaliesForInsightCommandInput, + ListAnomaliesForInsightCommandOutput, +} from "./commands/ListAnomaliesForInsightCommand"; +import { ListEventsCommandInput, ListEventsCommandOutput } from "./commands/ListEventsCommand"; +import { ListInsightsCommandInput, ListInsightsCommandOutput } from "./commands/ListInsightsCommand"; +import { + ListNotificationChannelsCommandInput, + ListNotificationChannelsCommandOutput, +} from "./commands/ListNotificationChannelsCommand"; +import { + ListRecommendationsCommandInput, + ListRecommendationsCommandOutput, +} from "./commands/ListRecommendationsCommand"; +import { PutFeedbackCommandInput, PutFeedbackCommandOutput } from "./commands/PutFeedbackCommand"; +import { + RemoveNotificationChannelCommandInput, + RemoveNotificationChannelCommandOutput, +} from "./commands/RemoveNotificationChannelCommand"; +import { SearchInsightsCommandInput, SearchInsightsCommandOutput } from "./commands/SearchInsightsCommand"; +import { + UpdateResourceCollectionCommandInput, + UpdateResourceCollectionCommandOutput, +} from "./commands/UpdateResourceCollectionCommand"; +import { + UpdateServiceIntegrationCommandInput, + UpdateServiceIntegrationCommandOutput, +} from "./commands/UpdateServiceIntegrationCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = + | AddNotificationChannelCommandInput + | DescribeAccountHealthCommandInput + | DescribeAccountOverviewCommandInput + | DescribeAnomalyCommandInput + | DescribeInsightCommandInput + | DescribeResourceCollectionHealthCommandInput + | DescribeServiceIntegrationCommandInput + | GetResourceCollectionCommandInput + | ListAnomaliesForInsightCommandInput + | ListEventsCommandInput + | ListInsightsCommandInput + | ListNotificationChannelsCommandInput + | ListRecommendationsCommandInput + | PutFeedbackCommandInput + | RemoveNotificationChannelCommandInput + | SearchInsightsCommandInput + | UpdateResourceCollectionCommandInput + | UpdateServiceIntegrationCommandInput; + +export type ServiceOutputTypes = + | AddNotificationChannelCommandOutput + | DescribeAccountHealthCommandOutput + | DescribeAccountOverviewCommandOutput + | DescribeAnomalyCommandOutput + | DescribeInsightCommandOutput + | DescribeResourceCollectionHealthCommandOutput + | DescribeServiceIntegrationCommandOutput + | GetResourceCollectionCommandOutput + | ListAnomaliesForInsightCommandOutput + | ListEventsCommandOutput + | ListInsightsCommandOutput + | ListNotificationChannelsCommandOutput + | ListRecommendationsCommandOutput + | PutFeedbackCommandOutput + | RemoveNotificationChannelCommandOutput + | SearchInsightsCommandOutput + | UpdateResourceCollectionCommandOutput + | UpdateServiceIntegrationCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type DevOpsGuruClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type DevOpsGuruClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

Amazon DevOps Guru is a fully managed service that helps you identify anomalous behavior in business + * critical operational applications. You specify the AWS resources that you want DevOps Guru to cover, + * then the Amazon CloudWatch metrics and AWS CloudTrail events related to those resources are analyzed. When + * anomalous behavior is detected, DevOps Guru creates an insight that includes + * recommendations, related events, and related metrics that can help you improve your + * operational applications. For more information, see What is Amazon DevOps Guru.

+ * + *

+ * You can specify 1 or 2 Amazon Simple Notification Service topics so you are notified every time a new insight is created. You can also enable DevOps Guru to generate + * an OpsItem in AWS Systems Manager for each insight to help you manage and track your work addressing insights. + *

+ * + *

+ * To learn about the DevOps Guru workflow, see How DevOps Guru works. To + * learn about DevOps Guru concepts, see Concepts in DevOps Guru. + *

+ */ +export class DevOpsGuruClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + DevOpsGuruClientResolvedConfig +> { + readonly config: DevOpsGuruClientResolvedConfig; + + constructor(configuration: DevOpsGuruClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-devops-guru/LICENSE b/clients/client-devops-guru/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-devops-guru/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-devops-guru/README.md b/clients/client-devops-guru/README.md new file mode 100644 index 000000000000..e9b7bcb82652 --- /dev/null +++ b/clients/client-devops-guru/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-devops-guru + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-devops-guru/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-devops-guru) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-devops-guru.svg)](https://www.npmjs.com/package/@aws-sdk/client-devops-guru) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-devops-guru/commands/AddNotificationChannelCommand.ts b/clients/client-devops-guru/commands/AddNotificationChannelCommand.ts new file mode 100644 index 000000000000..89e8500a5481 --- /dev/null +++ b/clients/client-devops-guru/commands/AddNotificationChannelCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { AddNotificationChannelRequest, AddNotificationChannelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1AddNotificationChannelCommand, + serializeAws_restJson1AddNotificationChannelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type AddNotificationChannelCommandInput = AddNotificationChannelRequest; +export type AddNotificationChannelCommandOutput = AddNotificationChannelResponse & __MetadataBearer; + +/** + *

+ * Adds a notification channel to DevOps Guru. A notification channel is used to notify you about important DevOps Guru events, such as when an insight is generated. + *

+ */ +export class AddNotificationChannelCommand extends $Command< + AddNotificationChannelCommandInput, + AddNotificationChannelCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: AddNotificationChannelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "AddNotificationChannelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: AddNotificationChannelRequest.filterSensitiveLog, + outputFilterSensitiveLog: AddNotificationChannelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: AddNotificationChannelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1AddNotificationChannelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1AddNotificationChannelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeAccountHealthCommand.ts b/clients/client-devops-guru/commands/DescribeAccountHealthCommand.ts new file mode 100644 index 000000000000..7ff4e379be4f --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeAccountHealthCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeAccountHealthRequest, DescribeAccountHealthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeAccountHealthCommand, + serializeAws_restJson1DescribeAccountHealthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeAccountHealthCommandInput = DescribeAccountHealthRequest; +export type DescribeAccountHealthCommandOutput = DescribeAccountHealthResponse & __MetadataBearer; + +/** + *

+ * Returns the number of open reactive insights, the number of open proactive insights, and the number of metrics analyzed in your AWS account. + * Use these numbers to gauge the health of operations in your AWS account. + *

+ */ +export class DescribeAccountHealthCommand extends $Command< + DescribeAccountHealthCommandInput, + DescribeAccountHealthCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeAccountHealthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeAccountHealthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeAccountHealthRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeAccountHealthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeAccountHealthCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeAccountHealthCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeAccountHealthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeAccountOverviewCommand.ts b/clients/client-devops-guru/commands/DescribeAccountOverviewCommand.ts new file mode 100644 index 000000000000..6660de848f52 --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeAccountOverviewCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeAccountOverviewRequest, DescribeAccountOverviewResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeAccountOverviewCommand, + serializeAws_restJson1DescribeAccountOverviewCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeAccountOverviewCommandInput = DescribeAccountOverviewRequest; +export type DescribeAccountOverviewCommandOutput = DescribeAccountOverviewResponse & __MetadataBearer; + +/** + *

+ * For the time range passed in, returns the number of open reactive insight that were created, the number of open proactive insights + * that were created, and the Mean Time to Recover (MTTR) for all closed reactive insights. + *

+ */ +export class DescribeAccountOverviewCommand extends $Command< + DescribeAccountOverviewCommandInput, + DescribeAccountOverviewCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeAccountOverviewCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeAccountOverviewCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeAccountOverviewRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeAccountOverviewResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeAccountOverviewCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeAccountOverviewCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeAccountOverviewCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeAnomalyCommand.ts b/clients/client-devops-guru/commands/DescribeAnomalyCommand.ts new file mode 100644 index 000000000000..b0bd3495a476 --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeAnomalyCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeAnomalyRequest, DescribeAnomalyResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeAnomalyCommand, + serializeAws_restJson1DescribeAnomalyCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeAnomalyCommandInput = DescribeAnomalyRequest; +export type DescribeAnomalyCommandOutput = DescribeAnomalyResponse & __MetadataBearer; + +/** + *

+ * Returns details about an anomaly that you specify using its ID. + *

+ */ +export class DescribeAnomalyCommand extends $Command< + DescribeAnomalyCommandInput, + DescribeAnomalyCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeAnomalyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeAnomalyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeAnomalyRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeAnomalyResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeAnomalyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeAnomalyCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeAnomalyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeInsightCommand.ts b/clients/client-devops-guru/commands/DescribeInsightCommand.ts new file mode 100644 index 000000000000..81eeb27cf421 --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeInsightCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeInsightRequest, DescribeInsightResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeInsightCommand, + serializeAws_restJson1DescribeInsightCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeInsightCommandInput = DescribeInsightRequest; +export type DescribeInsightCommandOutput = DescribeInsightResponse & __MetadataBearer; + +/** + *

+ * Returns details about an insight that you specify using its ID. + *

+ */ +export class DescribeInsightCommand extends $Command< + DescribeInsightCommandInput, + DescribeInsightCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeInsightCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeInsightCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeInsightRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeInsightResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeInsightCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeInsightCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeInsightCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeResourceCollectionHealthCommand.ts b/clients/client-devops-guru/commands/DescribeResourceCollectionHealthCommand.ts new file mode 100644 index 000000000000..75ce2e8a7892 --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeResourceCollectionHealthCommand.ts @@ -0,0 +1,98 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeResourceCollectionHealthRequest, DescribeResourceCollectionHealthResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeResourceCollectionHealthCommand, + serializeAws_restJson1DescribeResourceCollectionHealthCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeResourceCollectionHealthCommandInput = DescribeResourceCollectionHealthRequest; +export type DescribeResourceCollectionHealthCommandOutput = DescribeResourceCollectionHealthResponse & __MetadataBearer; + +/** + *

+ * Returns the number of open proactive insights, open reactive insights, and the Mean Time to Recover (MTTR) for all closed insights in + * resource collections in your account. You specify the type of AWS resources collection. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ +export class DescribeResourceCollectionHealthCommand extends $Command< + DescribeResourceCollectionHealthCommandInput, + DescribeResourceCollectionHealthCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeResourceCollectionHealthCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeResourceCollectionHealthCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeResourceCollectionHealthRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeResourceCollectionHealthResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: DescribeResourceCollectionHealthCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeResourceCollectionHealthCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1DescribeResourceCollectionHealthCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/DescribeServiceIntegrationCommand.ts b/clients/client-devops-guru/commands/DescribeServiceIntegrationCommand.ts new file mode 100644 index 000000000000..ec14d707a558 --- /dev/null +++ b/clients/client-devops-guru/commands/DescribeServiceIntegrationCommand.ts @@ -0,0 +1,95 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { DescribeServiceIntegrationRequest, DescribeServiceIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeServiceIntegrationCommand, + serializeAws_restJson1DescribeServiceIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeServiceIntegrationCommandInput = DescribeServiceIntegrationRequest; +export type DescribeServiceIntegrationCommandOutput = DescribeServiceIntegrationResponse & __MetadataBearer; + +/** + *

+ * Returns the integration status of services that are integrated with DevOps Guru. + * The one service that can be integrated with DevOps Guru + * is AWS Systems Manager, which can be used to create an OpsItem for each generated insight. + *

+ */ +export class DescribeServiceIntegrationCommand extends $Command< + DescribeServiceIntegrationCommandInput, + DescribeServiceIntegrationCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeServiceIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "DescribeServiceIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeServiceIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeServiceIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeServiceIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeServiceIntegrationCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1DescribeServiceIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/GetResourceCollectionCommand.ts b/clients/client-devops-guru/commands/GetResourceCollectionCommand.ts new file mode 100644 index 000000000000..791e37a5ec11 --- /dev/null +++ b/clients/client-devops-guru/commands/GetResourceCollectionCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { GetResourceCollectionRequest, GetResourceCollectionResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetResourceCollectionCommand, + serializeAws_restJson1GetResourceCollectionCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetResourceCollectionCommandInput = GetResourceCollectionRequest; +export type GetResourceCollectionCommandOutput = GetResourceCollectionResponse & __MetadataBearer; + +/** + *

+ * Returns lists AWS resources that are of the specified resource collection type. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ +export class GetResourceCollectionCommand extends $Command< + GetResourceCollectionCommandInput, + GetResourceCollectionCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetResourceCollectionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "GetResourceCollectionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetResourceCollectionRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetResourceCollectionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetResourceCollectionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetResourceCollectionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetResourceCollectionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/ListAnomaliesForInsightCommand.ts b/clients/client-devops-guru/commands/ListAnomaliesForInsightCommand.ts new file mode 100644 index 000000000000..82d53201aa70 --- /dev/null +++ b/clients/client-devops-guru/commands/ListAnomaliesForInsightCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { ListAnomaliesForInsightRequest, ListAnomaliesForInsightResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListAnomaliesForInsightCommand, + serializeAws_restJson1ListAnomaliesForInsightCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListAnomaliesForInsightCommandInput = ListAnomaliesForInsightRequest; +export type ListAnomaliesForInsightCommandOutput = ListAnomaliesForInsightResponse & __MetadataBearer; + +/** + *

+ * Returns a list of the anomalies that belong to an insight that you specify using its ID. + *

+ */ +export class ListAnomaliesForInsightCommand extends $Command< + ListAnomaliesForInsightCommandInput, + ListAnomaliesForInsightCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListAnomaliesForInsightCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "ListAnomaliesForInsightCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListAnomaliesForInsightRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListAnomaliesForInsightResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListAnomaliesForInsightCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListAnomaliesForInsightCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListAnomaliesForInsightCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/ListEventsCommand.ts b/clients/client-devops-guru/commands/ListEventsCommand.ts new file mode 100644 index 000000000000..70182d24280b --- /dev/null +++ b/clients/client-devops-guru/commands/ListEventsCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { ListEventsRequest, ListEventsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListEventsCommand, + serializeAws_restJson1ListEventsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListEventsCommandInput = ListEventsRequest; +export type ListEventsCommandOutput = ListEventsResponse & __MetadataBearer; + +/** + *

+ * Returns a list of the events emitted by the resources that are evaluated by DevOps Guru. You can use filters to specify which events are returned. + *

+ */ +export class ListEventsCommand extends $Command< + ListEventsCommandInput, + ListEventsCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListEventsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "ListEventsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListEventsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListEventsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListEventsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListEventsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListEventsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/ListInsightsCommand.ts b/clients/client-devops-guru/commands/ListInsightsCommand.ts new file mode 100644 index 000000000000..f1c9a2da460f --- /dev/null +++ b/clients/client-devops-guru/commands/ListInsightsCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { ListInsightsRequest, ListInsightsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListInsightsCommand, + serializeAws_restJson1ListInsightsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListInsightsCommandInput = ListInsightsRequest; +export type ListInsightsCommandOutput = ListInsightsResponse & __MetadataBearer; + +/** + *

+ * Returns a list of insights in your AWS account. You can specify which insights are returned by their start time and + * status (ONGOING, CLOSED, or ANY). + *

+ */ +export class ListInsightsCommand extends $Command< + ListInsightsCommandInput, + ListInsightsCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListInsightsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "ListInsightsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListInsightsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListInsightsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListInsightsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListInsightsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListInsightsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/ListNotificationChannelsCommand.ts b/clients/client-devops-guru/commands/ListNotificationChannelsCommand.ts new file mode 100644 index 000000000000..704e5b9f40af --- /dev/null +++ b/clients/client-devops-guru/commands/ListNotificationChannelsCommand.ts @@ -0,0 +1,92 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { ListNotificationChannelsRequest, ListNotificationChannelsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListNotificationChannelsCommand, + serializeAws_restJson1ListNotificationChannelsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListNotificationChannelsCommandInput = ListNotificationChannelsRequest; +export type ListNotificationChannelsCommandOutput = ListNotificationChannelsResponse & __MetadataBearer; + +/** + *

+ * Returns a list of notification channels configured for DevOps Guru. Each notification channel is used to notify you when + * DevOps Guru generates an insight that contains information about how to improve your operations. The one + * supported notification channel is Amazon Simple Notification Service (Amazon SNS). + *

+ */ +export class ListNotificationChannelsCommand extends $Command< + ListNotificationChannelsCommandInput, + ListNotificationChannelsCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListNotificationChannelsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "ListNotificationChannelsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListNotificationChannelsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListNotificationChannelsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListNotificationChannelsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListNotificationChannelsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListNotificationChannelsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/ListRecommendationsCommand.ts b/clients/client-devops-guru/commands/ListRecommendationsCommand.ts new file mode 100644 index 000000000000..5a0c546a6dfc --- /dev/null +++ b/clients/client-devops-guru/commands/ListRecommendationsCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { ListRecommendationsRequest, ListRecommendationsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListRecommendationsCommand, + serializeAws_restJson1ListRecommendationsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListRecommendationsCommandInput = ListRecommendationsRequest; +export type ListRecommendationsCommandOutput = ListRecommendationsResponse & __MetadataBearer; + +/** + *

+ * Returns a list of a specified insight's recommendations. Each recommendation includes a list of related metrics and a list of related events. + *

+ */ +export class ListRecommendationsCommand extends $Command< + ListRecommendationsCommandInput, + ListRecommendationsCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListRecommendationsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "ListRecommendationsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListRecommendationsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListRecommendationsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListRecommendationsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListRecommendationsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListRecommendationsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/PutFeedbackCommand.ts b/clients/client-devops-guru/commands/PutFeedbackCommand.ts new file mode 100644 index 000000000000..d3830085e813 --- /dev/null +++ b/clients/client-devops-guru/commands/PutFeedbackCommand.ts @@ -0,0 +1,90 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { PutFeedbackRequest, PutFeedbackResponse } from "../models/models_0"; +import { + deserializeAws_restJson1PutFeedbackCommand, + serializeAws_restJson1PutFeedbackCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutFeedbackCommandInput = PutFeedbackRequest; +export type PutFeedbackCommandOutput = PutFeedbackResponse & __MetadataBearer; + +/** + *

+ * Collects customer feedback about the specified insight. + *

+ */ +export class PutFeedbackCommand extends $Command< + PutFeedbackCommandInput, + PutFeedbackCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutFeedbackCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "PutFeedbackCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutFeedbackRequest.filterSensitiveLog, + outputFilterSensitiveLog: PutFeedbackResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutFeedbackCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1PutFeedbackCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1PutFeedbackCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/RemoveNotificationChannelCommand.ts b/clients/client-devops-guru/commands/RemoveNotificationChannelCommand.ts new file mode 100644 index 000000000000..73bcb73817ba --- /dev/null +++ b/clients/client-devops-guru/commands/RemoveNotificationChannelCommand.ts @@ -0,0 +1,94 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { RemoveNotificationChannelRequest, RemoveNotificationChannelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1RemoveNotificationChannelCommand, + serializeAws_restJson1RemoveNotificationChannelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type RemoveNotificationChannelCommandInput = RemoveNotificationChannelRequest; +export type RemoveNotificationChannelCommandOutput = RemoveNotificationChannelResponse & __MetadataBearer; + +/** + *

+ * Removes a notification channel from DevOps Guru. A notification channel is used to notify you when DevOps Guru generates an insight + * that contains information about how to improve your operations. + *

+ */ +export class RemoveNotificationChannelCommand extends $Command< + RemoveNotificationChannelCommandInput, + RemoveNotificationChannelCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: RemoveNotificationChannelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "RemoveNotificationChannelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: RemoveNotificationChannelRequest.filterSensitiveLog, + outputFilterSensitiveLog: RemoveNotificationChannelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: RemoveNotificationChannelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1RemoveNotificationChannelCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1RemoveNotificationChannelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/SearchInsightsCommand.ts b/clients/client-devops-guru/commands/SearchInsightsCommand.ts new file mode 100644 index 000000000000..e7590d44288b --- /dev/null +++ b/clients/client-devops-guru/commands/SearchInsightsCommand.ts @@ -0,0 +1,96 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { SearchInsightsRequest, SearchInsightsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1SearchInsightsCommand, + serializeAws_restJson1SearchInsightsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type SearchInsightsCommandInput = SearchInsightsRequest; +export type SearchInsightsCommandOutput = SearchInsightsResponse & __MetadataBearer; + +/** + *

+ * Returns a list of insights in your AWS account. You can specify which insights are returned by their start time, one or more statuses + * (ONGOING, CLOSED, and CLOSED), one or more severities (LOW, MEDIUM, + * and HIGH), and type (REACTIVE or PROACTIVE). + *

+ *

+ * Use the Filters parameter to specify status and severity + * search parameters. Use the Type parameter to specify REACTIVE or PROACTIVE in your search. + *

+ */ +export class SearchInsightsCommand extends $Command< + SearchInsightsCommandInput, + SearchInsightsCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: SearchInsightsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "SearchInsightsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: SearchInsightsRequest.filterSensitiveLog, + outputFilterSensitiveLog: SearchInsightsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: SearchInsightsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1SearchInsightsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1SearchInsightsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/UpdateResourceCollectionCommand.ts b/clients/client-devops-guru/commands/UpdateResourceCollectionCommand.ts new file mode 100644 index 000000000000..b1085d1193a5 --- /dev/null +++ b/clients/client-devops-guru/commands/UpdateResourceCollectionCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { UpdateResourceCollectionRequest, UpdateResourceCollectionResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateResourceCollectionCommand, + serializeAws_restJson1UpdateResourceCollectionCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateResourceCollectionCommandInput = UpdateResourceCollectionRequest; +export type UpdateResourceCollectionCommandOutput = UpdateResourceCollectionResponse & __MetadataBearer; + +/** + *

Updates the collection of resources that DevOps Guru analyzes. + * The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. This method also creates the IAM role required for you + * to use DevOps Guru.

+ */ +export class UpdateResourceCollectionCommand extends $Command< + UpdateResourceCollectionCommandInput, + UpdateResourceCollectionCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateResourceCollectionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "UpdateResourceCollectionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateResourceCollectionRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateResourceCollectionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateResourceCollectionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateResourceCollectionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateResourceCollectionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/commands/UpdateServiceIntegrationCommand.ts b/clients/client-devops-guru/commands/UpdateServiceIntegrationCommand.ts new file mode 100644 index 000000000000..4d5f931b912d --- /dev/null +++ b/clients/client-devops-guru/commands/UpdateServiceIntegrationCommand.ts @@ -0,0 +1,91 @@ +import { DevOpsGuruClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DevOpsGuruClient"; +import { UpdateServiceIntegrationRequest, UpdateServiceIntegrationResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateServiceIntegrationCommand, + serializeAws_restJson1UpdateServiceIntegrationCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateServiceIntegrationCommandInput = UpdateServiceIntegrationRequest; +export type UpdateServiceIntegrationCommandOutput = UpdateServiceIntegrationResponse & __MetadataBearer; + +/** + *

+ * Enables or disables integration with a service that can be integrated with DevOps Guru. The one service that can be integrated with + * DevOps Guru is AWS Systems Manager, which can be used to create an OpsItem for each generated insight. + *

+ */ +export class UpdateServiceIntegrationCommand extends $Command< + UpdateServiceIntegrationCommandInput, + UpdateServiceIntegrationCommandOutput, + DevOpsGuruClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateServiceIntegrationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DevOpsGuruClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DevOpsGuruClient"; + const commandName = "UpdateServiceIntegrationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateServiceIntegrationRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateServiceIntegrationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateServiceIntegrationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateServiceIntegrationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateServiceIntegrationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-devops-guru/endpoints.ts b/clients/client-devops-guru/endpoints.ts new file mode 100644 index 000000000000..f5fd4b40fce5 --- /dev/null +++ b/clients/client-devops-guru/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "devops-guru.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "devops-guru.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "devops-guru.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "devops-guru.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "devops-guru.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-devops-guru/index.ts b/clients/client-devops-guru/index.ts new file mode 100644 index 000000000000..27c590d16b0a --- /dev/null +++ b/clients/client-devops-guru/index.ts @@ -0,0 +1,30 @@ +export * from "./DevOpsGuruClient"; +export * from "./DevOpsGuru"; +export * from "./commands/AddNotificationChannelCommand"; +export * from "./commands/DescribeAccountHealthCommand"; +export * from "./commands/DescribeAccountOverviewCommand"; +export * from "./commands/DescribeAnomalyCommand"; +export * from "./commands/DescribeInsightCommand"; +export * from "./commands/DescribeResourceCollectionHealthCommand"; +export * from "./pagination/DescribeResourceCollectionHealthPaginator"; +export * from "./commands/DescribeServiceIntegrationCommand"; +export * from "./commands/GetResourceCollectionCommand"; +export * from "./pagination/GetResourceCollectionPaginator"; +export * from "./commands/ListAnomaliesForInsightCommand"; +export * from "./pagination/ListAnomaliesForInsightPaginator"; +export * from "./commands/ListEventsCommand"; +export * from "./pagination/ListEventsPaginator"; +export * from "./commands/ListInsightsCommand"; +export * from "./pagination/ListInsightsPaginator"; +export * from "./commands/ListNotificationChannelsCommand"; +export * from "./pagination/ListNotificationChannelsPaginator"; +export * from "./commands/ListRecommendationsCommand"; +export * from "./pagination/ListRecommendationsPaginator"; +export * from "./commands/PutFeedbackCommand"; +export * from "./commands/RemoveNotificationChannelCommand"; +export * from "./commands/SearchInsightsCommand"; +export * from "./pagination/SearchInsightsPaginator"; +export * from "./commands/UpdateResourceCollectionCommand"; +export * from "./commands/UpdateServiceIntegrationCommand"; +export * from "./pagination/Interfaces"; +export * from "./models/index"; diff --git a/clients/client-devops-guru/models/index.ts b/clients/client-devops-guru/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-devops-guru/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-devops-guru/models/models_0.ts b/clients/client-devops-guru/models/models_0.ts new file mode 100644 index 000000000000..d318a9c350a2 --- /dev/null +++ b/clients/client-devops-guru/models/models_0.ts @@ -0,0 +1,2677 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +/** + *

You don't have permissions to perform the requested operation. The user or role that is making the request must have at + * least one IAM permissions policy attached that grants the required permissions. For more information, see + * Access Management in the IAM User Guide.

+ */ +export interface AccessDeniedException extends __SmithyException, $MetadataBearer { + name: "AccessDeniedException"; + $fault: "client"; + Message: string | undefined; +} + +export namespace AccessDeniedException { + export const filterSensitiveLog = (obj: AccessDeniedException): any => ({ + ...obj, + }); +} + +/** + *

Contains the Amazon Resource Name (ARN) of an Amazon Simple Notification Service topic.

+ */ +export interface SnsChannelConfig { + /** + *

The Amazon Resource Name (ARN) of an Amazon Simple Notification Service topic.

+ */ + TopicArn?: string; +} + +export namespace SnsChannelConfig { + export const filterSensitiveLog = (obj: SnsChannelConfig): any => ({ + ...obj, + }); +} + +/** + *

Information about notification channels you have configured with DevOps Guru. + * The one + * supported notification channel is Amazon Simple Notification Service (Amazon SNS).

+ */ +export interface NotificationChannelConfig { + /** + *

+ * Information about a notification channel configured in DevOps Guru to send notifications when insights are created. + *

+ */ + Sns: SnsChannelConfig | undefined; +} + +export namespace NotificationChannelConfig { + export const filterSensitiveLog = (obj: NotificationChannelConfig): any => ({ + ...obj, + }); +} + +export interface AddNotificationChannelRequest { + /** + *

A NotificationChannelConfig object that specifies what type of + * notification channel to add. The one + * supported notification channel is Amazon Simple Notification Service (Amazon SNS).

+ */ + Config: NotificationChannelConfig | undefined; +} + +export namespace AddNotificationChannelRequest { + export const filterSensitiveLog = (obj: AddNotificationChannelRequest): any => ({ + ...obj, + }); +} + +export interface AddNotificationChannelResponse { + /** + *

+ * The ID of the added notification channel. + *

+ */ + Id: string | undefined; +} + +export namespace AddNotificationChannelResponse { + export const filterSensitiveLog = (obj: AddNotificationChannelResponse): any => ({ + ...obj, + }); +} + +/** + *

+ * An exception that is thrown when a conflict occurs. + *

+ */ +export interface ConflictException extends __SmithyException, $MetadataBearer { + name: "ConflictException"; + $fault: "client"; + Message: string | undefined; + /** + *

+ * The ID of the AWS resource in which a conflict occurred. + *

+ */ + ResourceId: string | undefined; + + /** + *

+ * The type of the AWS resource in which a conflict occurred. + *

+ */ + ResourceType: string | undefined; +} + +export namespace ConflictException { + export const filterSensitiveLog = (obj: ConflictException): any => ({ + ...obj, + }); +} + +/** + *

An internal failure in an Amazon service occurred.

+ */ +export interface InternalServerException extends __SmithyException, $MetadataBearer { + name: "InternalServerException"; + $fault: "server"; + Message: string | undefined; + /** + *

+ * The number of seconds after which the action that caused the internal server + * exception can be retried. + *

+ */ + RetryAfterSeconds?: number; +} + +export namespace InternalServerException { + export const filterSensitiveLog = (obj: InternalServerException): any => ({ + ...obj, + }); +} + +/** + *

A requested resource could not be found

+ */ +export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { + name: "ResourceNotFoundException"; + $fault: "client"; + Message: string | undefined; + /** + *

+ * The ID of the AWS resource that could not be found. + *

+ */ + ResourceId: string | undefined; + + /** + *

+ * The type of the AWS resource that could not be found. + *

+ */ + ResourceType: string | undefined; +} + +export namespace ResourceNotFoundException { + export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

The request contains a value that exceeds a maximum quota.

+ */ +export interface ServiceQuotaExceededException extends __SmithyException, $MetadataBearer { + name: "ServiceQuotaExceededException"; + $fault: "client"; + Message?: string; +} + +export namespace ServiceQuotaExceededException { + export const filterSensitiveLog = (obj: ServiceQuotaExceededException): any => ({ + ...obj, + }); +} + +/** + *

The request was denied due to a request throttling.

+ */ +export interface ThrottlingException extends __SmithyException, $MetadataBearer { + name: "ThrottlingException"; + $fault: "client"; + Message: string | undefined; + /** + *

+ * The code of the quota that was exceeded, causing the throttling exception. + *

+ */ + QuotaCode?: string; + + /** + *

+ * The code of the service that caused the throttling exception. + *

+ */ + ServiceCode?: string; + + /** + *

+ * The number of seconds after which the action that caused the throttling + * exception can be retried. + *

+ */ + RetryAfterSeconds?: number; +} + +export namespace ThrottlingException { + export const filterSensitiveLog = (obj: ThrottlingException): any => ({ + ...obj, + }); +} + +/** + *

+ * The field associated with the validation exception. + *

+ */ +export interface ValidationExceptionField { + /** + *

+ * The name of the field. + *

+ */ + Name: string | undefined; + + /** + *

+ * The message associated with the validation exception with information to help + * determine its cause. + *

+ */ + Message: string | undefined; +} + +export namespace ValidationExceptionField { + export const filterSensitiveLog = (obj: ValidationExceptionField): any => ({ + ...obj, + }); +} + +export enum ValidationExceptionReason { + CANNOT_PARSE = "CANNOT_PARSE", + FIELD_VALIDATION_FAILED = "FIELD_VALIDATION_FAILED", + OTHER = "OTHER", + UNKNOWN_OPERATION = "UNKNOWN_OPERATION", +} + +/** + *

+ * Contains information about data passed in to a field during a request that is not valid. + *

+ */ +export interface ValidationException extends __SmithyException, $MetadataBearer { + name: "ValidationException"; + $fault: "client"; + /** + *

+ * A message that describes the validation exception. + *

+ */ + Message: string | undefined; + + /** + *

+ * The reason the validation exception was thrown. + *

+ */ + Reason?: ValidationExceptionReason | string; + + /** + *

+ * An array of fields that are associated with the validation exception. + *

+ */ + Fields?: ValidationExceptionField[]; +} + +export namespace ValidationException { + export const filterSensitiveLog = (obj: ValidationException): any => ({ + ...obj, + }); +} + +export enum AnomalySeverity { + HIGH = "HIGH", + LOW = "LOW", + MEDIUM = "MEDIUM", +} + +/** + *

+ * The dimension of a Amazon CloudWatch metric that is used when DevOps Guru analyzes the resources in your account for + * operational problems and anomalous behaivor. A dimension is a name/value pair that is part of the idenity + * of a metric. A metric can have up to 10 dimensions. For more information, see + * Dimensions + * in the Amazon CloudWatch User Guide. + *

+ */ +export interface CloudWatchMetricsDimension { + /** + *

+ * The name of the CloudWatch dimension. + *

+ */ + Name?: string; + + /** + *

+ * The value of the CloudWatch dimension. + *

+ */ + Value?: string; +} + +export namespace CloudWatchMetricsDimension { + export const filterSensitiveLog = (obj: CloudWatchMetricsDimension): any => ({ + ...obj, + }); +} + +export enum CloudWatchMetricsStat { + AVERAGE = "Average", + MAXIMUM = "Maximum", + MINIMUM = "Minimum", + P50 = "p50", + P90 = "p90", + P99 = "p99", + SAMPLE_COUNT = "SampleCount", + SUM = "Sum", +} + +/** + *

+ * Information about an Amazon CloudWatch metric. + *

+ */ +export interface CloudWatchMetricsDetail { + /** + *

+ * The name of the CloudWatch metric. + *

+ */ + MetricName?: string; + + /** + *

+ * The namespace of the CloudWatch metric. A namespace is a container for CloudWatch metrics. + *

+ */ + Namespace?: string; + + /** + *

+ * An array of CloudWatch dimensions associated with + *

+ */ + Dimensions?: CloudWatchMetricsDimension[]; + + /** + *

+ * The type of statistic associated with the CloudWatch metric. For more information, see + * Statistics in the + * Amazon CloudWatch User Guide. + *

+ */ + Stat?: CloudWatchMetricsStat | string; + + /** + *

+ * The unit of measure used for the CloudWatch metric. For example, Bytes, Seconds, + * Count, and Percent. + *

+ */ + Unit?: string; + + /** + *

+ * The length of time associated with the CloudWatch metric in number of seconds. + *

+ */ + Period?: number; +} + +export namespace CloudWatchMetricsDetail { + export const filterSensitiveLog = (obj: CloudWatchMetricsDetail): any => ({ + ...obj, + }); +} + +/** + *

+ * Details about the source of the anomalous operational data that triggered the anonaly. The + * one supported source is Amazon CloudWatch metrics. + *

+ */ +export interface AnomalySourceDetails { + /** + *

An array of CloudWatchMetricsDetail object that contains information + * about the analyzed metrics that displayed anomalous behavior.

+ */ + CloudWatchMetrics?: CloudWatchMetricsDetail[]; +} + +export namespace AnomalySourceDetails { + export const filterSensitiveLog = (obj: AnomalySourceDetails): any => ({ + ...obj, + }); +} + +export enum AnomalyStatus { + CLOSED = "CLOSED", + ONGOING = "ONGOING", +} + +/** + *

+ * A time range that specifies when the observed unusual behavior in an anomaly started and ended. + *

+ */ +export interface AnomalyTimeRange { + /** + *

+ * The time when the anomalous behavior started. + *

+ */ + StartTime: Date | undefined; + + /** + *

The time when the anomalous behavior ended.

+ */ + EndTime?: Date; +} + +export namespace AnomalyTimeRange { + export const filterSensitiveLog = (obj: AnomalyTimeRange): any => ({ + ...obj, + }); +} + +export interface DescribeAccountHealthRequest {} + +export namespace DescribeAccountHealthRequest { + export const filterSensitiveLog = (obj: DescribeAccountHealthRequest): any => ({ + ...obj, + }); +} + +export interface DescribeAccountHealthResponse { + /** + *

+ * An integer that specifies the number of open reactive insights in your AWS account. + *

+ */ + OpenReactiveInsights: number | undefined; + + /** + *

+ * An integer that specifies the number of open proactive insights in your AWS account. + *

+ */ + OpenProactiveInsights: number | undefined; + + /** + *

+ * An integer that specifies the number of metrics that have been analyzed in your AWS account. + *

+ */ + MetricsAnalyzed: number | undefined; +} + +export namespace DescribeAccountHealthResponse { + export const filterSensitiveLog = (obj: DescribeAccountHealthResponse): any => ({ + ...obj, + }); +} + +export interface DescribeAccountOverviewRequest { + /** + *

+ * The start of the time range passed in. The start time granularity is at the + * day level. The floor of the start time is used. Returned information occurred after this day. + *

+ */ + FromTime: Date | undefined; + + /** + *

+ * The end of the time range passed in. The start time granularity is at the + * day level. The floor of the start time is used. Returned information occurred before this day. If this is not specified, then the current day is used. + *

+ */ + ToTime?: Date; +} + +export namespace DescribeAccountOverviewRequest { + export const filterSensitiveLog = (obj: DescribeAccountOverviewRequest): any => ({ + ...obj, + }); +} + +export interface DescribeAccountOverviewResponse { + /** + *

+ * An integer that specifies the number of open reactive insights in your AWS account that were created during the + * time range passed in. + *

+ */ + ReactiveInsights: number | undefined; + + /** + *

+ * An integer that specifies the number of open proactive insights in your AWS account that were created during the + * time range passed in. + *

+ */ + ProactiveInsights: number | undefined; + + /** + *

+ * The Mean Time to Recover (MTTR) for all closed insights that were created during the + * time range passed in. + *

+ */ + MeanTimeToRecoverInMilliseconds: number | undefined; +} + +export namespace DescribeAccountOverviewResponse { + export const filterSensitiveLog = (obj: DescribeAccountOverviewResponse): any => ({ + ...obj, + }); +} + +export interface DescribeAnomalyRequest { + /** + *

+ * The ID of the anomaly. + *

+ */ + Id: string | undefined; +} + +export namespace DescribeAnomalyRequest { + export const filterSensitiveLog = (obj: DescribeAnomalyRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * The time range during which anomalous behavior in a proactive anomaly or an insight is expected to occur. + *

+ */ +export interface PredictionTimeRange { + /** + *

+ * The time range during which a metric limit is expected to be exceeded. This applies to proactive insights only. + *

+ */ + StartTime: Date | undefined; + + /** + *

+ * The time when the behavior in a proactive insight is expected to end. + *

+ */ + EndTime?: Date; +} + +export namespace PredictionTimeRange { + export const filterSensitiveLog = (obj: PredictionTimeRange): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about AWS CloudFormation stacks. You can use stacks to specify which AWS resources in your account to analyze. + * For more information, see Stacks + * in the AWS CloudFormation User Guide. + *

+ */ +export interface CloudFormationCollection { + /** + *

+ * An array of CloudFormation stack names. + *

+ */ + StackNames?: string[]; +} + +export namespace CloudFormationCollection { + export const filterSensitiveLog = (obj: CloudFormationCollection): any => ({ + ...obj, + }); +} + +/** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ +export interface ResourceCollection { + /** + *

An array of the names of AWS CloudFormation stacks. The stacks define AWS resources + * that DevOps Guru analyzes. + *

+ */ + CloudFormation?: CloudFormationCollection; +} + +export namespace ResourceCollection { + export const filterSensitiveLog = (obj: ResourceCollection): any => ({ + ...obj, + }); +} + +/** + *

Information about an anomaly. This object is returned by ListAnomalies.

+ */ +export interface ProactiveAnomaly { + /** + *

+ * The ID of a proactive anomaly. + *

+ */ + Id?: string; + + /** + *

+ * The severity of a proactive anomaly. + *

+ */ + Severity?: AnomalySeverity | string; + + /** + *

+ * The status of a proactive anomaly. + *

+ */ + Status?: AnomalyStatus | string; + + /** + *

+ * The time of the anomaly's most recent update. + *

+ */ + UpdateTime?: Date; + + /** + *

+ * A time range that specifies when the observed unusual behavior in an anomaly started and ended. + *

+ */ + AnomalyTimeRange?: AnomalyTimeRange; + + /** + *

+ * The time range during which anomalous behavior in a proactive anomaly or an insight is expected to occur. + *

+ */ + PredictionTimeRange?: PredictionTimeRange; + + /** + *

+ * Details about the source of the analyzed operational data that triggered the anomaly. The one supported source is Amazon CloudWatch metrics. + *

+ */ + SourceDetails?: AnomalySourceDetails; + + /** + *

+ * The ID of the insight that contains this anomaly. An insight is composed of related anomalies. + *

+ */ + AssociatedInsightId?: string; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; + + /** + *

+ * A threshold that was exceeded by behavior in analyzed resources. Exceeding this + * threshold is related to the anomalous behavior that generated this anomaly. + *

+ */ + Limit?: number; +} + +export namespace ProactiveAnomaly { + export const filterSensitiveLog = (obj: ProactiveAnomaly): any => ({ + ...obj, + }); +} + +/** + *

Details about a reactive anomaly. This object is returned by ListAnomalies.

+ */ +export interface ReactiveAnomaly { + /** + *

The ID of the reactive anomaly.

+ */ + Id?: string; + + /** + *

The severity of the anomaly.

+ */ + Severity?: AnomalySeverity | string; + + /** + *

+ * The status of the anomaly. + *

+ */ + Status?: AnomalyStatus | string; + + /** + *

+ * A time range that specifies when the observed unusual behavior in an anomaly started and ended. + *

+ */ + AnomalyTimeRange?: AnomalyTimeRange; + + /** + *

+ * Details about the source of the analyzed operational data that triggered the anomaly. The one supported source is Amazon CloudWatch metrics. + *

+ */ + SourceDetails?: AnomalySourceDetails; + + /** + *

+ * The ID of the insight that contains this anomaly. An insight is composed of related anomalies. + *

+ */ + AssociatedInsightId?: string; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace ReactiveAnomaly { + export const filterSensitiveLog = (obj: ReactiveAnomaly): any => ({ + ...obj, + }); +} + +export interface DescribeAnomalyResponse { + /** + *

+ * An ReactiveAnomaly object that represents the requested anomaly. + *

+ */ + ProactiveAnomaly?: ProactiveAnomaly; + + /** + *

+ * An ProactiveAnomaly object that represents the requested anomaly. + *

+ */ + ReactiveAnomaly?: ReactiveAnomaly; +} + +export namespace DescribeAnomalyResponse { + export const filterSensitiveLog = (obj: DescribeAnomalyResponse): any => ({ + ...obj, + }); +} + +export interface DescribeInsightRequest { + /** + *

+ * The ID of the insight. + *

+ */ + Id: string | undefined; +} + +export namespace DescribeInsightRequest { + export const filterSensitiveLog = (obj: DescribeInsightRequest): any => ({ + ...obj, + }); +} + +/** + *

A time ranged that specifies when the observed behavior in an insight started and + * ended.

+ */ +export interface InsightTimeRange { + /** + *

+ * The time when the behavior described in an insight started. + *

+ */ + StartTime: Date | undefined; + + /** + *

+ * The time when the behavior described in an insight ended. + *

+ */ + EndTime?: Date; +} + +export namespace InsightTimeRange { + export const filterSensitiveLog = (obj: InsightTimeRange): any => ({ + ...obj, + }); +} + +export enum InsightSeverity { + HIGH = "HIGH", + LOW = "LOW", + MEDIUM = "MEDIUM", +} + +export enum InsightStatus { + CLOSED = "CLOSED", + ONGOING = "ONGOING", +} + +/** + *

Details about a proactive insight. This object is returned by ListInsights.

+ */ +export interface ProactiveInsight { + /** + *

The ID of the proactive insight.

+ */ + Id?: string; + + /** + *

The name of the proactive insight.

+ */ + Name?: string; + + /** + *

The severity of the proactive insight.

+ */ + Severity?: InsightSeverity | string; + + /** + *

The status of the proactive insight.

+ */ + Status?: InsightStatus | string; + + /** + *

A time ranged that specifies when the observed behavior in an insight started and + * ended.

+ */ + InsightTimeRange?: InsightTimeRange; + + /** + *

+ * The time range during which anomalous behavior in a proactive anomaly or an insight is expected to occur. + *

+ */ + PredictionTimeRange?: PredictionTimeRange; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; + + /** + *

+ * The ID of the AWS System Manager OpsItem created for this insight. You must enable + * the creation of OpstItems insights before they are created for each insight. + *

+ */ + SsmOpsItemId?: string; +} + +export namespace ProactiveInsight { + export const filterSensitiveLog = (obj: ProactiveInsight): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about a reactive insight. This object is returned by ListInsights. + *

+ */ +export interface ReactiveInsight { + /** + *

+ * The ID of a reactive insight. + *

+ */ + Id?: string; + + /** + *

+ * The name of a reactive insight. + *

+ */ + Name?: string; + + /** + *

+ * The severity of a reactive insight. + *

+ */ + Severity?: InsightSeverity | string; + + /** + *

+ * The status of a reactive insight. + *

+ */ + Status?: InsightStatus | string; + + /** + *

A time ranged that specifies when the observed behavior in an insight started and + * ended.

+ */ + InsightTimeRange?: InsightTimeRange; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; + + /** + *

+ * The ID of the AWS System Manager OpsItem created for this insight. You must enable + * the creation of OpstItems insights before they are created for each insight. + *

+ */ + SsmOpsItemId?: string; +} + +export namespace ReactiveInsight { + export const filterSensitiveLog = (obj: ReactiveInsight): any => ({ + ...obj, + }); +} + +export interface DescribeInsightResponse { + /** + *

+ * An ProactiveInsight object that represents the requested insight. + *

+ */ + ProactiveInsight?: ProactiveInsight; + + /** + *

+ * An ReactiveInsight object that represents the requested insight. + *

+ */ + ReactiveInsight?: ReactiveInsight; +} + +export namespace DescribeInsightResponse { + export const filterSensitiveLog = (obj: DescribeInsightResponse): any => ({ + ...obj, + }); +} + +export enum ResourceCollectionType { + AWS_CLOUD_FORMATION = "AWS_CLOUD_FORMATION", +} + +export interface DescribeResourceCollectionHealthRequest { + /** + *

+ * An AWS resource collection type. This type specifies how analyzed AWS resources are defined. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollectionType: ResourceCollectionType | string | undefined; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace DescribeResourceCollectionHealthRequest { + export const filterSensitiveLog = (obj: DescribeResourceCollectionHealthRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about the number of open reactive and proactive insights that can be + * used to gauge the health of your system. + *

+ */ +export interface InsightHealth { + /** + *

+ * The number of open proactive insights. + *

+ */ + OpenProactiveInsights?: number; + + /** + *

+ * The number of open reactive insights. + *

+ */ + OpenReactiveInsights?: number; + + /** + *

+ * The Meant Time to Recover (MTTR) for the insight. + *

+ */ + MeanTimeToRecoverInMilliseconds?: number; +} + +export namespace InsightHealth { + export const filterSensitiveLog = (obj: InsightHealth): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about the health of AWS resources in your account that are specified by an AWS CloudFormation stack. + *

+ */ +export interface CloudFormationHealth { + /** + *

+ * The name of the CloudFormation stack. + *

+ */ + StackName?: string; + + /** + *

+ * Information about the health of the AWS resources in your account that are specified by an AWS CloudFormation stack, including + * the number of open proactive, open reactive insights, and the Mean Time to Recover (MTTR) of closed insights. + *

+ */ + Insight?: InsightHealth; +} + +export namespace CloudFormationHealth { + export const filterSensitiveLog = (obj: CloudFormationHealth): any => ({ + ...obj, + }); +} + +export interface DescribeResourceCollectionHealthResponse { + /** + *

+ * The returned CloudFormationHealthOverview object that contains an InsightHealthOverview object with + * the requested system health information. + *

+ */ + CloudFormation: CloudFormationHealth[] | undefined; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace DescribeResourceCollectionHealthResponse { + export const filterSensitiveLog = (obj: DescribeResourceCollectionHealthResponse): any => ({ + ...obj, + }); +} + +export interface DescribeServiceIntegrationRequest {} + +export namespace DescribeServiceIntegrationRequest { + export const filterSensitiveLog = (obj: DescribeServiceIntegrationRequest): any => ({ + ...obj, + }); +} + +export enum OptInStatus { + DISABLED = "DISABLED", + ENABLED = "ENABLED", +} + +/** + *

+ * Information about whether DevOps Guru is configured to create an OpsItem in AWS Systems Manager OpsCenter for each created insight. + *

+ */ +export interface OpsCenterIntegration { + /** + *

+ * Specifies if DevOps Guru is enabled to create an AWS Systems Manager OpsItem for each created insight. + *

+ */ + OptInStatus?: OptInStatus | string; +} + +export namespace OpsCenterIntegration { + export const filterSensitiveLog = (obj: OpsCenterIntegration): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about the integration of DevOps Guru with another AWS service, such as AWS Systems Manager. + *

+ */ +export interface ServiceIntegrationConfig { + /** + *

+ * Information about whether DevOps Guru is configured to create an OpsItem in AWS Systems Manager OpsCenter for each created insight. + *

+ */ + OpsCenter?: OpsCenterIntegration; +} + +export namespace ServiceIntegrationConfig { + export const filterSensitiveLog = (obj: ServiceIntegrationConfig): any => ({ + ...obj, + }); +} + +export interface DescribeServiceIntegrationResponse { + /** + *

+ * Information about the integration of DevOps Guru with another AWS service, such as AWS Systems Manager. + *

+ */ + ServiceIntegration?: ServiceIntegrationConfig; +} + +export namespace DescribeServiceIntegrationResponse { + export const filterSensitiveLog = (obj: DescribeServiceIntegrationResponse): any => ({ + ...obj, + }); +} + +export interface GetResourceCollectionRequest { + /** + *

+ * The type of AWS resource collections to return. The one valid value is CLOUD_FORMATION for + * AWS CloudFormation stacks. + *

+ */ + ResourceCollectionType: ResourceCollectionType | string | undefined; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace GetResourceCollectionRequest { + export const filterSensitiveLog = (obj: GetResourceCollectionRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about AWS CloudFormation stacks. You can use stacks to specify which AWS resources in your account to analyze. + * For more information, see Stacks + * in the AWS CloudFormation User Guide. + *

+ */ +export interface CloudFormationCollectionFilter { + /** + *

+ * An array of CloudFormation stack names. + *

+ */ + StackNames?: string[]; +} + +export namespace CloudFormationCollectionFilter { + export const filterSensitiveLog = (obj: CloudFormationCollectionFilter): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about a filter used to specify which AWS resources are analyzed for anomalous behavior by DevOps Guru. + *

+ */ +export interface ResourceCollectionFilter { + /** + *

+ * Information about AWS CloudFormation stacks. You can use stacks to specify which AWS resources in your account to analyze. + * For more information, see Stacks + * in the AWS CloudFormation User Guide. + *

+ */ + CloudFormation?: CloudFormationCollectionFilter; +} + +export namespace ResourceCollectionFilter { + export const filterSensitiveLog = (obj: ResourceCollectionFilter): any => ({ + ...obj, + }); +} + +export interface GetResourceCollectionResponse { + /** + *

+ * The requested list of AWS resource collections. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollectionFilter; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace GetResourceCollectionResponse { + export const filterSensitiveLog = (obj: GetResourceCollectionResponse): any => ({ + ...obj, + }); +} + +/** + *

+ * A time range used to specify when the behavior of an insight or anomaly started. + *

+ */ +export interface StartTimeRange { + /** + *

+ * The start time of the time range. + *

+ */ + FromTime?: Date; + + /** + *

+ * The end time of the time range. + *

+ */ + ToTime?: Date; +} + +export namespace StartTimeRange { + export const filterSensitiveLog = (obj: StartTimeRange): any => ({ + ...obj, + }); +} + +export interface ListAnomaliesForInsightRequest { + /** + *

+ * The ID of the insight. The returned anomalies belong to this insight. + *

+ */ + InsightId: string | undefined; + + /** + *

+ * A time range used to specify when the requested anomalies started. All returned anomalies started + * during this time range. + *

+ */ + StartTimeRange?: StartTimeRange; + + /** + *

The maximum number of results to return with a single call. + * To retrieve the remaining results, make another call with the returned nextToken value. + * The default value is 500.

+ */ + MaxResults?: number; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace ListAnomaliesForInsightRequest { + export const filterSensitiveLog = (obj: ListAnomaliesForInsightRequest): any => ({ + ...obj, + }); +} + +/** + *

Details about a proactive anomaly. This object is returned by + * DescribeAnomaly. + *

+ */ +export interface ProactiveAnomalySummary { + /** + *

The ID of the anomaly.

+ */ + Id?: string; + + /** + *

The severity of the anomaly.

+ */ + Severity?: AnomalySeverity | string; + + /** + *

The status of the anomaly.

+ */ + Status?: AnomalyStatus | string; + + /** + *

+ * The time of the anomaly's most recent update. + *

+ */ + UpdateTime?: Date; + + /** + *

+ * A time range that specifies when the observed unusual behavior in an anomaly started and ended. + *

+ */ + AnomalyTimeRange?: AnomalyTimeRange; + + /** + *

+ * The time range during which anomalous behavior in a proactive anomaly or an insight is expected to occur. + *

+ */ + PredictionTimeRange?: PredictionTimeRange; + + /** + *

+ * Details about the source of the analyzed operational data that triggered the anomaly. The one supported source is Amazon CloudWatch metrics. + *

+ */ + SourceDetails?: AnomalySourceDetails; + + /** + *

+ * The ID of the insight that contains this anomaly. An insight is composed of related anomalies. + *

+ */ + AssociatedInsightId?: string; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; + + /** + *

+ * A threshold that was exceeded by behavior in analyzed resources. Exceeding this + * threshold is related to the anomalous behavior that generated this anomaly. + *

+ */ + Limit?: number; +} + +export namespace ProactiveAnomalySummary { + export const filterSensitiveLog = (obj: ProactiveAnomalySummary): any => ({ + ...obj, + }); +} + +/** + *

Details about a reactive anomaly. This object is returned by + * DescribeAnomaly. + *

+ */ +export interface ReactiveAnomalySummary { + /** + *

+ * The ID of the reactive anomaly. + *

+ */ + Id?: string; + + /** + *

+ * The severity of the reactive anomaly. + *

+ */ + Severity?: AnomalySeverity | string; + + /** + *

+ * The status of the reactive anomaly. + *

+ */ + Status?: AnomalyStatus | string; + + /** + *

+ * A time range that specifies when the observed unusual behavior in an anomaly started and ended. + *

+ */ + AnomalyTimeRange?: AnomalyTimeRange; + + /** + *

+ * Details about the source of the analyzed operational data that triggered the anomaly. The one supported source is Amazon CloudWatch metrics. + *

+ */ + SourceDetails?: AnomalySourceDetails; + + /** + *

+ * The ID of the insight that contains this anomaly. An insight is composed of related anomalies. + *

+ */ + AssociatedInsightId?: string; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace ReactiveAnomalySummary { + export const filterSensitiveLog = (obj: ReactiveAnomalySummary): any => ({ + ...obj, + }); +} + +export interface ListAnomaliesForInsightResponse { + /** + *

+ * An array of ProactiveAnomalySummary objects that represent the requested anomalies + *

+ */ + ProactiveAnomalies?: ProactiveAnomalySummary[]; + + /** + *

+ * An array of ReactiveAnomalySummary objects that represent the requested anomalies + *

+ */ + ReactiveAnomalies?: ReactiveAnomalySummary[]; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace ListAnomaliesForInsightResponse { + export const filterSensitiveLog = (obj: ListAnomaliesForInsightResponse): any => ({ + ...obj, + }); +} + +export enum EventDataSource { + AWS_CLOUD_TRAIL = "AWS_CLOUD_TRAIL", + AWS_CODE_DEPLOY = "AWS_CODE_DEPLOY", +} + +export enum EventClass { + CONFIG_CHANGE = "CONFIG_CHANGE", + DEPLOYMENT = "DEPLOYMENT", + INFRASTRUCTURE = "INFRASTRUCTURE", + SCHEMA_CHANGE = "SCHEMA_CHANGE", + SECURITY_CHANGE = "SECURITY_CHANGE", +} + +/** + *

+ * The time range during which an AWS event occurred. AWS resource events and metrics are analyzed by DevOps Guru to find anomalous behavior and + * provide recommendations to improve your operational solutions. + *

+ */ +export interface EventTimeRange { + /** + *

+ * The time when the event started. + *

+ */ + FromTime: Date | undefined; + + /** + *

+ * The time when the event ended. + *

+ */ + ToTime: Date | undefined; +} + +export namespace EventTimeRange { + export const filterSensitiveLog = (obj: EventTimeRange): any => ({ + ...obj, + }); +} + +/** + *

+ * Filters you can use to specify which events are returned when ListEvents is called. + *

+ */ +export interface ListEventsFilters { + /** + *

+ * An ID of an insight that is related to the events you want to filter for. + *

+ */ + InsightId?: string; + + /** + *

A time range during which you want the filtered events to have occurred.

+ */ + EventTimeRange?: EventTimeRange; + + /** + *

+ * The class of the events you want to filter for, such as an infrastructure change, a deployment, or a schema change. + *

+ */ + EventClass?: EventClass | string; + + /** + *

+ * The AWS source that emitted the events you want to filter for. + *

+ */ + EventSource?: string; + + /** + *

+ * The source, AWS_CLOUD_TRAIL or AWS_CODE_DEPLOY, of the events you want returned. + *

+ */ + DataSource?: EventDataSource | string; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace ListEventsFilters { + export const filterSensitiveLog = (obj: ListEventsFilters): any => ({ + ...obj, + }); +} + +export interface ListEventsRequest { + /** + *

+ * A ListEventsFilters object used to specify which events to return. + *

+ */ + Filters: ListEventsFilters | undefined; + + /** + *

The maximum number of results to return with a single call. + * To retrieve the remaining results, make another call with the returned nextToken value. + * The default value is 500.

+ */ + MaxResults?: number; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace ListEventsRequest { + export const filterSensitiveLog = (obj: ListEventsRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * The AWS resource that emitted an event. AWS resource events and metrics are analyzed by DevOps Guru to find anomalous behavior and + * provide recommendations to improve your operational solutions. + *

+ */ +export interface EventResource { + /** + *

+ * The type of resource that emitted an event. + *

+ */ + Type?: string; + + /** + *

+ * The name of the resource that emitted an event. + *

+ */ + Name?: string; + + /** + *

+ * The Amazon Resource Name (ARN) of the resource that emitted an event. + *

+ */ + Arn?: string; +} + +export namespace EventResource { + export const filterSensitiveLog = (obj: EventResource): any => ({ + ...obj, + }); +} + +/** + *

+ * An AWS resource event. AWS resource events and metrics are analyzed by DevOps Guru to find anomalous behavior and + * provide recommendations to improve your operational solutions. + *

+ */ +export interface Event { + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; + + /** + *

+ * The ID of the event. + *

+ */ + Id?: string; + + /** + *

A Timestamp that specifies the time the event occurred.

+ */ + Time?: Date; + + /** + *

+ * The AWS source that emitted the event. + *

+ */ + EventSource?: string; + + /** + *

+ * The name of the event. + *

+ */ + Name?: string; + + /** + *

+ * The source, AWS_CLOUD_TRAIL or AWS_CODE_DEPLOY, where DevOps Guru analysis found the event. + *

+ */ + DataSource?: EventDataSource | string; + + /** + *

+ * The class of the event. The class specifies what the event is related to, such as an infrastructure change, a deployment, or a schema change. + *

+ */ + EventClass?: EventClass | string; + + /** + *

+ * An EventResource object that contains information about the resource that emitted the event. + *

+ */ + Resources?: EventResource[]; +} + +export namespace Event { + export const filterSensitiveLog = (obj: Event): any => ({ + ...obj, + }); +} + +export interface ListEventsResponse { + /** + *

+ * A list of the requested events. + *

+ */ + Events: Event[] | undefined; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace ListEventsResponse { + export const filterSensitiveLog = (obj: ListEventsResponse): any => ({ + ...obj, + }); +} + +export enum InsightType { + PROACTIVE = "PROACTIVE", + REACTIVE = "REACTIVE", +} + +/** + *

+ * Used to filter for insights that have any status. + *

+ */ +export interface ListInsightsAnyStatusFilter { + /** + *

+ * Use to filter for either REACTIVE or PROACTIVE insights. + *

+ */ + Type: InsightType | string | undefined; + + /** + *

+ * A time range used to specify when the behavior of the filtered insights started. + *

+ */ + StartTimeRange: StartTimeRange | undefined; +} + +export namespace ListInsightsAnyStatusFilter { + export const filterSensitiveLog = (obj: ListInsightsAnyStatusFilter): any => ({ + ...obj, + }); +} + +/** + *

+ * A range of time that specifies when anomalous behavior in an anomaly or insight ended. + *

+ */ +export interface EndTimeRange { + /** + *

+ * The earliest end time in the time range. + *

+ */ + FromTime?: Date; + + /** + *

+ * The latest end time in the time range. + *

+ */ + ToTime?: Date; +} + +export namespace EndTimeRange { + export const filterSensitiveLog = (obj: EndTimeRange): any => ({ + ...obj, + }); +} + +/** + *

+ * Used to filter for insights that have the status CLOSED. + *

+ */ +export interface ListInsightsClosedStatusFilter { + /** + *

+ * Use to filter for either REACTIVE or PROACTIVE insights. + *

+ */ + Type: InsightType | string | undefined; + + /** + *

+ * A time range used to specify when the behavior of the filtered insights ended. + *

+ */ + EndTimeRange: EndTimeRange | undefined; +} + +export namespace ListInsightsClosedStatusFilter { + export const filterSensitiveLog = (obj: ListInsightsClosedStatusFilter): any => ({ + ...obj, + }); +} + +/** + *

+ * Used to filter for insights that have the status ONGOING. + *

+ */ +export interface ListInsightsOngoingStatusFilter { + /** + *

+ * Use to filter for either REACTIVE or PROACTIVE insights. + *

+ */ + Type: InsightType | string | undefined; +} + +export namespace ListInsightsOngoingStatusFilter { + export const filterSensitiveLog = (obj: ListInsightsOngoingStatusFilter): any => ({ + ...obj, + }); +} + +/** + *

+ * A filter used by ListInsights to specify which insights to return. + *

+ */ +export interface ListInsightsStatusFilter { + /** + *

+ * A ListInsightsAnyStatusFilter that specifies ongoing insights + * that are either REACTIVE or PROACTIVE. + *

+ */ + Ongoing?: ListInsightsOngoingStatusFilter; + + /** + *

+ * A ListInsightsClosedStatusFilter that specifies closed insights that are + * either REACTIVE or PROACTIVE. + *

+ */ + Closed?: ListInsightsClosedStatusFilter; + + /** + *

+ * A ListInsightsAnyStatusFilter that specifies insights of any status + * that are either REACTIVE or PROACTIVE. + *

+ */ + Any?: ListInsightsAnyStatusFilter; +} + +export namespace ListInsightsStatusFilter { + export const filterSensitiveLog = (obj: ListInsightsStatusFilter): any => ({ + ...obj, + }); +} + +export interface ListInsightsRequest { + /** + *

+ * A filter used to filter the returned insights by their status. You can specify one status filter. + *

+ */ + StatusFilter: ListInsightsStatusFilter | undefined; + + /** + *

The maximum number of results to return with a single call. + * To retrieve the remaining results, make another call with the returned nextToken value. + * The default value is 500.

+ */ + MaxResults?: number; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace ListInsightsRequest { + export const filterSensitiveLog = (obj: ListInsightsRequest): any => ({ + ...obj, + }); +} + +/** + *

Details about a proactive insight. This object is returned by + * DescribeInsight. + *

+ */ +export interface ProactiveInsightSummary { + /** + *

The ID of the proactive insight.

+ */ + Id?: string; + + /** + *

The name of the proactive insight.

+ */ + Name?: string; + + /** + *

The severity of the proactive insight.

+ */ + Severity?: InsightSeverity | string; + + /** + *

The status of the proactive insight.

+ */ + Status?: InsightStatus | string; + + /** + *

A time ranged that specifies when the observed behavior in an insight started and + * ended.

+ */ + InsightTimeRange?: InsightTimeRange; + + /** + *

+ * The time range during which anomalous behavior in a proactive anomaly or an insight is expected to occur. + *

+ */ + PredictionTimeRange?: PredictionTimeRange; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace ProactiveInsightSummary { + export const filterSensitiveLog = (obj: ProactiveInsightSummary): any => ({ + ...obj, + }); +} + +/** + *

Information about a reactive insight. This object is returned by + * DescribeInsight. + *

+ */ +export interface ReactiveInsightSummary { + /** + *

+ * The ID of a reactive summary. + *

+ */ + Id?: string; + + /** + *

+ * The name of a reactive insight. + *

+ */ + Name?: string; + + /** + *

+ * The severity of a reactive insight. + *

+ */ + Severity?: InsightSeverity | string; + + /** + *

+ * The status of a reactive insight. + *

+ */ + Status?: InsightStatus | string; + + /** + *

A time ranged that specifies when the observed behavior in an insight started and + * ended.

+ */ + InsightTimeRange?: InsightTimeRange; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace ReactiveInsightSummary { + export const filterSensitiveLog = (obj: ReactiveInsightSummary): any => ({ + ...obj, + }); +} + +export interface ListInsightsResponse { + /** + *

+ * The returned list of proactive insights. + *

+ */ + ProactiveInsights?: ProactiveInsightSummary[]; + + /** + *

+ * The returned list of reactive insights. + *

+ */ + ReactiveInsights?: ReactiveInsightSummary[]; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace ListInsightsResponse { + export const filterSensitiveLog = (obj: ListInsightsResponse): any => ({ + ...obj, + }); +} + +export interface ListNotificationChannelsRequest { + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace ListNotificationChannelsRequest { + export const filterSensitiveLog = (obj: ListNotificationChannelsRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about a notification channel. A notification channel is used to notify you when DevOps Guru creates an insight. + * The one + * supported notification channel is Amazon Simple Notification Service (Amazon SNS). + *

+ */ +export interface NotificationChannel { + /** + *

+ * The ID of a notification channel. + *

+ */ + Id?: string; + + /** + *

+ * A NotificationChannelConfig object that contains information about configured notification channels. + *

+ */ + Config?: NotificationChannelConfig; +} + +export namespace NotificationChannel { + export const filterSensitiveLog = (obj: NotificationChannel): any => ({ + ...obj, + }); +} + +export interface ListNotificationChannelsResponse { + /** + *

+ * An array that contains the requested notification channels. + *

+ */ + Channels?: NotificationChannel[]; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace ListNotificationChannelsResponse { + export const filterSensitiveLog = (obj: ListNotificationChannelsResponse): any => ({ + ...obj, + }); +} + +export interface ListRecommendationsRequest { + /** + *

+ * The ID of the requested insight. + *

+ */ + InsightId: string | undefined; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; +} + +export namespace ListRecommendationsRequest { + export const filterSensitiveLog = (obj: ListRecommendationsRequest): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about a resource in which DevOps Guru detected anomalous behavior. + *

+ */ +export interface RecommendationRelatedAnomalyResource { + /** + *

+ * The name of the resource. + *

+ */ + Name?: string; + + /** + *

+ * The type of the resource. + *

+ */ + Type?: string; +} + +export namespace RecommendationRelatedAnomalyResource { + export const filterSensitiveLog = (obj: RecommendationRelatedAnomalyResource): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about an Amazon CloudWatch metric that is analyzed by DevOps Guru. It is one of many analyzed metrics + * that are used to generate insights. + *

+ */ +export interface RecommendationRelatedCloudWatchMetricsSourceDetail { + /** + *

The name of the CloudWatch metric.

+ */ + MetricName?: string; + + /** + *

The namespace of the CloudWatch metric. A namespace is a container for CloudWatch metrics.

+ */ + Namespace?: string; +} + +export namespace RecommendationRelatedCloudWatchMetricsSourceDetail { + export const filterSensitiveLog = (obj: RecommendationRelatedCloudWatchMetricsSourceDetail): any => ({ + ...obj, + }); +} + +/** + *

+ * Contains an array of RecommendationRelatedCloudWatchMetricsSourceDetail objects that contain the name + * and namespace of an Amazon CloudWatch metric. + *

+ */ +export interface RecommendationRelatedAnomalySourceDetail { + /** + *

An array of CloudWatchMetricsDetail objects that contains information + * about the analyzed metrics that displayed anomalous behavior.

+ */ + CloudWatchMetrics?: RecommendationRelatedCloudWatchMetricsSourceDetail[]; +} + +export namespace RecommendationRelatedAnomalySourceDetail { + export const filterSensitiveLog = (obj: RecommendationRelatedAnomalySourceDetail): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about an anomaly that is related to a recommendations. + *

+ */ +export interface RecommendationRelatedAnomaly { + /** + *

+ * An array of objects that represent resources in which DevOps Guru detected anomalous behavior. Each object contains the name + * and type of the resource. + *

+ */ + Resources?: RecommendationRelatedAnomalyResource[]; + + /** + *

+ * Information about where the anomalous behavior related the recommendation was found. For example, details in Amazon CloudWatch metrics. + *

+ */ + SourceDetails?: RecommendationRelatedAnomalySourceDetail[]; +} + +export namespace RecommendationRelatedAnomaly { + export const filterSensitiveLog = (obj: RecommendationRelatedAnomaly): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about an AWS resource that emitted and event that is related to a recommendation in an insight. + *

+ */ +export interface RecommendationRelatedEventResource { + /** + *

+ * The name of the resource that emitted the event. This corresponds to the Name field in an + * EventResource object. + *

+ */ + Name?: string; + + /** + *

+ * The type of the resource that emitted the event. This corresponds to the Type field in an + * EventResource object. + *

+ */ + Type?: string; +} + +export namespace RecommendationRelatedEventResource { + export const filterSensitiveLog = (obj: RecommendationRelatedEventResource): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about an event that is related to a recommendations. + *

+ */ +export interface RecommendationRelatedEvent { + /** + *

+ * The name of the event. This corresponds to the Name field in an + * Event object. + *

+ */ + Name?: string; + + /** + *

+ * A ResourceCollection object that contains arrays of the names of AWS + * CloudFormation stacks. + *

+ */ + Resources?: RecommendationRelatedEventResource[]; +} + +export namespace RecommendationRelatedEvent { + export const filterSensitiveLog = (obj: RecommendationRelatedEvent): any => ({ + ...obj, + }); +} + +/** + *

Recommendation information to help you remediate detected anomalous behavior that + * generated an insight.

+ */ +export interface Recommendation { + /** + *

+ * A description of the problem. + *

+ */ + Description?: string; + + /** + *

+ * A hyperlink to information to help you address the problem. + *

+ */ + Link?: string; + + /** + *

+ * The name of the recommendation. + *

+ */ + Name?: string; + + /** + *

+ * The reason DevOps Guru flagged the anomalous behavior as a problem. + *

+ */ + Reason?: string; + + /** + *

+ * Events that are related to the problem. Use these events to learn more about what's happening and to help address the issue. + *

+ */ + RelatedEvents?: RecommendationRelatedEvent[]; + + /** + *

+ * Anomalies that are related to the problem. Use these Anomalies to learn more about what's happening and to help address the issue. + *

+ */ + RelatedAnomalies?: RecommendationRelatedAnomaly[]; +} + +export namespace Recommendation { + export const filterSensitiveLog = (obj: Recommendation): any => ({ + ...obj, + }); +} + +export interface ListRecommendationsResponse { + /** + *

+ * An array of the requested recommendations. + *

+ */ + Recommendations?: Recommendation[]; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace ListRecommendationsResponse { + export const filterSensitiveLog = (obj: ListRecommendationsResponse): any => ({ + ...obj, + }); +} + +export enum InsightFeedbackOption { + ALERT_TOO_SENSITIVE = "ALERT_TOO_SENSITIVE", + DATA_INCORRECT = "DATA_INCORRECT", + DATA_NOISY_ANOMALY = "DATA_NOISY_ANOMALY", + RECOMMENDATION_USEFUL = "RECOMMENDATION_USEFUL", + VALID_COLLECTION = "VALID_COLLECTION", +} + +/** + *

+ * Information about insight feedback received from a customer. + *

+ */ +export interface InsightFeedback { + /** + *

+ * The insight feedback ID. + *

+ */ + Id?: string; + + /** + *

+ * The feedback provided by the customer. + *

+ */ + Feedback?: InsightFeedbackOption | string; +} + +export namespace InsightFeedback { + export const filterSensitiveLog = (obj: InsightFeedback): any => ({ + ...obj, + }); +} + +export interface PutFeedbackRequest { + /** + *

+ * The feedback from customers is about the recommendations in this insight. + *

+ */ + InsightFeedback?: InsightFeedback; +} + +export namespace PutFeedbackRequest { + export const filterSensitiveLog = (obj: PutFeedbackRequest): any => ({ + ...obj, + }); +} + +export interface PutFeedbackResponse {} + +export namespace PutFeedbackResponse { + export const filterSensitiveLog = (obj: PutFeedbackResponse): any => ({ + ...obj, + }); +} + +export interface RemoveNotificationChannelRequest { + /** + *

+ * The ID of the notification channel to be removed. + *

+ */ + Id: string | undefined; +} + +export namespace RemoveNotificationChannelRequest { + export const filterSensitiveLog = (obj: RemoveNotificationChannelRequest): any => ({ + ...obj, + }); +} + +export interface RemoveNotificationChannelResponse {} + +export namespace RemoveNotificationChannelResponse { + export const filterSensitiveLog = (obj: RemoveNotificationChannelResponse): any => ({ + ...obj, + }); +} + +/** + *

+ * Specifies one or more severity values and one or more status values that are used to search + * for insights. + *

+ */ +export interface SearchInsightsFilters { + /** + *

+ * An array of severity values used to search for insights. + *

+ */ + Severities?: (InsightSeverity | string)[]; + + /** + *

+ * An array of status values used to search for insights. + *

+ */ + Statuses?: (InsightStatus | string)[]; + + /** + *

+ * A collection of AWS resources supported by DevOps Guru. The one type of AWS resource collection supported is AWS CloudFormation stacks. DevOps Guru can be configured to analyze + * only the AWS resources that are defined in the stacks. + *

+ */ + ResourceCollection?: ResourceCollection; +} + +export namespace SearchInsightsFilters { + export const filterSensitiveLog = (obj: SearchInsightsFilters): any => ({ + ...obj, + }); +} + +export interface SearchInsightsRequest { + /** + *

+ * The start of the time range passed in. Returned insights occurred after this time. + *

+ */ + StartTimeRange: StartTimeRange | undefined; + + /** + *

+ * A SearchInsightsFilters object that is used to set the severity and status filters on your insight search. + *

+ */ + Filters?: SearchInsightsFilters; + + /** + *

The maximum number of results to return with a single call. + * To retrieve the remaining results, make another call with the returned nextToken value. + * The default value is 500.

+ */ + MaxResults?: number; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If this value is null, it retrieves the first page.

+ */ + NextToken?: string; + + /** + *

+ * The type of insights you are searching for (REACTIVE or PROACTIVE). + *

+ */ + Type: InsightType | string | undefined; +} + +export namespace SearchInsightsRequest { + export const filterSensitiveLog = (obj: SearchInsightsRequest): any => ({ + ...obj, + }); +} + +export interface SearchInsightsResponse { + /** + *

+ * The returned proactive insights. + *

+ */ + ProactiveInsights?: ProactiveInsightSummary[]; + + /** + *

+ * The returned reactive insights. + *

+ */ + ReactiveInsights?: ReactiveInsightSummary[]; + + /** + *

The pagination token to use to retrieve + * the next page of results for this operation. If there are no more pages, this value is null.

+ */ + NextToken?: string; +} + +export namespace SearchInsightsResponse { + export const filterSensitiveLog = (obj: SearchInsightsResponse): any => ({ + ...obj, + }); +} + +export enum UpdateResourceCollectionAction { + ADD = "ADD", + REMOVE = "REMOVE", +} + +/** + *

Contains the names of AWS CloudFormation stacks used to update a collection of stacks.

+ */ +export interface UpdateCloudFormationCollectionFilter { + /** + *

+ * An array of the name of stacks to update. + *

+ */ + StackNames?: string[]; +} + +export namespace UpdateCloudFormationCollectionFilter { + export const filterSensitiveLog = (obj: UpdateCloudFormationCollectionFilter): any => ({ + ...obj, + }); +} + +/** + *

+ * Contains information used to update a collection of AWS resources. + *

+ */ +export interface UpdateResourceCollectionFilter { + /** + *

+ * An collection of AWS CloudFormation stacks. + *

+ */ + CloudFormation?: UpdateCloudFormationCollectionFilter; +} + +export namespace UpdateResourceCollectionFilter { + export const filterSensitiveLog = (obj: UpdateResourceCollectionFilter): any => ({ + ...obj, + }); +} + +export interface UpdateResourceCollectionRequest { + /** + *

+ * Specifies if the resource collection in the request is added or deleted to the resource collection. + *

+ */ + Action: UpdateResourceCollectionAction | string | undefined; + + /** + *

+ * Contains information used to update a collection of AWS resources. + *

+ */ + ResourceCollection: UpdateResourceCollectionFilter | undefined; +} + +export namespace UpdateResourceCollectionRequest { + export const filterSensitiveLog = (obj: UpdateResourceCollectionRequest): any => ({ + ...obj, + }); +} + +export interface UpdateResourceCollectionResponse {} + +export namespace UpdateResourceCollectionResponse { + export const filterSensitiveLog = (obj: UpdateResourceCollectionResponse): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about whether DevOps Guru is configured to create an OpsItem in AWS Systems Manager OpsCenter for each created insight. + *

+ */ +export interface OpsCenterIntegrationConfig { + /** + *

+ * Specifies if DevOps Guru is enabled to create an AWS Systems Manager OpsItem for each created insight. + *

+ */ + OptInStatus?: OptInStatus | string; +} + +export namespace OpsCenterIntegrationConfig { + export const filterSensitiveLog = (obj: OpsCenterIntegrationConfig): any => ({ + ...obj, + }); +} + +/** + *

+ * Information about updating the integration status of an AWS service, such as AWS Systems Manager, with DevOps Guru. + *

+ */ +export interface UpdateServiceIntegrationConfig { + /** + *

+ * Information about whether DevOps Guru is configured to create an OpsItem in AWS Systems Manager OpsCenter for each created insight. + *

+ */ + OpsCenter?: OpsCenterIntegrationConfig; +} + +export namespace UpdateServiceIntegrationConfig { + export const filterSensitiveLog = (obj: UpdateServiceIntegrationConfig): any => ({ + ...obj, + }); +} + +export interface UpdateServiceIntegrationRequest { + /** + *

+ * An IntegratedServiceConfig object used to specify the integrated service you want to update, and whether you + * want to update it to enabled or disabled. + *

+ */ + ServiceIntegration: UpdateServiceIntegrationConfig | undefined; +} + +export namespace UpdateServiceIntegrationRequest { + export const filterSensitiveLog = (obj: UpdateServiceIntegrationRequest): any => ({ + ...obj, + }); +} + +export interface UpdateServiceIntegrationResponse {} + +export namespace UpdateServiceIntegrationResponse { + export const filterSensitiveLog = (obj: UpdateServiceIntegrationResponse): any => ({ + ...obj, + }); +} diff --git a/clients/client-devops-guru/package.json b/clients/client-devops-guru/package.json new file mode 100644 index 000000000000..d0d78f2d51be --- /dev/null +++ b/clients/client-devops-guru/package.json @@ -0,0 +1,83 @@ +{ + "name": "@aws-sdk/client-devops-guru", + "description": "AWS SDK for JavaScript Devops Guru Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-devops-guru", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-devops-guru" + } +} diff --git a/clients/client-devops-guru/pagination/DescribeResourceCollectionHealthPaginator.ts b/clients/client-devops-guru/pagination/DescribeResourceCollectionHealthPaginator.ts new file mode 100644 index 000000000000..51e89bc93c06 --- /dev/null +++ b/clients/client-devops-guru/pagination/DescribeResourceCollectionHealthPaginator.ts @@ -0,0 +1,56 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + DescribeResourceCollectionHealthCommand, + DescribeResourceCollectionHealthCommandInput, + DescribeResourceCollectionHealthCommandOutput, +} from "../commands/DescribeResourceCollectionHealthCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: DescribeResourceCollectionHealthCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeResourceCollectionHealthCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: DescribeResourceCollectionHealthCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeResourceCollectionHealth(input, ...args); +}; +export async function* paginateDescribeResourceCollectionHealth( + config: DevOpsGuruPaginationConfiguration, + input: DescribeResourceCollectionHealthCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeResourceCollectionHealthCommandOutput; + while (hasNext) { + input.NextToken = token; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/GetResourceCollectionPaginator.ts b/clients/client-devops-guru/pagination/GetResourceCollectionPaginator.ts new file mode 100644 index 000000000000..a753d647b103 --- /dev/null +++ b/clients/client-devops-guru/pagination/GetResourceCollectionPaginator.ts @@ -0,0 +1,56 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + GetResourceCollectionCommand, + GetResourceCollectionCommandInput, + GetResourceCollectionCommandOutput, +} from "../commands/GetResourceCollectionCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: GetResourceCollectionCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new GetResourceCollectionCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: GetResourceCollectionCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.getResourceCollection(input, ...args); +}; +export async function* paginateGetResourceCollection( + config: DevOpsGuruPaginationConfiguration, + input: GetResourceCollectionCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: GetResourceCollectionCommandOutput; + while (hasNext) { + input.NextToken = token; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/Interfaces.ts b/clients/client-devops-guru/pagination/Interfaces.ts new file mode 100644 index 000000000000..f46acf918592 --- /dev/null +++ b/clients/client-devops-guru/pagination/Interfaces.ts @@ -0,0 +1,7 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { PaginationConfiguration } from "@aws-sdk/types"; + +export interface DevOpsGuruPaginationConfiguration extends PaginationConfiguration { + client: DevOpsGuru | DevOpsGuruClient; +} diff --git a/clients/client-devops-guru/pagination/ListAnomaliesForInsightPaginator.ts b/clients/client-devops-guru/pagination/ListAnomaliesForInsightPaginator.ts new file mode 100644 index 000000000000..26733747172e --- /dev/null +++ b/clients/client-devops-guru/pagination/ListAnomaliesForInsightPaginator.ts @@ -0,0 +1,57 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + ListAnomaliesForInsightCommand, + ListAnomaliesForInsightCommandInput, + ListAnomaliesForInsightCommandOutput, +} from "../commands/ListAnomaliesForInsightCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: ListAnomaliesForInsightCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListAnomaliesForInsightCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: ListAnomaliesForInsightCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listAnomaliesForInsight(input, ...args); +}; +export async function* paginateListAnomaliesForInsight( + config: DevOpsGuruPaginationConfiguration, + input: ListAnomaliesForInsightCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListAnomaliesForInsightCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/ListEventsPaginator.ts b/clients/client-devops-guru/pagination/ListEventsPaginator.ts new file mode 100644 index 000000000000..e72ed9cbfb64 --- /dev/null +++ b/clients/client-devops-guru/pagination/ListEventsPaginator.ts @@ -0,0 +1,53 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { ListEventsCommand, ListEventsCommandInput, ListEventsCommandOutput } from "../commands/ListEventsCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: ListEventsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListEventsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: ListEventsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listEvents(input, ...args); +}; +export async function* paginateListEvents( + config: DevOpsGuruPaginationConfiguration, + input: ListEventsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListEventsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/ListInsightsPaginator.ts b/clients/client-devops-guru/pagination/ListInsightsPaginator.ts new file mode 100644 index 000000000000..91dd396215b1 --- /dev/null +++ b/clients/client-devops-guru/pagination/ListInsightsPaginator.ts @@ -0,0 +1,57 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + ListInsightsCommand, + ListInsightsCommandInput, + ListInsightsCommandOutput, +} from "../commands/ListInsightsCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: ListInsightsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListInsightsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: ListInsightsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listInsights(input, ...args); +}; +export async function* paginateListInsights( + config: DevOpsGuruPaginationConfiguration, + input: ListInsightsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListInsightsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/ListNotificationChannelsPaginator.ts b/clients/client-devops-guru/pagination/ListNotificationChannelsPaginator.ts new file mode 100644 index 000000000000..a9316f6997d9 --- /dev/null +++ b/clients/client-devops-guru/pagination/ListNotificationChannelsPaginator.ts @@ -0,0 +1,56 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + ListNotificationChannelsCommand, + ListNotificationChannelsCommandInput, + ListNotificationChannelsCommandOutput, +} from "../commands/ListNotificationChannelsCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: ListNotificationChannelsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListNotificationChannelsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: ListNotificationChannelsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listNotificationChannels(input, ...args); +}; +export async function* paginateListNotificationChannels( + config: DevOpsGuruPaginationConfiguration, + input: ListNotificationChannelsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListNotificationChannelsCommandOutput; + while (hasNext) { + input.NextToken = token; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/ListRecommendationsPaginator.ts b/clients/client-devops-guru/pagination/ListRecommendationsPaginator.ts new file mode 100644 index 000000000000..f68b77defbc8 --- /dev/null +++ b/clients/client-devops-guru/pagination/ListRecommendationsPaginator.ts @@ -0,0 +1,56 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + ListRecommendationsCommand, + ListRecommendationsCommandInput, + ListRecommendationsCommandOutput, +} from "../commands/ListRecommendationsCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: ListRecommendationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListRecommendationsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: ListRecommendationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listRecommendations(input, ...args); +}; +export async function* paginateListRecommendations( + config: DevOpsGuruPaginationConfiguration, + input: ListRecommendationsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListRecommendationsCommandOutput; + while (hasNext) { + input.NextToken = token; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/pagination/SearchInsightsPaginator.ts b/clients/client-devops-guru/pagination/SearchInsightsPaginator.ts new file mode 100644 index 000000000000..e805578e6e61 --- /dev/null +++ b/clients/client-devops-guru/pagination/SearchInsightsPaginator.ts @@ -0,0 +1,57 @@ +import { DevOpsGuru } from "../DevOpsGuru"; +import { DevOpsGuruClient } from "../DevOpsGuruClient"; +import { + SearchInsightsCommand, + SearchInsightsCommandInput, + SearchInsightsCommandOutput, +} from "../commands/SearchInsightsCommand"; +import { DevOpsGuruPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: DevOpsGuruClient, + input: SearchInsightsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new SearchInsightsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: DevOpsGuru, + input: SearchInsightsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.searchInsights(input, ...args); +}; +export async function* paginateSearchInsights( + config: DevOpsGuruPaginationConfiguration, + input: SearchInsightsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: SearchInsightsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof DevOpsGuru) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof DevOpsGuruClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected DevOpsGuru | DevOpsGuruClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-devops-guru/protocols/Aws_restJson1.ts b/clients/client-devops-guru/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..f6635fc0c533 --- /dev/null +++ b/clients/client-devops-guru/protocols/Aws_restJson1.ts @@ -0,0 +1,3271 @@ +import { + AddNotificationChannelCommandInput, + AddNotificationChannelCommandOutput, +} from "../commands/AddNotificationChannelCommand"; +import { + DescribeAccountHealthCommandInput, + DescribeAccountHealthCommandOutput, +} from "../commands/DescribeAccountHealthCommand"; +import { + DescribeAccountOverviewCommandInput, + DescribeAccountOverviewCommandOutput, +} from "../commands/DescribeAccountOverviewCommand"; +import { DescribeAnomalyCommandInput, DescribeAnomalyCommandOutput } from "../commands/DescribeAnomalyCommand"; +import { DescribeInsightCommandInput, DescribeInsightCommandOutput } from "../commands/DescribeInsightCommand"; +import { + DescribeResourceCollectionHealthCommandInput, + DescribeResourceCollectionHealthCommandOutput, +} from "../commands/DescribeResourceCollectionHealthCommand"; +import { + DescribeServiceIntegrationCommandInput, + DescribeServiceIntegrationCommandOutput, +} from "../commands/DescribeServiceIntegrationCommand"; +import { + GetResourceCollectionCommandInput, + GetResourceCollectionCommandOutput, +} from "../commands/GetResourceCollectionCommand"; +import { + ListAnomaliesForInsightCommandInput, + ListAnomaliesForInsightCommandOutput, +} from "../commands/ListAnomaliesForInsightCommand"; +import { ListEventsCommandInput, ListEventsCommandOutput } from "../commands/ListEventsCommand"; +import { ListInsightsCommandInput, ListInsightsCommandOutput } from "../commands/ListInsightsCommand"; +import { + ListNotificationChannelsCommandInput, + ListNotificationChannelsCommandOutput, +} from "../commands/ListNotificationChannelsCommand"; +import { + ListRecommendationsCommandInput, + ListRecommendationsCommandOutput, +} from "../commands/ListRecommendationsCommand"; +import { PutFeedbackCommandInput, PutFeedbackCommandOutput } from "../commands/PutFeedbackCommand"; +import { + RemoveNotificationChannelCommandInput, + RemoveNotificationChannelCommandOutput, +} from "../commands/RemoveNotificationChannelCommand"; +import { SearchInsightsCommandInput, SearchInsightsCommandOutput } from "../commands/SearchInsightsCommand"; +import { + UpdateResourceCollectionCommandInput, + UpdateResourceCollectionCommandOutput, +} from "../commands/UpdateResourceCollectionCommand"; +import { + UpdateServiceIntegrationCommandInput, + UpdateServiceIntegrationCommandOutput, +} from "../commands/UpdateServiceIntegrationCommand"; +import { + AccessDeniedException, + AnomalySourceDetails, + AnomalyTimeRange, + CloudFormationCollection, + CloudFormationCollectionFilter, + CloudFormationHealth, + CloudWatchMetricsDetail, + CloudWatchMetricsDimension, + ConflictException, + EndTimeRange, + Event, + EventResource, + EventTimeRange, + InsightFeedback, + InsightHealth, + InsightSeverity, + InsightStatus, + InsightTimeRange, + InternalServerException, + ListEventsFilters, + ListInsightsAnyStatusFilter, + ListInsightsClosedStatusFilter, + ListInsightsOngoingStatusFilter, + ListInsightsStatusFilter, + NotificationChannel, + NotificationChannelConfig, + OpsCenterIntegration, + OpsCenterIntegrationConfig, + PredictionTimeRange, + ProactiveAnomaly, + ProactiveAnomalySummary, + ProactiveInsight, + ProactiveInsightSummary, + ReactiveAnomaly, + ReactiveAnomalySummary, + ReactiveInsight, + ReactiveInsightSummary, + Recommendation, + RecommendationRelatedAnomaly, + RecommendationRelatedAnomalyResource, + RecommendationRelatedAnomalySourceDetail, + RecommendationRelatedCloudWatchMetricsSourceDetail, + RecommendationRelatedEvent, + RecommendationRelatedEventResource, + ResourceCollection, + ResourceCollectionFilter, + ResourceNotFoundException, + SearchInsightsFilters, + ServiceIntegrationConfig, + ServiceQuotaExceededException, + SnsChannelConfig, + StartTimeRange, + ThrottlingException, + UpdateCloudFormationCollectionFilter, + UpdateResourceCollectionFilter, + UpdateServiceIntegrationConfig, + ValidationException, + ValidationExceptionField, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { + SmithyException as __SmithyException, + extendedEncodeURIComponent as __extendedEncodeURIComponent, +} from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export const serializeAws_restJson1AddNotificationChannelCommand = async ( + input: AddNotificationChannelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/channels"; + let body: any; + body = JSON.stringify({ + ...(input.Config !== undefined && { + Config: serializeAws_restJson1NotificationChannelConfig(input.Config, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeAccountHealthCommand = async ( + input: DescribeAccountHealthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/accounts/health"; + let body: any; + body = "{}"; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeAccountOverviewCommand = async ( + input: DescribeAccountOverviewCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/accounts/overview"; + let body: any; + body = JSON.stringify({ + ...(input.FromTime !== undefined && { FromTime: Math.round(input.FromTime.getTime() / 1000) }), + ...(input.ToTime !== undefined && { ToTime: Math.round(input.ToTime.getTime() / 1000) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeAnomalyCommand = async ( + input: DescribeAnomalyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/anomalies/{Id}"; + if (input.Id !== undefined) { + const labelValue: string = input.Id; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Id."); + } + resolvedPath = resolvedPath.replace("{Id}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Id."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeInsightCommand = async ( + input: DescribeInsightCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/insights/{Id}"; + if (input.Id !== undefined) { + const labelValue: string = input.Id; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Id."); + } + resolvedPath = resolvedPath.replace("{Id}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Id."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeResourceCollectionHealthCommand = async ( + input: DescribeResourceCollectionHealthCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/accounts/health/resource-collection/{ResourceCollectionType}"; + if (input.ResourceCollectionType !== undefined) { + const labelValue: string = input.ResourceCollectionType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ResourceCollectionType."); + } + resolvedPath = resolvedPath.replace("{ResourceCollectionType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ResourceCollectionType."); + } + const query: any = { + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1DescribeServiceIntegrationCommand = async ( + input: DescribeServiceIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/service-integrations"; + let body: any; + body = "{}"; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1GetResourceCollectionCommand = async ( + input: GetResourceCollectionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/resource-collections/{ResourceCollectionType}"; + if (input.ResourceCollectionType !== undefined) { + const labelValue: string = input.ResourceCollectionType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ResourceCollectionType."); + } + resolvedPath = resolvedPath.replace("{ResourceCollectionType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ResourceCollectionType."); + } + const query: any = { + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListAnomaliesForInsightCommand = async ( + input: ListAnomaliesForInsightCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/anomalies/insight/{InsightId}"; + if (input.InsightId !== undefined) { + const labelValue: string = input.InsightId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: InsightId."); + } + resolvedPath = resolvedPath.replace("{InsightId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: InsightId."); + } + let body: any; + body = JSON.stringify({ + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.StartTimeRange !== undefined && { + StartTimeRange: serializeAws_restJson1StartTimeRange(input.StartTimeRange, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListEventsCommand = async ( + input: ListEventsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/events"; + let body: any; + body = JSON.stringify({ + ...(input.Filters !== undefined && { Filters: serializeAws_restJson1ListEventsFilters(input.Filters, context) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListInsightsCommand = async ( + input: ListInsightsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/insights"; + let body: any; + body = JSON.stringify({ + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.StatusFilter !== undefined && { + StatusFilter: serializeAws_restJson1ListInsightsStatusFilter(input.StatusFilter, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListNotificationChannelsCommand = async ( + input: ListNotificationChannelsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/channels"; + let body: any; + body = JSON.stringify({ + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListRecommendationsCommand = async ( + input: ListRecommendationsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/recommendations"; + let body: any; + body = JSON.stringify({ + ...(input.InsightId !== undefined && { InsightId: input.InsightId }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1PutFeedbackCommand = async ( + input: PutFeedbackCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/feedback"; + let body: any; + body = JSON.stringify({ + ...(input.InsightFeedback !== undefined && { + InsightFeedback: serializeAws_restJson1InsightFeedback(input.InsightFeedback, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1RemoveNotificationChannelCommand = async ( + input: RemoveNotificationChannelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/channels/{Id}"; + if (input.Id !== undefined) { + const labelValue: string = input.Id; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: Id."); + } + resolvedPath = resolvedPath.replace("{Id}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: Id."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1SearchInsightsCommand = async ( + input: SearchInsightsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/insights/search"; + let body: any; + body = JSON.stringify({ + ...(input.Filters !== undefined && { + Filters: serializeAws_restJson1SearchInsightsFilters(input.Filters, context), + }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.StartTimeRange !== undefined && { + StartTimeRange: serializeAws_restJson1StartTimeRange(input.StartTimeRange, context), + }), + ...(input.Type !== undefined && { Type: input.Type }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateResourceCollectionCommand = async ( + input: UpdateResourceCollectionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/resource-collections"; + let body: any; + body = JSON.stringify({ + ...(input.Action !== undefined && { Action: input.Action }), + ...(input.ResourceCollection !== undefined && { + ResourceCollection: serializeAws_restJson1UpdateResourceCollectionFilter(input.ResourceCollection, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateServiceIntegrationCommand = async ( + input: UpdateServiceIntegrationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/service-integrations"; + let body: any; + body = JSON.stringify({ + ...(input.ServiceIntegration !== undefined && { + ServiceIntegration: serializeAws_restJson1UpdateServiceIntegrationConfig(input.ServiceIntegration, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1AddNotificationChannelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1AddNotificationChannelCommandError(output, context); + } + const contents: AddNotificationChannelCommandOutput = { + $metadata: deserializeMetadata(output), + Id: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Id !== undefined && data.Id !== null) { + contents.Id = data.Id; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1AddNotificationChannelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.devopsguru#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.devopsguru#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeAccountHealthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeAccountHealthCommandError(output, context); + } + const contents: DescribeAccountHealthCommandOutput = { + $metadata: deserializeMetadata(output), + MetricsAnalyzed: undefined, + OpenProactiveInsights: undefined, + OpenReactiveInsights: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.MetricsAnalyzed !== undefined && data.MetricsAnalyzed !== null) { + contents.MetricsAnalyzed = data.MetricsAnalyzed; + } + if (data.OpenProactiveInsights !== undefined && data.OpenProactiveInsights !== null) { + contents.OpenProactiveInsights = data.OpenProactiveInsights; + } + if (data.OpenReactiveInsights !== undefined && data.OpenReactiveInsights !== null) { + contents.OpenReactiveInsights = data.OpenReactiveInsights; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeAccountHealthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeAccountOverviewCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeAccountOverviewCommandError(output, context); + } + const contents: DescribeAccountOverviewCommandOutput = { + $metadata: deserializeMetadata(output), + MeanTimeToRecoverInMilliseconds: undefined, + ProactiveInsights: undefined, + ReactiveInsights: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.MeanTimeToRecoverInMilliseconds !== undefined && data.MeanTimeToRecoverInMilliseconds !== null) { + contents.MeanTimeToRecoverInMilliseconds = data.MeanTimeToRecoverInMilliseconds; + } + if (data.ProactiveInsights !== undefined && data.ProactiveInsights !== null) { + contents.ProactiveInsights = data.ProactiveInsights; + } + if (data.ReactiveInsights !== undefined && data.ReactiveInsights !== null) { + contents.ReactiveInsights = data.ReactiveInsights; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeAccountOverviewCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeAnomalyCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeAnomalyCommandError(output, context); + } + const contents: DescribeAnomalyCommandOutput = { + $metadata: deserializeMetadata(output), + ProactiveAnomaly: undefined, + ReactiveAnomaly: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ProactiveAnomaly !== undefined && data.ProactiveAnomaly !== null) { + contents.ProactiveAnomaly = deserializeAws_restJson1ProactiveAnomaly(data.ProactiveAnomaly, context); + } + if (data.ReactiveAnomaly !== undefined && data.ReactiveAnomaly !== null) { + contents.ReactiveAnomaly = deserializeAws_restJson1ReactiveAnomaly(data.ReactiveAnomaly, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeAnomalyCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeInsightCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeInsightCommandError(output, context); + } + const contents: DescribeInsightCommandOutput = { + $metadata: deserializeMetadata(output), + ProactiveInsight: undefined, + ReactiveInsight: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ProactiveInsight !== undefined && data.ProactiveInsight !== null) { + contents.ProactiveInsight = deserializeAws_restJson1ProactiveInsight(data.ProactiveInsight, context); + } + if (data.ReactiveInsight !== undefined && data.ReactiveInsight !== null) { + contents.ReactiveInsight = deserializeAws_restJson1ReactiveInsight(data.ReactiveInsight, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeInsightCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeResourceCollectionHealthCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeResourceCollectionHealthCommandError(output, context); + } + const contents: DescribeResourceCollectionHealthCommandOutput = { + $metadata: deserializeMetadata(output), + CloudFormation: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.CloudFormation !== undefined && data.CloudFormation !== null) { + contents.CloudFormation = deserializeAws_restJson1CloudFormationHealths(data.CloudFormation, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeResourceCollectionHealthCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeServiceIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeServiceIntegrationCommandError(output, context); + } + const contents: DescribeServiceIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + ServiceIntegration: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ServiceIntegration !== undefined && data.ServiceIntegration !== null) { + contents.ServiceIntegration = deserializeAws_restJson1ServiceIntegrationConfig(data.ServiceIntegration, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeServiceIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetResourceCollectionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetResourceCollectionCommandError(output, context); + } + const contents: GetResourceCollectionCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + ResourceCollection: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.ResourceCollection !== undefined && data.ResourceCollection !== null) { + contents.ResourceCollection = deserializeAws_restJson1ResourceCollectionFilter(data.ResourceCollection, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetResourceCollectionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListAnomaliesForInsightCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListAnomaliesForInsightCommandError(output, context); + } + const contents: ListAnomaliesForInsightCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + ProactiveAnomalies: undefined, + ReactiveAnomalies: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.ProactiveAnomalies !== undefined && data.ProactiveAnomalies !== null) { + contents.ProactiveAnomalies = deserializeAws_restJson1ProactiveAnomalies(data.ProactiveAnomalies, context); + } + if (data.ReactiveAnomalies !== undefined && data.ReactiveAnomalies !== null) { + contents.ReactiveAnomalies = deserializeAws_restJson1ReactiveAnomalies(data.ReactiveAnomalies, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListAnomaliesForInsightCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListEventsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListEventsCommandError(output, context); + } + const contents: ListEventsCommandOutput = { + $metadata: deserializeMetadata(output), + Events: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Events !== undefined && data.Events !== null) { + contents.Events = deserializeAws_restJson1Events(data.Events, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListEventsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListInsightsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListInsightsCommandError(output, context); + } + const contents: ListInsightsCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + ProactiveInsights: undefined, + ReactiveInsights: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.ProactiveInsights !== undefined && data.ProactiveInsights !== null) { + contents.ProactiveInsights = deserializeAws_restJson1ProactiveInsights(data.ProactiveInsights, context); + } + if (data.ReactiveInsights !== undefined && data.ReactiveInsights !== null) { + contents.ReactiveInsights = deserializeAws_restJson1ReactiveInsights(data.ReactiveInsights, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListInsightsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListNotificationChannelsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListNotificationChannelsCommandError(output, context); + } + const contents: ListNotificationChannelsCommandOutput = { + $metadata: deserializeMetadata(output), + Channels: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Channels !== undefined && data.Channels !== null) { + contents.Channels = deserializeAws_restJson1Channels(data.Channels, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListNotificationChannelsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListRecommendationsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListRecommendationsCommandError(output, context); + } + const contents: ListRecommendationsCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + Recommendations: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.Recommendations !== undefined && data.Recommendations !== null) { + contents.Recommendations = deserializeAws_restJson1Recommendations(data.Recommendations, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListRecommendationsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1PutFeedbackCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1PutFeedbackCommandError(output, context); + } + const contents: PutFeedbackCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1PutFeedbackCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.devopsguru#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1RemoveNotificationChannelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1RemoveNotificationChannelCommandError(output, context); + } + const contents: RemoveNotificationChannelCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1RemoveNotificationChannelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.devopsguru#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.devopsguru#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1SearchInsightsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1SearchInsightsCommandError(output, context); + } + const contents: SearchInsightsCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + ProactiveInsights: undefined, + ReactiveInsights: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.ProactiveInsights !== undefined && data.ProactiveInsights !== null) { + contents.ProactiveInsights = deserializeAws_restJson1ProactiveInsights(data.ProactiveInsights, context); + } + if (data.ReactiveInsights !== undefined && data.ReactiveInsights !== null) { + contents.ReactiveInsights = deserializeAws_restJson1ReactiveInsights(data.ReactiveInsights, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1SearchInsightsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateResourceCollectionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateResourceCollectionCommandError(output, context); + } + const contents: UpdateResourceCollectionCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateResourceCollectionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.devopsguru#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateServiceIntegrationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateServiceIntegrationCommandError(output, context); + } + const contents: UpdateServiceIntegrationCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateServiceIntegrationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.devopsguru#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.devopsguru#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.devopsguru#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.devopsguru#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.devopsguru#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1AccessDeniedExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: AccessDeniedException = { + name: "AccessDeniedException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ConflictExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ConflictException = { + name: "ConflictException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + ResourceId: undefined, + ResourceType: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.ResourceId !== undefined && data.ResourceId !== null) { + contents.ResourceId = data.ResourceId; + } + if (data.ResourceType !== undefined && data.ResourceType !== null) { + contents.ResourceType = data.ResourceType; + } + return contents; +}; + +const deserializeAws_restJson1InternalServerExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InternalServerException = { + name: "InternalServerException", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + RetryAfterSeconds: undefined, + }; + if (parsedOutput.headers["retry-after"] !== undefined) { + contents.RetryAfterSeconds = parseInt(parsedOutput.headers["retry-after"], 10); + } + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceNotFoundException = { + name: "ResourceNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + ResourceId: undefined, + ResourceType: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.ResourceId !== undefined && data.ResourceId !== null) { + contents.ResourceId = data.ResourceId; + } + if (data.ResourceType !== undefined && data.ResourceType !== null) { + contents.ResourceType = data.ResourceType; + } + return contents; +}; + +const deserializeAws_restJson1ServiceQuotaExceededExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ServiceQuotaExceededException = { + name: "ServiceQuotaExceededException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ThrottlingExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ThrottlingException = { + name: "ThrottlingException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + QuotaCode: undefined, + RetryAfterSeconds: undefined, + ServiceCode: undefined, + }; + if (parsedOutput.headers["retry-after"] !== undefined) { + contents.RetryAfterSeconds = parseInt(parsedOutput.headers["retry-after"], 10); + } + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.QuotaCode !== undefined && data.QuotaCode !== null) { + contents.QuotaCode = data.QuotaCode; + } + if (data.ServiceCode !== undefined && data.ServiceCode !== null) { + contents.ServiceCode = data.ServiceCode; + } + return contents; +}; + +const deserializeAws_restJson1ValidationExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ValidationException = { + name: "ValidationException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Fields: undefined, + Message: undefined, + Reason: undefined, + }; + const data: any = parsedOutput.body; + if (data.Fields !== undefined && data.Fields !== null) { + contents.Fields = deserializeAws_restJson1ValidationExceptionFields(data.Fields, context); + } + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.Reason !== undefined && data.Reason !== null) { + contents.Reason = data.Reason; + } + return contents; +}; + +const serializeAws_restJson1CloudFormationCollection = ( + input: CloudFormationCollection, + context: __SerdeContext +): any => { + return { + ...(input.StackNames !== undefined && { StackNames: serializeAws_restJson1StackNames(input.StackNames, context) }), + }; +}; + +const serializeAws_restJson1EndTimeRange = (input: EndTimeRange, context: __SerdeContext): any => { + return { + ...(input.FromTime !== undefined && { FromTime: Math.round(input.FromTime.getTime() / 1000) }), + ...(input.ToTime !== undefined && { ToTime: Math.round(input.ToTime.getTime() / 1000) }), + }; +}; + +const serializeAws_restJson1EventTimeRange = (input: EventTimeRange, context: __SerdeContext): any => { + return { + ...(input.FromTime !== undefined && { FromTime: Math.round(input.FromTime.getTime() / 1000) }), + ...(input.ToTime !== undefined && { ToTime: Math.round(input.ToTime.getTime() / 1000) }), + }; +}; + +const serializeAws_restJson1InsightFeedback = (input: InsightFeedback, context: __SerdeContext): any => { + return { + ...(input.Feedback !== undefined && { Feedback: input.Feedback }), + ...(input.Id !== undefined && { Id: input.Id }), + }; +}; + +const serializeAws_restJson1InsightSeverities = (input: (InsightSeverity | string)[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1InsightStatuses = (input: (InsightStatus | string)[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1ListEventsFilters = (input: ListEventsFilters, context: __SerdeContext): any => { + return { + ...(input.DataSource !== undefined && { DataSource: input.DataSource }), + ...(input.EventClass !== undefined && { EventClass: input.EventClass }), + ...(input.EventSource !== undefined && { EventSource: input.EventSource }), + ...(input.EventTimeRange !== undefined && { + EventTimeRange: serializeAws_restJson1EventTimeRange(input.EventTimeRange, context), + }), + ...(input.InsightId !== undefined && { InsightId: input.InsightId }), + ...(input.ResourceCollection !== undefined && { + ResourceCollection: serializeAws_restJson1ResourceCollection(input.ResourceCollection, context), + }), + }; +}; + +const serializeAws_restJson1ListInsightsAnyStatusFilter = ( + input: ListInsightsAnyStatusFilter, + context: __SerdeContext +): any => { + return { + ...(input.StartTimeRange !== undefined && { + StartTimeRange: serializeAws_restJson1StartTimeRange(input.StartTimeRange, context), + }), + ...(input.Type !== undefined && { Type: input.Type }), + }; +}; + +const serializeAws_restJson1ListInsightsClosedStatusFilter = ( + input: ListInsightsClosedStatusFilter, + context: __SerdeContext +): any => { + return { + ...(input.EndTimeRange !== undefined && { + EndTimeRange: serializeAws_restJson1EndTimeRange(input.EndTimeRange, context), + }), + ...(input.Type !== undefined && { Type: input.Type }), + }; +}; + +const serializeAws_restJson1ListInsightsOngoingStatusFilter = ( + input: ListInsightsOngoingStatusFilter, + context: __SerdeContext +): any => { + return { + ...(input.Type !== undefined && { Type: input.Type }), + }; +}; + +const serializeAws_restJson1ListInsightsStatusFilter = ( + input: ListInsightsStatusFilter, + context: __SerdeContext +): any => { + return { + ...(input.Any !== undefined && { Any: serializeAws_restJson1ListInsightsAnyStatusFilter(input.Any, context) }), + ...(input.Closed !== undefined && { + Closed: serializeAws_restJson1ListInsightsClosedStatusFilter(input.Closed, context), + }), + ...(input.Ongoing !== undefined && { + Ongoing: serializeAws_restJson1ListInsightsOngoingStatusFilter(input.Ongoing, context), + }), + }; +}; + +const serializeAws_restJson1NotificationChannelConfig = ( + input: NotificationChannelConfig, + context: __SerdeContext +): any => { + return { + ...(input.Sns !== undefined && { Sns: serializeAws_restJson1SnsChannelConfig(input.Sns, context) }), + }; +}; + +const serializeAws_restJson1OpsCenterIntegrationConfig = ( + input: OpsCenterIntegrationConfig, + context: __SerdeContext +): any => { + return { + ...(input.OptInStatus !== undefined && { OptInStatus: input.OptInStatus }), + }; +}; + +const serializeAws_restJson1ResourceCollection = (input: ResourceCollection, context: __SerdeContext): any => { + return { + ...(input.CloudFormation !== undefined && { + CloudFormation: serializeAws_restJson1CloudFormationCollection(input.CloudFormation, context), + }), + }; +}; + +const serializeAws_restJson1SearchInsightsFilters = (input: SearchInsightsFilters, context: __SerdeContext): any => { + return { + ...(input.ResourceCollection !== undefined && { + ResourceCollection: serializeAws_restJson1ResourceCollection(input.ResourceCollection, context), + }), + ...(input.Severities !== undefined && { + Severities: serializeAws_restJson1InsightSeverities(input.Severities, context), + }), + ...(input.Statuses !== undefined && { Statuses: serializeAws_restJson1InsightStatuses(input.Statuses, context) }), + }; +}; + +const serializeAws_restJson1SnsChannelConfig = (input: SnsChannelConfig, context: __SerdeContext): any => { + return { + ...(input.TopicArn !== undefined && { TopicArn: input.TopicArn }), + }; +}; + +const serializeAws_restJson1StackNames = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1StartTimeRange = (input: StartTimeRange, context: __SerdeContext): any => { + return { + ...(input.FromTime !== undefined && { FromTime: Math.round(input.FromTime.getTime() / 1000) }), + ...(input.ToTime !== undefined && { ToTime: Math.round(input.ToTime.getTime() / 1000) }), + }; +}; + +const serializeAws_restJson1UpdateCloudFormationCollectionFilter = ( + input: UpdateCloudFormationCollectionFilter, + context: __SerdeContext +): any => { + return { + ...(input.StackNames !== undefined && { + StackNames: serializeAws_restJson1UpdateStackNames(input.StackNames, context), + }), + }; +}; + +const serializeAws_restJson1UpdateResourceCollectionFilter = ( + input: UpdateResourceCollectionFilter, + context: __SerdeContext +): any => { + return { + ...(input.CloudFormation !== undefined && { + CloudFormation: serializeAws_restJson1UpdateCloudFormationCollectionFilter(input.CloudFormation, context), + }), + }; +}; + +const serializeAws_restJson1UpdateServiceIntegrationConfig = ( + input: UpdateServiceIntegrationConfig, + context: __SerdeContext +): any => { + return { + ...(input.OpsCenter !== undefined && { + OpsCenter: serializeAws_restJson1OpsCenterIntegrationConfig(input.OpsCenter, context), + }), + }; +}; + +const serializeAws_restJson1UpdateStackNames = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const deserializeAws_restJson1AnomalySourceDetails = (output: any, context: __SerdeContext): AnomalySourceDetails => { + return { + CloudWatchMetrics: + output.CloudWatchMetrics !== undefined && output.CloudWatchMetrics !== null + ? deserializeAws_restJson1CloudWatchMetricsDetails(output.CloudWatchMetrics, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1AnomalyTimeRange = (output: any, context: __SerdeContext): AnomalyTimeRange => { + return { + EndTime: + output.EndTime !== undefined && output.EndTime !== null ? new Date(Math.round(output.EndTime * 1000)) : undefined, + StartTime: + output.StartTime !== undefined && output.StartTime !== null + ? new Date(Math.round(output.StartTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_restJson1Channels = (output: any, context: __SerdeContext): NotificationChannel[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1NotificationChannel(entry, context)); +}; + +const deserializeAws_restJson1CloudFormationCollection = ( + output: any, + context: __SerdeContext +): CloudFormationCollection => { + return { + StackNames: + output.StackNames !== undefined && output.StackNames !== null + ? deserializeAws_restJson1StackNames(output.StackNames, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CloudFormationCollectionFilter = ( + output: any, + context: __SerdeContext +): CloudFormationCollectionFilter => { + return { + StackNames: + output.StackNames !== undefined && output.StackNames !== null + ? deserializeAws_restJson1StackNames(output.StackNames, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1CloudFormationHealth = (output: any, context: __SerdeContext): CloudFormationHealth => { + return { + Insight: + output.Insight !== undefined && output.Insight !== null + ? deserializeAws_restJson1InsightHealth(output.Insight, context) + : undefined, + StackName: output.StackName !== undefined && output.StackName !== null ? output.StackName : undefined, + } as any; +}; + +const deserializeAws_restJson1CloudFormationHealths = ( + output: any, + context: __SerdeContext +): CloudFormationHealth[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1CloudFormationHealth(entry, context)); +}; + +const deserializeAws_restJson1CloudWatchMetricsDetail = ( + output: any, + context: __SerdeContext +): CloudWatchMetricsDetail => { + return { + Dimensions: + output.Dimensions !== undefined && output.Dimensions !== null + ? deserializeAws_restJson1CloudWatchMetricsDimensions(output.Dimensions, context) + : undefined, + MetricName: output.MetricName !== undefined && output.MetricName !== null ? output.MetricName : undefined, + Namespace: output.Namespace !== undefined && output.Namespace !== null ? output.Namespace : undefined, + Period: output.Period !== undefined && output.Period !== null ? output.Period : undefined, + Stat: output.Stat !== undefined && output.Stat !== null ? output.Stat : undefined, + Unit: output.Unit !== undefined && output.Unit !== null ? output.Unit : undefined, + } as any; +}; + +const deserializeAws_restJson1CloudWatchMetricsDetails = ( + output: any, + context: __SerdeContext +): CloudWatchMetricsDetail[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1CloudWatchMetricsDetail(entry, context)); +}; + +const deserializeAws_restJson1CloudWatchMetricsDimension = ( + output: any, + context: __SerdeContext +): CloudWatchMetricsDimension => { + return { + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Value: output.Value !== undefined && output.Value !== null ? output.Value : undefined, + } as any; +}; + +const deserializeAws_restJson1CloudWatchMetricsDimensions = ( + output: any, + context: __SerdeContext +): CloudWatchMetricsDimension[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1CloudWatchMetricsDimension(entry, context)); +}; + +const deserializeAws_restJson1Event = (output: any, context: __SerdeContext): Event => { + return { + DataSource: output.DataSource !== undefined && output.DataSource !== null ? output.DataSource : undefined, + EventClass: output.EventClass !== undefined && output.EventClass !== null ? output.EventClass : undefined, + EventSource: output.EventSource !== undefined && output.EventSource !== null ? output.EventSource : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Resources: + output.Resources !== undefined && output.Resources !== null + ? deserializeAws_restJson1EventResources(output.Resources, context) + : undefined, + Time: output.Time !== undefined && output.Time !== null ? new Date(Math.round(output.Time * 1000)) : undefined, + } as any; +}; + +const deserializeAws_restJson1EventResource = (output: any, context: __SerdeContext): EventResource => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + } as any; +}; + +const deserializeAws_restJson1EventResources = (output: any, context: __SerdeContext): EventResource[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1EventResource(entry, context)); +}; + +const deserializeAws_restJson1Events = (output: any, context: __SerdeContext): Event[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1Event(entry, context)); +}; + +const deserializeAws_restJson1InsightHealth = (output: any, context: __SerdeContext): InsightHealth => { + return { + MeanTimeToRecoverInMilliseconds: + output.MeanTimeToRecoverInMilliseconds !== undefined && output.MeanTimeToRecoverInMilliseconds !== null + ? output.MeanTimeToRecoverInMilliseconds + : undefined, + OpenProactiveInsights: + output.OpenProactiveInsights !== undefined && output.OpenProactiveInsights !== null + ? output.OpenProactiveInsights + : undefined, + OpenReactiveInsights: + output.OpenReactiveInsights !== undefined && output.OpenReactiveInsights !== null + ? output.OpenReactiveInsights + : undefined, + } as any; +}; + +const deserializeAws_restJson1InsightTimeRange = (output: any, context: __SerdeContext): InsightTimeRange => { + return { + EndTime: + output.EndTime !== undefined && output.EndTime !== null ? new Date(Math.round(output.EndTime * 1000)) : undefined, + StartTime: + output.StartTime !== undefined && output.StartTime !== null + ? new Date(Math.round(output.StartTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_restJson1NotificationChannel = (output: any, context: __SerdeContext): NotificationChannel => { + return { + Config: + output.Config !== undefined && output.Config !== null + ? deserializeAws_restJson1NotificationChannelConfig(output.Config, context) + : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + } as any; +}; + +const deserializeAws_restJson1NotificationChannelConfig = ( + output: any, + context: __SerdeContext +): NotificationChannelConfig => { + return { + Sns: + output.Sns !== undefined && output.Sns !== null + ? deserializeAws_restJson1SnsChannelConfig(output.Sns, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1OpsCenterIntegration = (output: any, context: __SerdeContext): OpsCenterIntegration => { + return { + OptInStatus: output.OptInStatus !== undefined && output.OptInStatus !== null ? output.OptInStatus : undefined, + } as any; +}; + +const deserializeAws_restJson1PredictionTimeRange = (output: any, context: __SerdeContext): PredictionTimeRange => { + return { + EndTime: + output.EndTime !== undefined && output.EndTime !== null ? new Date(Math.round(output.EndTime * 1000)) : undefined, + StartTime: + output.StartTime !== undefined && output.StartTime !== null + ? new Date(Math.round(output.StartTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ProactiveAnomalies = ( + output: any, + context: __SerdeContext +): ProactiveAnomalySummary[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ProactiveAnomalySummary(entry, context)); +}; + +const deserializeAws_restJson1ProactiveAnomaly = (output: any, context: __SerdeContext): ProactiveAnomaly => { + return { + AnomalyTimeRange: + output.AnomalyTimeRange !== undefined && output.AnomalyTimeRange !== null + ? deserializeAws_restJson1AnomalyTimeRange(output.AnomalyTimeRange, context) + : undefined, + AssociatedInsightId: + output.AssociatedInsightId !== undefined && output.AssociatedInsightId !== null + ? output.AssociatedInsightId + : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + Limit: output.Limit !== undefined && output.Limit !== null ? output.Limit : undefined, + PredictionTimeRange: + output.PredictionTimeRange !== undefined && output.PredictionTimeRange !== null + ? deserializeAws_restJson1PredictionTimeRange(output.PredictionTimeRange, context) + : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SourceDetails: + output.SourceDetails !== undefined && output.SourceDetails !== null + ? deserializeAws_restJson1AnomalySourceDetails(output.SourceDetails, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + UpdateTime: + output.UpdateTime !== undefined && output.UpdateTime !== null + ? new Date(Math.round(output.UpdateTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ProactiveAnomalySummary = ( + output: any, + context: __SerdeContext +): ProactiveAnomalySummary => { + return { + AnomalyTimeRange: + output.AnomalyTimeRange !== undefined && output.AnomalyTimeRange !== null + ? deserializeAws_restJson1AnomalyTimeRange(output.AnomalyTimeRange, context) + : undefined, + AssociatedInsightId: + output.AssociatedInsightId !== undefined && output.AssociatedInsightId !== null + ? output.AssociatedInsightId + : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + Limit: output.Limit !== undefined && output.Limit !== null ? output.Limit : undefined, + PredictionTimeRange: + output.PredictionTimeRange !== undefined && output.PredictionTimeRange !== null + ? deserializeAws_restJson1PredictionTimeRange(output.PredictionTimeRange, context) + : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SourceDetails: + output.SourceDetails !== undefined && output.SourceDetails !== null + ? deserializeAws_restJson1AnomalySourceDetails(output.SourceDetails, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + UpdateTime: + output.UpdateTime !== undefined && output.UpdateTime !== null + ? new Date(Math.round(output.UpdateTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ProactiveInsight = (output: any, context: __SerdeContext): ProactiveInsight => { + return { + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + InsightTimeRange: + output.InsightTimeRange !== undefined && output.InsightTimeRange !== null + ? deserializeAws_restJson1InsightTimeRange(output.InsightTimeRange, context) + : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + PredictionTimeRange: + output.PredictionTimeRange !== undefined && output.PredictionTimeRange !== null + ? deserializeAws_restJson1PredictionTimeRange(output.PredictionTimeRange, context) + : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SsmOpsItemId: output.SsmOpsItemId !== undefined && output.SsmOpsItemId !== null ? output.SsmOpsItemId : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1ProactiveInsights = (output: any, context: __SerdeContext): ProactiveInsightSummary[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ProactiveInsightSummary(entry, context)); +}; + +const deserializeAws_restJson1ProactiveInsightSummary = ( + output: any, + context: __SerdeContext +): ProactiveInsightSummary => { + return { + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + InsightTimeRange: + output.InsightTimeRange !== undefined && output.InsightTimeRange !== null + ? deserializeAws_restJson1InsightTimeRange(output.InsightTimeRange, context) + : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + PredictionTimeRange: + output.PredictionTimeRange !== undefined && output.PredictionTimeRange !== null + ? deserializeAws_restJson1PredictionTimeRange(output.PredictionTimeRange, context) + : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1ReactiveAnomalies = (output: any, context: __SerdeContext): ReactiveAnomalySummary[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ReactiveAnomalySummary(entry, context)); +}; + +const deserializeAws_restJson1ReactiveAnomaly = (output: any, context: __SerdeContext): ReactiveAnomaly => { + return { + AnomalyTimeRange: + output.AnomalyTimeRange !== undefined && output.AnomalyTimeRange !== null + ? deserializeAws_restJson1AnomalyTimeRange(output.AnomalyTimeRange, context) + : undefined, + AssociatedInsightId: + output.AssociatedInsightId !== undefined && output.AssociatedInsightId !== null + ? output.AssociatedInsightId + : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SourceDetails: + output.SourceDetails !== undefined && output.SourceDetails !== null + ? deserializeAws_restJson1AnomalySourceDetails(output.SourceDetails, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1ReactiveAnomalySummary = ( + output: any, + context: __SerdeContext +): ReactiveAnomalySummary => { + return { + AnomalyTimeRange: + output.AnomalyTimeRange !== undefined && output.AnomalyTimeRange !== null + ? deserializeAws_restJson1AnomalyTimeRange(output.AnomalyTimeRange, context) + : undefined, + AssociatedInsightId: + output.AssociatedInsightId !== undefined && output.AssociatedInsightId !== null + ? output.AssociatedInsightId + : undefined, + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SourceDetails: + output.SourceDetails !== undefined && output.SourceDetails !== null + ? deserializeAws_restJson1AnomalySourceDetails(output.SourceDetails, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1ReactiveInsight = (output: any, context: __SerdeContext): ReactiveInsight => { + return { + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + InsightTimeRange: + output.InsightTimeRange !== undefined && output.InsightTimeRange !== null + ? deserializeAws_restJson1InsightTimeRange(output.InsightTimeRange, context) + : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + SsmOpsItemId: output.SsmOpsItemId !== undefined && output.SsmOpsItemId !== null ? output.SsmOpsItemId : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1ReactiveInsights = (output: any, context: __SerdeContext): ReactiveInsightSummary[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ReactiveInsightSummary(entry, context)); +}; + +const deserializeAws_restJson1ReactiveInsightSummary = ( + output: any, + context: __SerdeContext +): ReactiveInsightSummary => { + return { + Id: output.Id !== undefined && output.Id !== null ? output.Id : undefined, + InsightTimeRange: + output.InsightTimeRange !== undefined && output.InsightTimeRange !== null + ? deserializeAws_restJson1InsightTimeRange(output.InsightTimeRange, context) + : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + ResourceCollection: + output.ResourceCollection !== undefined && output.ResourceCollection !== null + ? deserializeAws_restJson1ResourceCollection(output.ResourceCollection, context) + : undefined, + Severity: output.Severity !== undefined && output.Severity !== null ? output.Severity : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_restJson1Recommendation = (output: any, context: __SerdeContext): Recommendation => { + return { + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + Link: output.Link !== undefined && output.Link !== null ? output.Link : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Reason: output.Reason !== undefined && output.Reason !== null ? output.Reason : undefined, + RelatedAnomalies: + output.RelatedAnomalies !== undefined && output.RelatedAnomalies !== null + ? deserializeAws_restJson1RecommendationRelatedAnomalies(output.RelatedAnomalies, context) + : undefined, + RelatedEvents: + output.RelatedEvents !== undefined && output.RelatedEvents !== null + ? deserializeAws_restJson1RecommendationRelatedEvents(output.RelatedEvents, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedAnomalies = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomaly[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1RecommendationRelatedAnomaly(entry, context)); +}; + +const deserializeAws_restJson1RecommendationRelatedAnomaly = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomaly => { + return { + Resources: + output.Resources !== undefined && output.Resources !== null + ? deserializeAws_restJson1RecommendationRelatedAnomalyResources(output.Resources, context) + : undefined, + SourceDetails: + output.SourceDetails !== undefined && output.SourceDetails !== null + ? deserializeAws_restJson1RelatedAnomalySourceDetails(output.SourceDetails, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedAnomalyResource = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomalyResource => { + return { + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedAnomalyResources = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomalyResource[] => { + return (output || []).map((entry: any) => + deserializeAws_restJson1RecommendationRelatedAnomalyResource(entry, context) + ); +}; + +const deserializeAws_restJson1RecommendationRelatedAnomalySourceDetail = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomalySourceDetail => { + return { + CloudWatchMetrics: + output.CloudWatchMetrics !== undefined && output.CloudWatchMetrics !== null + ? deserializeAws_restJson1RecommendationRelatedCloudWatchMetricsSourceDetails(output.CloudWatchMetrics, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedCloudWatchMetricsSourceDetail = ( + output: any, + context: __SerdeContext +): RecommendationRelatedCloudWatchMetricsSourceDetail => { + return { + MetricName: output.MetricName !== undefined && output.MetricName !== null ? output.MetricName : undefined, + Namespace: output.Namespace !== undefined && output.Namespace !== null ? output.Namespace : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedCloudWatchMetricsSourceDetails = ( + output: any, + context: __SerdeContext +): RecommendationRelatedCloudWatchMetricsSourceDetail[] => { + return (output || []).map((entry: any) => + deserializeAws_restJson1RecommendationRelatedCloudWatchMetricsSourceDetail(entry, context) + ); +}; + +const deserializeAws_restJson1RecommendationRelatedEvent = ( + output: any, + context: __SerdeContext +): RecommendationRelatedEvent => { + return { + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Resources: + output.Resources !== undefined && output.Resources !== null + ? deserializeAws_restJson1RecommendationRelatedEventResources(output.Resources, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedEventResource = ( + output: any, + context: __SerdeContext +): RecommendationRelatedEventResource => { + return { + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + } as any; +}; + +const deserializeAws_restJson1RecommendationRelatedEventResources = ( + output: any, + context: __SerdeContext +): RecommendationRelatedEventResource[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1RecommendationRelatedEventResource(entry, context)); +}; + +const deserializeAws_restJson1RecommendationRelatedEvents = ( + output: any, + context: __SerdeContext +): RecommendationRelatedEvent[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1RecommendationRelatedEvent(entry, context)); +}; + +const deserializeAws_restJson1Recommendations = (output: any, context: __SerdeContext): Recommendation[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1Recommendation(entry, context)); +}; + +const deserializeAws_restJson1RelatedAnomalySourceDetails = ( + output: any, + context: __SerdeContext +): RecommendationRelatedAnomalySourceDetail[] => { + return (output || []).map((entry: any) => + deserializeAws_restJson1RecommendationRelatedAnomalySourceDetail(entry, context) + ); +}; + +const deserializeAws_restJson1ResourceCollection = (output: any, context: __SerdeContext): ResourceCollection => { + return { + CloudFormation: + output.CloudFormation !== undefined && output.CloudFormation !== null + ? deserializeAws_restJson1CloudFormationCollection(output.CloudFormation, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ResourceCollectionFilter = ( + output: any, + context: __SerdeContext +): ResourceCollectionFilter => { + return { + CloudFormation: + output.CloudFormation !== undefined && output.CloudFormation !== null + ? deserializeAws_restJson1CloudFormationCollectionFilter(output.CloudFormation, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ServiceIntegrationConfig = ( + output: any, + context: __SerdeContext +): ServiceIntegrationConfig => { + return { + OpsCenter: + output.OpsCenter !== undefined && output.OpsCenter !== null + ? deserializeAws_restJson1OpsCenterIntegration(output.OpsCenter, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1SnsChannelConfig = (output: any, context: __SerdeContext): SnsChannelConfig => { + return { + TopicArn: output.TopicArn !== undefined && output.TopicArn !== null ? output.TopicArn : undefined, + } as any; +}; + +const deserializeAws_restJson1StackNames = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1ValidationExceptionField = ( + output: any, + context: __SerdeContext +): ValidationExceptionField => { + return { + Message: output.Message !== undefined && output.Message !== null ? output.Message : undefined, + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + } as any; +}; + +const deserializeAws_restJson1ValidationExceptionFields = ( + output: any, + context: __SerdeContext +): ValidationExceptionField[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ValidationExceptionField(entry, context)); +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-devops-guru/runtimeConfig.browser.ts b/clients/client-devops-guru/runtimeConfig.browser.ts new file mode 100644 index 000000000000..3d624b5e89fe --- /dev/null +++ b/clients/client-devops-guru/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./DevOpsGuruClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-devops-guru/runtimeConfig.native.ts b/clients/client-devops-guru/runtimeConfig.native.ts new file mode 100644 index 000000000000..00208d07f98a --- /dev/null +++ b/clients/client-devops-guru/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./DevOpsGuruClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-devops-guru/runtimeConfig.shared.ts b/clients/client-devops-guru/runtimeConfig.shared.ts new file mode 100644 index 000000000000..99d656b13a43 --- /dev/null +++ b/clients/client-devops-guru/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2019-12-11", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "devops-guru", +}; diff --git a/clients/client-devops-guru/runtimeConfig.ts b/clients/client-devops-guru/runtimeConfig.ts new file mode 100644 index 000000000000..6b10468c3264 --- /dev/null +++ b/clients/client-devops-guru/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./DevOpsGuruClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-devops-guru/tsconfig.es.json b/clients/client-devops-guru/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-devops-guru/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-devops-guru/tsconfig.json b/clients/client-devops-guru/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-devops-guru/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-directory-service/DirectoryService.ts b/clients/client-directory-service/DirectoryService.ts index 71f658b76f70..2a50a36ce14e 100644 --- a/clients/client-directory-service/DirectoryService.ts +++ b/clients/client-directory-service/DirectoryService.ts @@ -134,6 +134,11 @@ import { DescribeTrustsCommandInput, DescribeTrustsCommandOutput, } from "./commands/DescribeTrustsCommand"; +import { + DisableClientAuthenticationCommand, + DisableClientAuthenticationCommandInput, + DisableClientAuthenticationCommandOutput, +} from "./commands/DisableClientAuthenticationCommand"; import { DisableLDAPSCommand, DisableLDAPSCommandInput, @@ -145,6 +150,11 @@ import { DisableRadiusCommandOutput, } from "./commands/DisableRadiusCommand"; import { DisableSsoCommand, DisableSsoCommandInput, DisableSsoCommandOutput } from "./commands/DisableSsoCommand"; +import { + EnableClientAuthenticationCommand, + EnableClientAuthenticationCommandInput, + EnableClientAuthenticationCommandOutput, +} from "./commands/EnableClientAuthenticationCommand"; import { EnableLDAPSCommand, EnableLDAPSCommandInput, EnableLDAPSCommandOutput } from "./commands/EnableLDAPSCommand"; import { EnableRadiusCommand, @@ -1278,6 +1288,38 @@ export class DirectoryService extends DirectoryServiceClient { } } + /** + *

Disable client authentication for smart cards.

+ */ + public disableClientAuthentication( + args: DisableClientAuthenticationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public disableClientAuthentication( + args: DisableClientAuthenticationCommandInput, + cb: (err: any, data?: DisableClientAuthenticationCommandOutput) => void + ): void; + public disableClientAuthentication( + args: DisableClientAuthenticationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DisableClientAuthenticationCommandOutput) => void + ): void; + public disableClientAuthentication( + args: DisableClientAuthenticationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DisableClientAuthenticationCommandOutput) => void), + cb?: (err: any, data?: DisableClientAuthenticationCommandOutput) => void + ): Promise | void { + const command = new DisableClientAuthenticationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Deactivates LDAP secure calls for the specified directory.

*/ @@ -1365,6 +1407,38 @@ export class DirectoryService extends DirectoryServiceClient { } } + /** + *

Enable client authentication for smardtcards.

+ */ + public enableClientAuthentication( + args: EnableClientAuthenticationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public enableClientAuthentication( + args: EnableClientAuthenticationCommandInput, + cb: (err: any, data?: EnableClientAuthenticationCommandOutput) => void + ): void; + public enableClientAuthentication( + args: EnableClientAuthenticationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: EnableClientAuthenticationCommandOutput) => void + ): void; + public enableClientAuthentication( + args: EnableClientAuthenticationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: EnableClientAuthenticationCommandOutput) => void), + cb?: (err: any, data?: EnableClientAuthenticationCommandOutput) => void + ): Promise | void { + const command = new EnableClientAuthenticationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

Activates the switch for the specific directory to always use LDAP secure calls.

*/ diff --git a/clients/client-directory-service/DirectoryServiceClient.ts b/clients/client-directory-service/DirectoryServiceClient.ts index 772f909e2b24..d8e201136418 100644 --- a/clients/client-directory-service/DirectoryServiceClient.ts +++ b/clients/client-directory-service/DirectoryServiceClient.ts @@ -74,9 +74,17 @@ import { } from "./commands/DescribeSharedDirectoriesCommand"; import { DescribeSnapshotsCommandInput, DescribeSnapshotsCommandOutput } from "./commands/DescribeSnapshotsCommand"; import { DescribeTrustsCommandInput, DescribeTrustsCommandOutput } from "./commands/DescribeTrustsCommand"; +import { + DisableClientAuthenticationCommandInput, + DisableClientAuthenticationCommandOutput, +} from "./commands/DisableClientAuthenticationCommand"; import { DisableLDAPSCommandInput, DisableLDAPSCommandOutput } from "./commands/DisableLDAPSCommand"; import { DisableRadiusCommandInput, DisableRadiusCommandOutput } from "./commands/DisableRadiusCommand"; import { DisableSsoCommandInput, DisableSsoCommandOutput } from "./commands/DisableSsoCommand"; +import { + EnableClientAuthenticationCommandInput, + EnableClientAuthenticationCommandOutput, +} from "./commands/EnableClientAuthenticationCommand"; import { EnableLDAPSCommandInput, EnableLDAPSCommandOutput } from "./commands/EnableLDAPSCommand"; import { EnableRadiusCommandInput, EnableRadiusCommandOutput } from "./commands/EnableRadiusCommand"; import { EnableSsoCommandInput, EnableSsoCommandOutput } from "./commands/EnableSsoCommand"; @@ -214,9 +222,11 @@ export type ServiceInputTypes = | DescribeSharedDirectoriesCommandInput | DescribeSnapshotsCommandInput | DescribeTrustsCommandInput + | DisableClientAuthenticationCommandInput | DisableLDAPSCommandInput | DisableRadiusCommandInput | DisableSsoCommandInput + | EnableClientAuthenticationCommandInput | EnableLDAPSCommandInput | EnableRadiusCommandInput | EnableSsoCommandInput @@ -276,9 +286,11 @@ export type ServiceOutputTypes = | DescribeSharedDirectoriesCommandOutput | DescribeSnapshotsCommandOutput | DescribeTrustsCommandOutput + | DisableClientAuthenticationCommandOutput | DisableLDAPSCommandOutput | DisableRadiusCommandOutput | DisableSsoCommandOutput + | EnableClientAuthenticationCommandOutput | EnableLDAPSCommandOutput | EnableRadiusCommandOutput | EnableSsoCommandOutput diff --git a/clients/client-directory-service/commands/DisableClientAuthenticationCommand.ts b/clients/client-directory-service/commands/DisableClientAuthenticationCommand.ts new file mode 100644 index 000000000000..05e37e2546b9 --- /dev/null +++ b/clients/client-directory-service/commands/DisableClientAuthenticationCommand.ts @@ -0,0 +1,91 @@ +import { DirectoryServiceClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DirectoryServiceClient"; +import { DisableClientAuthenticationRequest, DisableClientAuthenticationResult } from "../models/models_0"; +import { + deserializeAws_json1_1DisableClientAuthenticationCommand, + serializeAws_json1_1DisableClientAuthenticationCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DisableClientAuthenticationCommandInput = DisableClientAuthenticationRequest; +export type DisableClientAuthenticationCommandOutput = DisableClientAuthenticationResult & __MetadataBearer; + +/** + *

Disable client authentication for smart cards.

+ */ +export class DisableClientAuthenticationCommand extends $Command< + DisableClientAuthenticationCommandInput, + DisableClientAuthenticationCommandOutput, + DirectoryServiceClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DisableClientAuthenticationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DirectoryServiceClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DirectoryServiceClient"; + const commandName = "DisableClientAuthenticationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DisableClientAuthenticationRequest.filterSensitiveLog, + outputFilterSensitiveLog: DisableClientAuthenticationResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DisableClientAuthenticationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DisableClientAuthenticationCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DisableClientAuthenticationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-directory-service/commands/EnableClientAuthenticationCommand.ts b/clients/client-directory-service/commands/EnableClientAuthenticationCommand.ts new file mode 100644 index 000000000000..96ed8aafb8e4 --- /dev/null +++ b/clients/client-directory-service/commands/EnableClientAuthenticationCommand.ts @@ -0,0 +1,91 @@ +import { DirectoryServiceClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../DirectoryServiceClient"; +import { EnableClientAuthenticationRequest, EnableClientAuthenticationResult } from "../models/models_0"; +import { + deserializeAws_json1_1EnableClientAuthenticationCommand, + serializeAws_json1_1EnableClientAuthenticationCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type EnableClientAuthenticationCommandInput = EnableClientAuthenticationRequest; +export type EnableClientAuthenticationCommandOutput = EnableClientAuthenticationResult & __MetadataBearer; + +/** + *

Enable client authentication for smardtcards.

+ */ +export class EnableClientAuthenticationCommand extends $Command< + EnableClientAuthenticationCommandInput, + EnableClientAuthenticationCommandOutput, + DirectoryServiceClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: EnableClientAuthenticationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: DirectoryServiceClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "DirectoryServiceClient"; + const commandName = "EnableClientAuthenticationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: EnableClientAuthenticationRequest.filterSensitiveLog, + outputFilterSensitiveLog: EnableClientAuthenticationResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: EnableClientAuthenticationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1EnableClientAuthenticationCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1EnableClientAuthenticationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-directory-service/index.ts b/clients/client-directory-service/index.ts index ed976685ea0e..d66783064c7c 100644 --- a/clients/client-directory-service/index.ts +++ b/clients/client-directory-service/index.ts @@ -32,9 +32,11 @@ export * from "./commands/DescribeRegionsCommand"; export * from "./commands/DescribeSharedDirectoriesCommand"; export * from "./commands/DescribeSnapshotsCommand"; export * from "./commands/DescribeTrustsCommand"; +export * from "./commands/DisableClientAuthenticationCommand"; export * from "./commands/DisableLDAPSCommand"; export * from "./commands/DisableRadiusCommand"; export * from "./commands/DisableSsoCommand"; +export * from "./commands/EnableClientAuthenticationCommand"; export * from "./commands/EnableLDAPSCommand"; export * from "./commands/EnableRadiusCommand"; export * from "./commands/EnableSsoCommand"; diff --git a/clients/client-directory-service/models/models_0.ts b/clients/client-directory-service/models/models_0.ts index 05c880e04468..e4e90b125f3d 100644 --- a/clients/client-directory-service/models/models_0.ts +++ b/clients/client-directory-service/models/models_0.ts @@ -38,15 +38,29 @@ export enum ShareStatus { */ export interface SharedDirectory { /** - *

Current directory status of the shared AWS Managed Microsoft AD directory.

+ *

Identifier of the directory owner account, which contains the directory that has been + * shared to the consumer account.

*/ - ShareStatus?: ShareStatus | string; + OwnerAccountId?: string; /** *

Identifier of the directory in the directory owner account.

*/ OwnerDirectoryId?: string; + /** + *

The method used when sharing a directory to determine whether the directory should be + * shared within your AWS organization (ORGANIZATIONS) or with any AWS account by + * sending a shared directory request (HANDSHAKE).

+ */ + ShareMethod?: ShareMethod | string; + + /** + *

Identifier of the directory consumer account that has access to the shared directory + * (OwnerDirectoryId) in the directory owner account.

+ */ + SharedAccountId?: string; + /** *

Identifier of the shared directory in the directory consumer account. This identifier is * different for each directory owner account.

@@ -54,10 +68,9 @@ export interface SharedDirectory { SharedDirectoryId?: string; /** - *

Identifier of the directory owner account, which contains the directory that has been - * shared to the consumer account.

+ *

Current directory status of the shared AWS Managed Microsoft AD directory.

*/ - OwnerAccountId?: string; + ShareStatus?: ShareStatus | string; /** *

A directory share request that is sent by the directory owner to the directory consumer. @@ -66,13 +79,6 @@ export interface SharedDirectory { */ ShareNotes?: string; - /** - *

The method used when sharing a directory to determine whether the directory should be - * shared within your AWS organization (ORGANIZATIONS) or with any AWS account by - * sending a shared directory request (HANDSHAKE).

- */ - ShareMethod?: ShareMethod | string; - /** *

The date and time that the shared directory was created.

*/ @@ -82,12 +88,6 @@ export interface SharedDirectory { *

The date and time that the shared directory was last updated.

*/ LastUpdatedDateTime?: Date; - - /** - *

Identifier of the directory consumer account that has access to the shared directory - * (OwnerDirectoryId) in the directory owner account.

- */ - SharedAccountId?: string; } export namespace SharedDirectory { @@ -164,14 +164,14 @@ export interface EntityDoesNotExistException extends __SmithyException, $Metadat name: "EntityDoesNotExistException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace EntityDoesNotExistException { @@ -233,14 +233,14 @@ export interface AccessDeniedException extends __SmithyException, $MetadataBeare name: "AccessDeniedException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace AccessDeniedException { @@ -396,14 +396,14 @@ export interface EntityAlreadyExistsException extends __SmithyException, $Metada name: "EntityAlreadyExistsException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace EntityAlreadyExistsException { @@ -439,17 +439,17 @@ export namespace IpRouteLimitExceededException { *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

*/ export interface DirectoryVpcSettings { + /** + *

The identifier of the VPC in which to create the directory.

+ */ + VpcId: string | undefined; + /** *

The identifiers of the subnets for the directory servers. The two subnets must be in * different Availability Zones. AWS Directory Service creates a directory server and a DNS * server in each of these subnets.

*/ SubnetIds: string[] | undefined; - - /** - *

The identifier of the VPC in which to create the directory.

- */ - VpcId: string | undefined; } export namespace DirectoryVpcSettings { @@ -459,11 +459,6 @@ export namespace DirectoryVpcSettings { } export interface AddRegionRequest { - /** - *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

- */ - VPCSettings: DirectoryVpcSettings | undefined; - /** *

The identifier of the directory to which you want to add Region replication.

*/ @@ -473,6 +468,11 @@ export interface AddRegionRequest { *

The name of the Region where you want to add domain controllers for replication. For example, us-east-1.

*/ RegionName: string | undefined; + + /** + *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

+ */ + VPCSettings: DirectoryVpcSettings | undefined; } export namespace AddRegionRequest { @@ -496,14 +496,14 @@ export interface DirectoryAlreadyInRegionException extends __SmithyException, $M name: "DirectoryAlreadyInRegionException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace DirectoryAlreadyInRegionException { @@ -536,7 +536,7 @@ export namespace DirectoryDoesNotExistException { } /** - *

You have reached the limit for maximum number of simultaneous region replications per directory.

+ *

You have reached the limit for maximum number of simultaneous Region replications per directory.

*/ export interface RegionLimitExceededException extends __SmithyException, $MetadataBearer { name: "RegionLimitExceededException"; @@ -565,14 +565,14 @@ export interface UnsupportedOperationException extends __SmithyException, $Metad name: "UnsupportedOperationException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace UnsupportedOperationException { @@ -586,14 +586,14 @@ export namespace UnsupportedOperationException { */ export interface Tag { /** - *

The optional value of the tag. The string value can be Unicode characters. The string can contain only the set of Unicode letters, digits, white-space, '_', '.', '/', '=', '+', '-' (Java regex: "^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-]*)$").

+ *

Required name of the tag. The string value can be Unicode characters and cannot be prefixed with "aws:". The string can contain only the set of Unicode letters, digits, white-space, '_', '.', '/', '=', '+', '-' (Java regex: "^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-]*)$").

*/ - Value: string | undefined; + Key: string | undefined; /** - *

Required name of the tag. The string value can be Unicode characters and cannot be prefixed with "aws:". The string can contain only the set of Unicode letters, digits, white-space, '_', '.', '/', '=', '+', '-' (Java regex: "^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-]*)$").

+ *

The optional value of the tag. The string value can be Unicode characters. The string can contain only the set of Unicode letters, digits, white-space, '_', '.', '/', '=', '+', '-' (Java regex: "^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-]*)$").

*/ - Key: string | undefined; + Value: string | undefined; } export namespace Tag { @@ -635,14 +635,14 @@ export interface TagLimitExceededException extends __SmithyException, $MetadataB name: "TagLimitExceededException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace TagLimitExceededException { @@ -656,14 +656,14 @@ export namespace TagLimitExceededException { */ export interface Attribute { /** - *

The value of the attribute.

+ *

The name of the attribute.

*/ - Value?: string; + Name?: string; /** - *

The name of the attribute.

+ *

The value of the attribute.

*/ - Name?: string; + Value?: string; } export namespace Attribute { @@ -679,14 +679,14 @@ export interface AuthenticationFailedException extends __SmithyException, $Metad name: "AuthenticationFailedException"; $fault: "client"; /** - *

The identifier of the request that caused the exception.

+ *

The textual message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The textual message for the exception.

+ *

The identifier of the request that caused the exception.

*/ - Message?: string; + RequestId?: string; } export namespace AuthenticationFailedException { @@ -721,6 +721,22 @@ export namespace CancelSchemaExtensionResult { }); } +/** + *

Contains information about the client certificate authentication settings, such as ClientLDAPS or ClientCertAuth.

+ */ +export interface ClientCertAuthSettings { + /** + *

Specifies the URL of the default OCSP server used to check for revocation status.

+ */ + OCSPUrl?: string; +} + +export namespace ClientCertAuthSettings { + export const filterSensitiveLog = (obj: ClientCertAuthSettings): any => ({ + ...obj, + }); +} + export enum CertificateState { DEREGISTERED = "Deregistered", DEREGISTERING = "Deregistering", @@ -730,6 +746,11 @@ export enum CertificateState { REGISTER_FAILED = "RegisterFailed", } +export enum CertificateType { + CLIENT_CERT_AUTH = "ClientCertAuth", + CLIENT_LDAPS = "ClientLDAPS", +} + /** *

Information about the certificate.

*/ @@ -739,6 +760,11 @@ export interface Certificate { */ CertificateId?: string; + /** + *

The state of the certificate.

+ */ + State?: CertificateState | string; + /** *

Describes a state change for the certificate.

*/ @@ -749,20 +775,25 @@ export interface Certificate { */ CommonName?: string; + /** + *

The date and time that the certificate was registered.

+ */ + RegisteredDateTime?: Date; + /** *

The date and time when the certificate will expire.

*/ ExpiryDateTime?: Date; /** - *

The state of the certificate.

+ *

Select ClientCertAuth for smart card integration.

*/ - State?: CertificateState | string; + Type?: CertificateType | string; /** - *

The date and time that the certificate was registered.

+ *

Provides information about the client certificate authentication settings. The default value is ClientLDAPS.

*/ - RegisteredDateTime?: Date; + ClientCertAuthSettings?: ClientCertAuthSettings; } export namespace Certificate { @@ -801,14 +832,14 @@ export interface CertificateDoesNotExistException extends __SmithyException, $Me name: "CertificateDoesNotExistException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace CertificateDoesNotExistException { @@ -821,6 +852,16 @@ export namespace CertificateDoesNotExistException { *

Contains general information about a certificate.

*/ export interface CertificateInfo { + /** + *

The identifier of the certificate.

+ */ + CertificateId?: string; + + /** + *

The common name for the certificate.

+ */ + CommonName?: string; + /** *

The state of the certificate.

*/ @@ -832,14 +873,9 @@ export interface CertificateInfo { ExpiryDateTime?: Date; /** - *

The identifier of the certificate.

- */ - CertificateId?: string; - - /** - *

The common name for the certificate.

+ *

Displays the type of certificate.

*/ - CommonName?: string; + Type?: CertificateType | string; } export namespace CertificateInfo { @@ -856,14 +892,14 @@ export interface CertificateInUseException extends __SmithyException, $MetadataB name: "CertificateInUseException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace CertificateInUseException { @@ -879,14 +915,14 @@ export interface CertificateLimitExceededException extends __SmithyException, $M name: "CertificateLimitExceededException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace CertificateLimitExceededException { @@ -895,16 +931,14 @@ export namespace CertificateLimitExceededException { }); } +export enum ClientAuthenticationType { + SMART_CARD = "SmartCard", +} + /** *

Contains information about a computer account in a directory.

*/ export interface Computer { - /** - *

An array of Attribute objects containing the LDAP attributes that belong to the - * computer account.

- */ - ComputerAttributes?: Attribute[]; - /** *

The identifier of the computer.

*/ @@ -914,6 +948,12 @@ export interface Computer { *

The computer name.

*/ ComputerName?: string; + + /** + *

An array of Attribute objects containing the LDAP attributes that belong to the + * computer account.

+ */ + ComputerAttributes?: Attribute[]; } export namespace Computer { @@ -1009,41 +1049,41 @@ export enum DirectorySize { */ export interface ConnectDirectoryRequest { /** - *

A description for the directory.

+ *

The fully qualified name of the on-premises directory, such as + * corp.example.com.

*/ - Description?: string; + Name: string | undefined; /** - *

The size of the directory.

+ *

The NetBIOS name of the on-premises directory, such as CORP.

*/ - Size: DirectorySize | string | undefined; + ShortName?: string; /** - *

The NetBIOS name of the on-premises directory, such as CORP.

+ *

The password for the on-premises user account.

*/ - ShortName?: string; + Password: string | undefined; /** - *

A DirectoryConnectSettings object that contains additional information - * for the operation.

+ *

A description for the directory.

*/ - ConnectSettings: DirectoryConnectSettings | undefined; + Description?: string; /** - *

The tags to be assigned to AD Connector.

+ *

The size of the directory.

*/ - Tags?: Tag[]; + Size: DirectorySize | string | undefined; /** - *

The fully qualified name of the on-premises directory, such as - * corp.example.com.

+ *

A DirectoryConnectSettings object that contains additional information + * for the operation.

*/ - Name: string | undefined; + ConnectSettings: DirectoryConnectSettings | undefined; /** - *

The password for the on-premises user account.

+ *

The tags to be assigned to AD Connector.

*/ - Password: string | undefined; + Tags?: Tag[]; } export namespace ConnectDirectoryRequest { @@ -1078,14 +1118,14 @@ export interface DirectoryLimitExceededException extends __SmithyException, $Met name: "DirectoryLimitExceededException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace DirectoryLimitExceededException { @@ -1143,9 +1183,9 @@ export namespace CreateAliasResult { */ export interface CreateComputerRequest { /** - *

The fully-qualified distinguished name of the organizational unit to place the computer account in.

+ *

The identifier of the directory in which to create the computer account.

*/ - OrganizationalUnitDistinguishedName?: string; + DirectoryId: string | undefined; /** *

The name of the computer account.

@@ -1153,20 +1193,20 @@ export interface CreateComputerRequest { ComputerName: string | undefined; /** - *

The identifier of the directory in which to create the computer account.

+ *

A one-time password that is used to join the computer to the directory. You should generate a random, strong password to use for this parameter.

*/ - DirectoryId: string | undefined; + Password: string | undefined; /** - *

An array of Attribute objects that contain any LDAP attributes to apply to the - * computer account.

+ *

The fully-qualified distinguished name of the organizational unit to place the computer account in.

*/ - ComputerAttributes?: Attribute[]; + OrganizationalUnitDistinguishedName?: string; /** - *

A one-time password that is used to join the computer to the directory. You should generate a random, strong password to use for this parameter.

+ *

An array of Attribute objects that contain any LDAP attributes to apply to the + * computer account.

*/ - Password: string | undefined; + ComputerAttributes?: Attribute[]; } export namespace CreateComputerRequest { @@ -1196,11 +1236,6 @@ export namespace CreateComputerResult { *

Initiates the creation of a conditional forwarder for your AWS Directory Service for Microsoft Active Directory. Conditional forwarders are required in order to set up a trust relationship with another domain.

*/ export interface CreateConditionalForwarderRequest { - /** - *

The IP addresses of the remote DNS server associated with RemoteDomainName.

- */ - DnsIpAddrs: string[] | undefined; - /** *

The directory ID of the AWS directory for which you are creating the conditional forwarder.

*/ @@ -1210,6 +1245,11 @@ export interface CreateConditionalForwarderRequest { *

The fully qualified domain name (FQDN) of the remote domain with which you will set up a trust relationship.

*/ RemoteDomainName: string | undefined; + + /** + *

The IP addresses of the remote DNS server associated with RemoteDomainName.

+ */ + DnsIpAddrs: string[] | undefined; } export namespace CreateConditionalForwarderRequest { @@ -1234,25 +1274,9 @@ export namespace CreateConditionalForwarderResult { */ export interface CreateDirectoryRequest { /** - *

The tags to be assigned to the Simple AD directory.

- */ - Tags?: Tag[]; - - /** - *

A DirectoryVpcSettings object that contains additional information for - * the operation.

- */ - VpcSettings?: DirectoryVpcSettings; - - /** - *

A description for the directory.

- */ - Description?: string; - - /** - *

The size of the directory.

+ *

The fully qualified name for the directory, such as corp.example.com.

*/ - Size: DirectorySize | string | undefined; + Name: string | undefined; /** *

The NetBIOS name of the directory, such as CORP.

@@ -1290,9 +1314,25 @@ export interface CreateDirectoryRequest { Password: string | undefined; /** - *

The fully qualified name for the directory, such as corp.example.com.

+ *

A description for the directory.

*/ - Name: string | undefined; + Description?: string; + + /** + *

The size of the directory.

+ */ + Size: DirectorySize | string | undefined; + + /** + *

A DirectoryVpcSettings object that contains additional information for + * the operation.

+ */ + VpcSettings?: DirectoryVpcSettings; + + /** + *

The tags to be assigned to the Simple AD directory.

+ */ + Tags?: Tag[]; } export namespace CreateDirectoryRequest { @@ -1319,17 +1359,17 @@ export namespace CreateDirectoryResult { } export interface CreateLogSubscriptionRequest { - /** - *

The name of the CloudWatch log group where the real-time domain controller logs are - * forwarded.

- */ - LogGroupName: string | undefined; - /** *

Identifier of the directory to which you want to subscribe and receive real-time logs to * your specified CloudWatch log group.

*/ DirectoryId: string | undefined; + + /** + *

The name of the CloudWatch log group where the real-time domain controller logs are + * forwarded.

+ */ + LogGroupName: string | undefined; } export namespace CreateLogSubscriptionRequest { @@ -1378,17 +1418,6 @@ export enum DirectoryEdition { *

Creates an AWS Managed Microsoft AD directory.

*/ export interface CreateMicrosoftADRequest { - /** - *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

- */ - VpcSettings: DirectoryVpcSettings | undefined; - - /** - *

The password for the default administrative user named Admin.

- *

If you need to change the password for the administrator account, you can use the ResetUserPassword API call.

- */ - Password: string | undefined; - /** *

The fully qualified domain name for the AWS Managed Microsoft AD directory, such as * corp.example.com. This name will resolve inside your VPC only. It does not need @@ -1397,24 +1426,35 @@ export interface CreateMicrosoftADRequest { Name: string | undefined; /** - *

The tags to be assigned to the AWS Managed Microsoft AD directory.

+ *

The NetBIOS name for your domain, such as CORP. If you don't specify a NetBIOS name, it will default to the first part of your directory DNS. For example, CORP for the directory DNS corp.example.com.

*/ - Tags?: Tag[]; + ShortName?: string; + + /** + *

The password for the default administrative user named Admin.

+ *

If you need to change the password for the administrator account, you can use the ResetUserPassword API call.

+ */ + Password: string | undefined; /** *

A description for the directory. This label will appear on the AWS console Directory Details page after the directory is created.

*/ Description?: string; + /** + *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

+ */ + VpcSettings: DirectoryVpcSettings | undefined; + /** *

AWS Managed Microsoft AD is available in two editions: Standard and Enterprise. Enterprise is the default.

*/ Edition?: DirectoryEdition | string; /** - *

The NetBIOS name for your domain, such as CORP. If you don't specify a NetBIOS name, it will default to the first part of your directory DNS. For example, CORP for the directory DNS corp.example.com.

+ *

The tags to be assigned to the AWS Managed Microsoft AD directory.

*/ - ShortName?: string; + Tags?: Tag[]; } export namespace CreateMicrosoftADRequest { @@ -1445,14 +1485,14 @@ export namespace CreateMicrosoftADResult { */ export interface CreateSnapshotRequest { /** - *

The descriptive name to apply to the snapshot.

+ *

The identifier of the directory of which to take a snapshot.

*/ - Name?: string; + DirectoryId: string | undefined; /** - *

The identifier of the directory of which to take a snapshot.

+ *

The descriptive name to apply to the snapshot.

*/ - DirectoryId: string | undefined; + Name?: string; } export namespace CreateSnapshotRequest { @@ -1486,14 +1526,14 @@ export interface SnapshotLimitExceededException extends __SmithyException, $Meta name: "SnapshotLimitExceededException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace SnapshotLimitExceededException { @@ -1524,29 +1564,29 @@ export enum TrustType { */ export interface CreateTrustRequest { /** - *

The direction of the trust relationship.

+ *

The Directory ID of the AWS Managed Microsoft AD directory for which to establish the trust relationship.

*/ - TrustDirection: TrustDirection | string | undefined; + DirectoryId: string | undefined; /** - *

The trust password. The must be the same password that was used when creating the trust relationship on the external domain.

+ *

The Fully Qualified Domain Name (FQDN) of the external domain for which to create the trust relationship.

*/ - TrustPassword: string | undefined; + RemoteDomainName: string | undefined; /** - *

The Directory ID of the AWS Managed Microsoft AD directory for which to establish the trust relationship.

+ *

The trust password. The must be the same password that was used when creating the trust relationship on the external domain.

*/ - DirectoryId: string | undefined; + TrustPassword: string | undefined; /** - *

Optional parameter to enable selective authentication for the trust.

+ *

The direction of the trust relationship.

*/ - SelectiveAuth?: SelectiveAuth | string; + TrustDirection: TrustDirection | string | undefined; /** - *

The Fully Qualified Domain Name (FQDN) of the external domain for which to create the trust relationship.

+ *

The trust relationship type. Forest is the default.

*/ - RemoteDomainName: string | undefined; + TrustType?: TrustType | string; /** *

The IP addresses of the remote DNS server associated with RemoteDomainName.

@@ -1554,9 +1594,9 @@ export interface CreateTrustRequest { ConditionalForwarderIpAddrs?: string[]; /** - *

The trust relationship type. Forest is the default.

+ *

Optional parameter to enable selective authentication for the trust.

*/ - TrustType?: TrustType | string; + SelectiveAuth?: SelectiveAuth | string; } export namespace CreateTrustRequest { @@ -1738,14 +1778,14 @@ export namespace DeleteTrustResult { export interface DeregisterCertificateRequest { /** - *

The identifier of the certificate.

+ *

The identifier of the directory.

*/ - CertificateId: string | undefined; + DirectoryId: string | undefined; /** - *

The identifier of the directory.

+ *

The identifier of the certificate.

*/ - DirectoryId: string | undefined; + CertificateId: string | undefined; } export namespace DeregisterCertificateRequest { @@ -1831,14 +1871,14 @@ export namespace DescribeCertificateResult { */ export interface DescribeConditionalForwardersRequest { /** - *

The fully qualified domain names (FQDN) of the remote domains for which to get the list of associated conditional forwarders. If this member is null, all conditional forwarders are returned.

+ *

The directory ID for which to get the list of associated conditional forwarders.

*/ - RemoteDomainNames?: string[]; + DirectoryId: string | undefined; /** - *

The directory ID for which to get the list of associated conditional forwarders.

+ *

The fully qualified domain names (FQDN) of the remote domains for which to get the list of associated conditional forwarders. If this member is null, all conditional forwarders are returned.

*/ - DirectoryId: string | undefined; + RemoteDomainNames?: string[]; } export namespace DescribeConditionalForwardersRequest { @@ -1867,6 +1907,13 @@ export namespace DescribeConditionalForwardersResult { *

Contains the inputs for the DescribeDirectories operation.

*/ export interface DescribeDirectoriesRequest { + /** + *

A list of identifiers of the directories for which to obtain the information. If this + * member is null, all directories that belong to the current account are returned.

+ *

An empty list results in an InvalidParameterException being thrown.

+ */ + DirectoryIds?: string[]; + /** *

The DescribeDirectoriesResult.NextToken value from a previous call to DescribeDirectories. Pass null if this is the first call.

*/ @@ -1877,13 +1924,6 @@ export interface DescribeDirectoriesRequest { * is specified by the limitations of the operation.

*/ Limit?: number; - - /** - *

A list of identifiers of the directories for which to obtain the information. If this - * member is null, all directories that belong to the current account are returned.

- *

An empty list results in an InvalidParameterException being thrown.

- */ - DirectoryIds?: string[]; } export namespace DescribeDirectoriesRequest { @@ -1896,11 +1936,6 @@ export namespace DescribeDirectoriesRequest { *

Contains information about an AD Connector directory.

*/ export interface DirectoryConnectSettingsDescription { - /** - *

A list of the Availability Zones that the directory is in.

- */ - AvailabilityZones?: string[]; - /** *

The identifier of the VPC that the AD Connector is in.

*/ @@ -1917,14 +1952,19 @@ export interface DirectoryConnectSettingsDescription { CustomerUserName?: string; /** - *

The IP addresses of the AD Connector servers.

+ *

The security group identifier for the AD Connector directory.

*/ - ConnectIps?: string[]; + SecurityGroupId?: string; /** - *

The security group identifier for the AD Connector directory.

+ *

A list of the Availability Zones that the directory is in.

*/ - SecurityGroupId?: string; + AvailabilityZones?: string[]; + + /** + *

The IP addresses of the AD Connector servers.

+ */ + ConnectIps?: string[]; } export namespace DirectoryConnectSettingsDescription { @@ -1945,19 +1985,19 @@ export enum RadiusAuthenticationProtocol { */ export interface RadiusSettings { /** - *

Not currently used.

+ *

An array of strings that contains the fully qualified domain name (FQDN) or IP addresses of the RADIUS server endpoints, or the FQDN or IP addresses of your RADIUS server load balancer.

*/ - DisplayLabel?: string; + RadiusServers?: string[]; /** - *

Required for enabling RADIUS on the directory.

+ *

The port that your RADIUS server is using for communications. Your on-premises network must allow inbound traffic over this port from the AWS Directory Service servers.

*/ - SharedSecret?: string; + RadiusPort?: number; /** - *

The port that your RADIUS server is using for communications. Your on-premises network must allow inbound traffic over this port from the AWS Directory Service servers.

+ *

The amount of time, in seconds, to wait for the RADIUS server to respond.

*/ - RadiusPort?: number; + RadiusTimeout?: number; /** *

The maximum number of times that communication with the RADIUS server is attempted.

@@ -1965,24 +2005,24 @@ export interface RadiusSettings { RadiusRetries?: number; /** - *

The protocol specified for your RADIUS endpoints.

+ *

Required for enabling RADIUS on the directory.

*/ - AuthenticationProtocol?: RadiusAuthenticationProtocol | string; + SharedSecret?: string; /** - *

Not currently used.

+ *

The protocol specified for your RADIUS endpoints.

*/ - UseSameUsername?: boolean; + AuthenticationProtocol?: RadiusAuthenticationProtocol | string; /** - *

The amount of time, in seconds, to wait for the RADIUS server to respond.

+ *

Not currently used.

*/ - RadiusTimeout?: number; + DisplayLabel?: string; /** - *

An array of strings that contains the fully qualified domain name (FQDN) or IP addresses of the RADIUS server endpoints, or the FQDN or IP addresses of your RADIUS server load balancer.

+ *

Not currently used.

*/ - RadiusServers?: string[]; + UseSameUsername?: boolean; } export namespace RadiusSettings { @@ -2003,24 +2043,24 @@ export enum RadiusStatus { */ export interface DirectoryVpcSettingsDescription { /** - *

The domain controller security group identifier for the directory.

+ *

The identifier of the VPC that the directory is in.

*/ - SecurityGroupId?: string; + VpcId?: string; /** - *

The identifier of the VPC that the directory is in.

+ *

The identifiers of the subnets for the directory servers.

*/ - VpcId?: string; + SubnetIds?: string[]; /** - *

The list of Availability Zones that the directory is in.

+ *

The domain controller security group identifier for the directory.

*/ - AvailabilityZones?: string[]; + SecurityGroupId?: string; /** - *

The identifiers of the subnets for the directory servers.

+ *

The list of Availability Zones that the directory is in.

*/ - SubnetIds?: string[]; + AvailabilityZones?: string[]; } export namespace DirectoryVpcSettingsDescription { @@ -2034,22 +2074,6 @@ export namespace DirectoryVpcSettingsDescription { * consumer account.

*/ export interface OwnerDirectoryDescription { - /** - *

A RadiusSettings object that contains information about the RADIUS - * server.

- */ - RadiusSettings?: RadiusSettings; - - /** - *

IP address of the directory’s domain controllers.

- */ - DnsIpAddrs?: string[]; - - /** - *

Information about the status of the RADIUS server.

- */ - RadiusStatus?: RadiusStatus | string; - /** *

Identifier of the AWS Managed Microsoft AD directory in the directory owner * account.

@@ -2061,10 +2085,26 @@ export interface OwnerDirectoryDescription { */ AccountId?: string; + /** + *

IP address of the directory’s domain controllers.

+ */ + DnsIpAddrs?: string[]; + /** *

Information about the VPC settings for the directory.

*/ VpcSettings?: DirectoryVpcSettingsDescription; + + /** + *

A RadiusSettings object that contains information about the RADIUS + * server.

+ */ + RadiusSettings?: RadiusSettings; + + /** + *

Information about the status of the RADIUS server.

+ */ + RadiusStatus?: RadiusStatus | string; } export namespace OwnerDirectoryDescription { @@ -2079,7 +2119,7 @@ export namespace OwnerDirectoryDescription { */ export interface RegionsInfo { /** - *

The Region from where the AWS Managed Microsoft AD directory was originally created.

+ *

The Region where the AWS Managed Microsoft AD directory was originally created.

*/ PrimaryRegion?: string; @@ -2121,31 +2161,29 @@ export enum DirectoryType { */ export interface DirectoryDescription { /** - *

Current directory status of the shared AWS Managed Microsoft AD directory.

+ *

The directory identifier.

*/ - ShareStatus?: ShareStatus | string; + DirectoryId?: string; /** - *

The current stage of the directory.

+ *

The fully qualified name of the directory.

*/ - Stage?: DirectoryStage | string; + Name?: string; /** - *

A DirectoryConnectSettingsDescription object that contains additional - * information about an AD Connector directory. This member is only present if the directory is - * an AD Connector directory.

+ *

The short name of the directory.

*/ - ConnectSettings?: DirectoryConnectSettingsDescription; + ShortName?: string; /** - *

Specifies when the directory was created.

+ *

The directory size.

*/ - LaunchTime?: Date; + Size?: DirectorySize | string; /** - *

Additional information about the directory stage.

+ *

The edition associated with this directory.

*/ - StageReason?: string; + Edition?: DirectoryEdition | string; /** *

The alias for the directory. If no alias has been created for the directory, the alias is @@ -2153,18 +2191,6 @@ export interface DirectoryDescription { */ Alias?: string; - /** - *

The desired number of domain controllers in the directory if the directory is Microsoft AD.

- */ - DesiredNumberOfDomainControllers?: number; - - /** - *

The method used when sharing a directory to determine whether the directory should be - * shared within your AWS organization (ORGANIZATIONS) or with any AWS account by - * sending a shared directory request (HANDSHAKE).

- */ - ShareMethod?: ShareMethod | string; - /** *

The access URL for the directory, such as * http://.awsapps.com. If no alias has been created for the @@ -2174,47 +2200,46 @@ export interface DirectoryDescription { AccessUrl?: string; /** - *

The directory size.

- */ - Size?: DirectorySize | string; - - /** - *

A directory share request that is sent by the directory owner to the directory consumer. - * The request includes a typed message to help the directory consumer administrator determine - * whether to approve or reject the share invitation.

+ *

The description for the directory.

*/ - ShareNotes?: string; + Description?: string; /** - *

The directory size.

+ *

The IP addresses of the DNS servers for the directory. For a Simple AD or Microsoft AD + * directory, these are the IP addresses of the Simple AD or Microsoft AD directory servers. For + * an AD Connector directory, these are the IP addresses of the DNS servers or domain controllers + * in the on-premises directory to which the AD Connector is connected.

*/ - Type?: DirectoryType | string; + DnsIpAddrs?: string[]; /** - *

The short name of the directory.

+ *

The current stage of the directory.

*/ - ShortName?: string; + Stage?: DirectoryStage | string; /** - *

The status of the RADIUS MFA server connection.

+ *

Current directory status of the shared AWS Managed Microsoft AD directory.

*/ - RadiusStatus?: RadiusStatus | string; + ShareStatus?: ShareStatus | string; /** - *

Describes the AWS Managed Microsoft AD directory in the directory owner account.

+ *

The method used when sharing a directory to determine whether the directory should be + * shared within your AWS organization (ORGANIZATIONS) or with any AWS account by + * sending a shared directory request (HANDSHAKE).

*/ - OwnerDirectoryDescription?: OwnerDirectoryDescription; + ShareMethod?: ShareMethod | string; /** - *

The description for the directory.

+ *

A directory share request that is sent by the directory owner to the directory consumer. + * The request includes a typed message to help the directory consumer administrator determine + * whether to approve or reject the share invitation.

*/ - Description?: string; + ShareNotes?: string; /** - *

A RadiusSettings object that contains information about the RADIUS - * server configured for this directory.

+ *

Specifies when the directory was created.

*/ - RadiusSettings?: RadiusSettings; + LaunchTime?: Date; /** *

The date and time that the stage was last updated.

@@ -2222,9 +2247,9 @@ export interface DirectoryDescription { StageLastUpdatedDateTime?: Date; /** - *

The fully qualified name of the directory.

+ *

The directory size.

*/ - Name?: string; + Type?: DirectoryType | string; /** *

A DirectoryVpcSettingsDescription object that contains additional @@ -2234,14 +2259,27 @@ export interface DirectoryDescription { VpcSettings?: DirectoryVpcSettingsDescription; /** - *

The directory identifier.

+ *

A DirectoryConnectSettingsDescription object that contains additional + * information about an AD Connector directory. This member is only present if the directory is + * an AD Connector directory.

*/ - DirectoryId?: string; + ConnectSettings?: DirectoryConnectSettingsDescription; /** - *

The edition associated with this directory.

+ *

A RadiusSettings object that contains information about the RADIUS + * server configured for this directory.

*/ - Edition?: DirectoryEdition | string; + RadiusSettings?: RadiusSettings; + + /** + *

The status of the RADIUS MFA server connection.

+ */ + RadiusStatus?: RadiusStatus | string; + + /** + *

Additional information about the directory stage.

+ */ + StageReason?: string; /** *

Indicates if single sign-on is enabled for the directory. For more information, see EnableSso and DisableSso.

@@ -2249,27 +2287,29 @@ export interface DirectoryDescription { SsoEnabled?: boolean; /** - *

Lists the Regions where the directory has replicated.

+ *

The desired number of domain controllers in the directory if the directory is Microsoft AD.

*/ - RegionsInfo?: RegionsInfo; + DesiredNumberOfDomainControllers?: number; /** - *

The IP addresses of the DNS servers for the directory. For a Simple AD or Microsoft AD - * directory, these are the IP addresses of the Simple AD or Microsoft AD directory servers. For - * an AD Connector directory, these are the IP addresses of the DNS servers or domain controllers - * in the on-premises directory to which the AD Connector is connected.

+ *

Describes the AWS Managed Microsoft AD directory in the directory owner account.

*/ - DnsIpAddrs?: string[]; + OwnerDirectoryDescription?: OwnerDirectoryDescription; + + /** + *

Lists the Regions where the directory has replicated.

+ */ + RegionsInfo?: RegionsInfo; } export namespace DirectoryDescription { export const filterSensitiveLog = (obj: DirectoryDescription): any => ({ ...obj, ...(obj.ShareNotes && { ShareNotes: SENSITIVE_STRING }), + ...(obj.RadiusSettings && { RadiusSettings: RadiusSettings.filterSensitiveLog(obj.RadiusSettings) }), ...(obj.OwnerDirectoryDescription && { OwnerDirectoryDescription: OwnerDirectoryDescription.filterSensitiveLog(obj.OwnerDirectoryDescription), }), - ...(obj.RadiusSettings && { RadiusSettings: RadiusSettings.filterSensitiveLog(obj.RadiusSettings) }), }); } @@ -2277,13 +2317,6 @@ export namespace DirectoryDescription { *

Contains the results of the DescribeDirectories operation.

*/ export interface DescribeDirectoriesResult { - /** - *

If not null, more results are available. Pass this value for the NextToken - * parameter in a subsequent call to DescribeDirectories to retrieve the next - * set of items.

- */ - NextToken?: string; - /** *

The list of DirectoryDescription objects that were retrieved.

*

It is possible that this list contains less than the number of items specified in the @@ -2292,6 +2325,13 @@ export interface DescribeDirectoriesResult { * exceeded.

*/ DirectoryDescriptions?: DirectoryDescription[]; + + /** + *

If not null, more results are available. Pass this value for the NextToken + * parameter in a subsequent call to DescribeDirectories to retrieve the next + * set of items.

+ */ + NextToken?: string; } export namespace DescribeDirectoriesResult { @@ -2310,14 +2350,14 @@ export interface InvalidNextTokenException extends __SmithyException, $MetadataB name: "InvalidNextTokenException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace InvalidNextTokenException { @@ -2328,9 +2368,9 @@ export namespace InvalidNextTokenException { export interface DescribeDomainControllersRequest { /** - *

The DescribeDomainControllers.NextToken value from a previous call to DescribeDomainControllers. Pass null if this is the first call.

+ *

Identifier of the directory for which to retrieve the domain controller information.

*/ - NextToken?: string; + DirectoryId: string | undefined; /** *

A list of identifiers for the domain controllers whose information will be provided.

@@ -2338,9 +2378,9 @@ export interface DescribeDomainControllersRequest { DomainControllerIds?: string[]; /** - *

Identifier of the directory for which to retrieve the domain controller information.

+ *

The DescribeDomainControllers.NextToken value from a previous call to DescribeDomainControllers. Pass null if this is the first call.

*/ - DirectoryId: string | undefined; + NextToken?: string; /** *

The maximum number of items to return.

@@ -2368,25 +2408,20 @@ export enum DomainControllerStatus { *

Contains information about the domain controllers for a specified directory.

*/ export interface DomainController { - /** - *

The IP address of the domain controller.

- */ - DnsIpAddr?: string; - /** *

Identifier of the directory where the domain controller resides.

*/ DirectoryId?: string; /** - *

Specifies when the domain controller was created.

+ *

Identifies a specific domain controller in the directory.

*/ - LaunchTime?: Date; + DomainControllerId?: string; /** - *

The date and time that the status was last updated.

+ *

The IP address of the domain controller.

*/ - StatusLastUpdatedDateTime?: Date; + DnsIpAddr?: string; /** *

The identifier of the VPC that contains the domain controller.

@@ -2394,14 +2429,14 @@ export interface DomainController { VpcId?: string; /** - *

Identifies a specific domain controller in the directory.

+ *

Identifier of the subnet in the VPC that contains the domain controller.

*/ - DomainControllerId?: string; + SubnetId?: string; /** - *

Identifier of the subnet in the VPC that contains the domain controller.

+ *

The Availability Zone where the domain controller is located.

*/ - SubnetId?: string; + AvailabilityZone?: string; /** *

The status of the domain controller.

@@ -2409,14 +2444,19 @@ export interface DomainController { Status?: DomainControllerStatus | string; /** - *

The Availability Zone where the domain controller is located.

+ *

A description of the domain controller state.

*/ - AvailabilityZone?: string; + StatusReason?: string; /** - *

A description of the domain controller state.

+ *

Specifies when the domain controller was created.

*/ - StatusReason?: string; + LaunchTime?: Date; + + /** + *

The date and time that the status was last updated.

+ */ + StatusLastUpdatedDateTime?: Date; } export namespace DomainController { @@ -2448,15 +2488,15 @@ export namespace DescribeDomainControllersResult { */ export interface DescribeEventTopicsRequest { /** - *

A list of SNS topic names for which to obtain the information. If this member is null, all associations for the specified Directory ID are returned.

- *

An empty list results in an InvalidParameterException being thrown.

+ *

The Directory ID for which to get the list of associated SNS topics. If this member is null, associations for all Directory IDs are returned.

*/ - TopicNames?: string[]; + DirectoryId?: string; /** - *

The Directory ID for which to get the list of associated SNS topics. If this member is null, associations for all Directory IDs are returned.

+ *

A list of SNS topic names for which to obtain the information. If this member is null, all associations for the specified Directory ID are returned.

+ *

An empty list results in an InvalidParameterException being thrown.

*/ - DirectoryId?: string; + TopicNames?: string[]; } export namespace DescribeEventTopicsRequest { @@ -2482,24 +2522,24 @@ export interface EventTopic { DirectoryId?: string; /** - *

The SNS topic ARN (Amazon Resource Name).

+ *

The name of an AWS SNS topic the receives status messages from the directory.

*/ - TopicArn?: string; + TopicName?: string; /** - *

The topic registration status.

+ *

The SNS topic ARN (Amazon Resource Name).

*/ - Status?: TopicStatus | string; + TopicArn?: string; /** - *

The name of an AWS SNS topic the receives status messages from the directory.

+ *

The date and time of when you associated your directory with the SNS topic.

*/ - TopicName?: string; + CreatedDateTime?: Date; /** - *

The date and time of when you associated your directory with the SNS topic.

+ *

The topic registration status.

*/ - CreatedDateTime?: Date; + Status?: TopicStatus | string; } export namespace EventTopic { @@ -2530,9 +2570,9 @@ export enum LDAPSType { export interface DescribeLDAPSSettingsRequest { /** - *

The type of next token used for pagination.

+ *

The identifier of the directory.

*/ - NextToken?: string; + DirectoryId: string | undefined; /** *

The type of LDAP security to enable. Currently only the value Client is @@ -2541,9 +2581,9 @@ export interface DescribeLDAPSSettingsRequest { Type?: LDAPSType | string; /** - *

The identifier of the directory.

+ *

The type of next token used for pagination.

*/ - DirectoryId: string | undefined; + NextToken?: string; /** *

Specifies the number of items that should be displayed on one page.

@@ -2569,9 +2609,9 @@ export enum LDAPSStatus { */ export interface LDAPSSettingInfo { /** - *

The date and time when the LDAPS settings were last updated.

+ *

The state of the LDAPS settings.

*/ - LastUpdatedDateTime?: Date; + LDAPSStatus?: LDAPSStatus | string; /** *

Describes a state change for LDAPS.

@@ -2579,9 +2619,9 @@ export interface LDAPSSettingInfo { LDAPSStatusReason?: string; /** - *

The state of the LDAPS settings.

+ *

The date and time when the LDAPS settings were last updated.

*/ - LDAPSStatus?: LDAPSStatus | string; + LastUpdatedDateTime?: Date; } export namespace LDAPSSettingInfo { @@ -2622,7 +2662,7 @@ export interface DescribeRegionsRequest { RegionName?: string; /** - *

The DescribeRegionsResult.NextToken value from a previous call to + *

The DescribeRegionsResult.NextToken value from a previous call to * DescribeRegions. Pass null if this is the first call.

*/ NextToken?: string; @@ -2640,18 +2680,13 @@ export enum RegionType { } /** - *

The replicated regional information for a directory.

+ *

The replicated Region information for a directory.

*/ export interface RegionDescription { /** - *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

- */ - VpcSettings?: DirectoryVpcSettings; - - /** - *

The date and time that the Region status was last updated.

+ *

The identifier of the directory.

*/ - StatusLastUpdatedDateTime?: Date; + DirectoryId?: string; /** *

The name of the Region. For example, us-east-1.

@@ -2659,7 +2694,7 @@ export interface RegionDescription { RegionName?: string; /** - *

Specifies if the Region is the primary Region or an additional Region.

+ *

Specifies whether the Region is the primary Region or an additional Region.

*/ RegionType?: RegionType | string; @@ -2668,6 +2703,11 @@ export interface RegionDescription { */ Status?: DirectoryStage | string; + /** + *

Contains VPC information for the CreateDirectory or CreateMicrosoftAD operation.

+ */ + VpcSettings?: DirectoryVpcSettings; + /** *

The desired number of domain controllers in the specified Region for the specified directory.

*/ @@ -2679,9 +2719,9 @@ export interface RegionDescription { LaunchTime?: Date; /** - *

The identifier of the directory.

+ *

The date and time that the Region status was last updated.

*/ - DirectoryId?: string; + StatusLastUpdatedDateTime?: Date; /** *

The date and time that the Region description was last updated.

@@ -2697,12 +2737,12 @@ export namespace RegionDescription { export interface DescribeRegionsResult { /** - *

List of regional information related to the directory per replicated Region.

+ *

List of Region information related to the directory for each replicated Region.

*/ RegionsDescription?: RegionDescription[]; /** - *

If not null, more results are available. Pass this value for the NextToken parameter + *

If not null, more results are available. Pass this value for the NextToken parameter * in a subsequent call to DescribeRegions to retrieve the next set of items.

*/ NextToken?: string; @@ -2716,9 +2756,9 @@ export namespace DescribeRegionsResult { export interface DescribeSharedDirectoriesRequest { /** - *

The number of shared directories to return in the response object.

+ *

Returns the identifier of the directory in the directory owner account.

*/ - Limit?: number; + OwnerDirectoryId: string | undefined; /** *

A list of identifiers of all shared directories in your account.

@@ -2732,9 +2772,9 @@ export interface DescribeSharedDirectoriesRequest { NextToken?: string; /** - *

Returns the identifier of the directory in the directory owner account.

+ *

The number of shared directories to return in the response object.

*/ - OwnerDirectoryId: string | undefined; + Limit?: number; } export namespace DescribeSharedDirectoriesRequest { @@ -2745,15 +2785,15 @@ export namespace DescribeSharedDirectoriesRequest { export interface DescribeSharedDirectoriesResult { /** - *

If not null, token that indicates that more results are available. Pass this value for the - * NextToken parameter in a subsequent call to DescribeSharedDirectories to retrieve the next set of items.

+ *

A list of all shared directories in your account.

*/ - NextToken?: string; + SharedDirectories?: SharedDirectory[]; /** - *

A list of all shared directories in your account.

+ *

If not null, token that indicates that more results are available. Pass this value for the + * NextToken parameter in a subsequent call to DescribeSharedDirectories to retrieve the next set of items.

*/ - SharedDirectories?: SharedDirectory[]; + NextToken?: string; } export namespace DescribeSharedDirectoriesResult { @@ -2769,6 +2809,11 @@ export namespace DescribeSharedDirectoriesResult { *

Contains the inputs for the DescribeSnapshots operation.

*/ export interface DescribeSnapshotsRequest { + /** + *

The identifier of the directory for which to retrieve snapshot information.

+ */ + DirectoryId?: string; + /** *

A list of identifiers of the snapshots to obtain the information for. If this member is * null or empty, all snapshots are returned using the Limit and NextToken @@ -2776,21 +2821,16 @@ export interface DescribeSnapshotsRequest { */ SnapshotIds?: string[]; - /** - *

The maximum number of objects to return.

- */ - Limit?: number; - - /** - *

The identifier of the directory for which to retrieve snapshot information.

- */ - DirectoryId?: string; - /** *

The DescribeSnapshotsResult.NextToken value from a previous call to * DescribeSnapshots. Pass null if this is the first call.

*/ NextToken?: string; + + /** + *

The maximum number of objects to return.

+ */ + Limit?: number; } export namespace DescribeSnapshotsRequest { @@ -2815,24 +2855,24 @@ export enum SnapshotType { */ export interface Snapshot { /** - *

The descriptive name of the snapshot.

+ *

The directory identifier.

*/ - Name?: string; + DirectoryId?: string; /** - *

The snapshot type.

+ *

The snapshot identifier.

*/ - Type?: SnapshotType | string; + SnapshotId?: string; /** - *

The snapshot identifier.

+ *

The snapshot type.

*/ - SnapshotId?: string; + Type?: SnapshotType | string; /** - *

The directory identifier.

+ *

The descriptive name of the snapshot.

*/ - DirectoryId?: string; + Name?: string; /** *

The snapshot status.

@@ -2881,12 +2921,6 @@ export namespace DescribeSnapshotsResult { *

Describes the trust relationships for a particular AWS Managed Microsoft AD directory. If no input parameters are are provided, such as directory ID or trust ID, this request describes all the trust relationships.

*/ export interface DescribeTrustsRequest { - /** - *

The DescribeTrustsResult.NextToken value from a previous call to - * DescribeTrusts. Pass null if this is the first call.

- */ - NextToken?: string; - /** *

The Directory ID of the AWS directory that is a part of the requested trust relationship.

*/ @@ -2898,6 +2932,12 @@ export interface DescribeTrustsRequest { */ TrustIds?: string[]; + /** + *

The DescribeTrustsResult.NextToken value from a previous call to + * DescribeTrusts. Pass null if this is the first call.

+ */ + NextToken?: string; + /** *

The maximum number of objects to return.

*/ @@ -2929,19 +2969,24 @@ export enum TrustState { */ export interface Trust { /** - *

The date and time that the trust relationship was last updated.

+ *

The Directory ID of the AWS directory involved in the trust relationship.

*/ - LastUpdatedDateTime?: Date; + DirectoryId?: string; /** - *

The date and time that the TrustState was last updated.

+ *

The unique ID of the trust relationship.

*/ - StateLastUpdatedDateTime?: Date; + TrustId?: string; /** - *

The reason for the TrustState.

+ *

The Fully Qualified Domain Name (FQDN) of the external domain involved in the trust relationship.

*/ - TrustStateReason?: string; + RemoteDomainName?: string; + + /** + *

The trust relationship type. Forest is the default.

+ */ + TrustType?: TrustType | string; /** *

The trust relationship direction.

@@ -2949,39 +2994,34 @@ export interface Trust { TrustDirection?: TrustDirection | string; /** - *

The Fully Qualified Domain Name (FQDN) of the external domain involved in the trust relationship.

+ *

The trust relationship state.

*/ - RemoteDomainName?: string; + TrustState?: TrustState | string; /** - *

The unique ID of the trust relationship.

+ *

The date and time that the trust relationship was created.

*/ - TrustId?: string; + CreatedDateTime?: Date; /** - *

The trust relationship type. Forest is the default.

+ *

The date and time that the trust relationship was last updated.

*/ - TrustType?: TrustType | string; + LastUpdatedDateTime?: Date; /** - *

The Directory ID of the AWS directory involved in the trust relationship.

+ *

The date and time that the TrustState was last updated.

*/ - DirectoryId?: string; + StateLastUpdatedDateTime?: Date; /** - *

The trust relationship state.

+ *

The reason for the TrustState.

*/ - TrustState?: TrustState | string; + TrustStateReason?: string; /** *

Current state of selective authentication for the trust.

*/ SelectiveAuth?: SelectiveAuth | string; - - /** - *

The date and time that the trust relationship was created.

- */ - CreatedDateTime?: Date; } export namespace Trust { @@ -3021,24 +3061,24 @@ export namespace DescribeTrustsResult { */ export interface DirectoryLimits { /** - *

The maximum number of connected directories allowed in the Region.

+ *

The maximum number of cloud directories allowed in the Region.

*/ - ConnectedDirectoriesLimit?: number; + CloudOnlyDirectoriesLimit?: number; /** - *

The maximum number of AWS Managed Microsoft AD directories allowed in the region.

+ *

The current number of cloud directories in the Region.

*/ - CloudOnlyMicrosoftADLimit?: number; + CloudOnlyDirectoriesCurrentCount?: number; /** - *

The current number of connected directories in the Region.

+ *

Indicates if the cloud directory limit has been reached.

*/ - ConnectedDirectoriesCurrentCount?: number; + CloudOnlyDirectoriesLimitReached?: boolean; /** - *

Indicates if the AWS Managed Microsoft AD directory limit has been reached.

+ *

The maximum number of AWS Managed Microsoft AD directories allowed in the region.

*/ - CloudOnlyMicrosoftADLimitReached?: boolean; + CloudOnlyMicrosoftADLimit?: number; /** *

The current number of AWS Managed Microsoft AD directories in the region.

@@ -3046,24 +3086,24 @@ export interface DirectoryLimits { CloudOnlyMicrosoftADCurrentCount?: number; /** - *

Indicates if the connected directory limit has been reached.

+ *

Indicates if the AWS Managed Microsoft AD directory limit has been reached.

*/ - ConnectedDirectoriesLimitReached?: boolean; + CloudOnlyMicrosoftADLimitReached?: boolean; /** - *

The maximum number of cloud directories allowed in the Region.

+ *

The maximum number of connected directories allowed in the Region.

*/ - CloudOnlyDirectoriesLimit?: number; + ConnectedDirectoriesLimit?: number; /** - *

The current number of cloud directories in the Region.

+ *

The current number of connected directories in the Region.

*/ - CloudOnlyDirectoriesCurrentCount?: number; + ConnectedDirectoriesCurrentCount?: number; /** - *

Indicates if the cloud directory limit has been reached.

+ *

Indicates if the connected directory limit has been reached.

*/ - CloudOnlyDirectoriesLimitReached?: boolean; + ConnectedDirectoriesLimitReached?: boolean; } export namespace DirectoryLimits { @@ -3078,19 +3118,68 @@ export namespace DirectoryLimits { export interface DirectoryNotSharedException extends __SmithyException, $MetadataBearer { name: "DirectoryNotSharedException"; $fault: "client"; + /** + *

The descriptive message for the exception.

+ */ + Message?: string; + /** *

The AWS request identifier.

*/ RequestId?: string; +} + +export namespace DirectoryNotSharedException { + export const filterSensitiveLog = (obj: DirectoryNotSharedException): any => ({ + ...obj, + }); +} + +export interface DisableClientAuthenticationRequest { + /** + *

Disable client authentication in a specified directory for smart cards.

+ */ + DirectoryId: string | undefined; + + /** + *

Disable the type of client authentication request.

+ */ + Type: ClientAuthenticationType | string | undefined; +} + +export namespace DisableClientAuthenticationRequest { + export const filterSensitiveLog = (obj: DisableClientAuthenticationRequest): any => ({ + ...obj, + }); +} + +export interface DisableClientAuthenticationResult {} + +export namespace DisableClientAuthenticationResult { + export const filterSensitiveLog = (obj: DisableClientAuthenticationResult): any => ({ + ...obj, + }); +} +/** + *

The client authorization was invalid.

+ */ +export interface InvalidClientAuthStatusException extends __SmithyException, $MetadataBearer { + name: "InvalidClientAuthStatusException"; + $fault: "client"; /** *

The descriptive message for the exception.

*/ Message?: string; + + /** + *

The AWS request identifier.

+ */ + RequestId?: string; } -export namespace DirectoryNotSharedException { - export const filterSensitiveLog = (obj: DirectoryNotSharedException): any => ({ +export namespace InvalidClientAuthStatusException { + export const filterSensitiveLog = (obj: InvalidClientAuthStatusException): any => ({ ...obj, }); } @@ -3130,14 +3219,14 @@ export interface InvalidLDAPSStatusException extends __SmithyException, $Metadat name: "InvalidLDAPSStatusException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace InvalidLDAPSStatusException { @@ -3177,12 +3266,6 @@ export namespace DisableRadiusResult { *

Contains the inputs for the DisableSso operation.

*/ export interface DisableSsoRequest { - /** - *

The password of an alternate account to use to disable single-sign on. This is only used - * for AD Connector directories. For more information, see the UserName parameter.

- */ - Password?: string; - /** *

The identifier of the directory for which to disable single-sign on.

*/ @@ -3196,6 +3279,12 @@ export interface DisableSsoRequest { * the service. The AD Connector service account is not changed.

*/ UserName?: string; + + /** + *

The password of an alternate account to use to disable single-sign on. This is only used + * for AD Connector directories. For more information, see the UserName parameter.

+ */ + Password?: string; } export namespace DisableSsoRequest { @@ -3216,29 +3305,28 @@ export namespace DisableSsoResult { }); } -export interface EnableLDAPSRequest { +export interface EnableClientAuthenticationRequest { /** - *

The identifier of the directory.

+ *

Enable client authentication in a specified directory for smart cards.

*/ DirectoryId: string | undefined; /** - *

The type of LDAP security to enable. Currently only the value Client is - * supported.

+ *

Enable the type of client authentication request.

*/ - Type: LDAPSType | string | undefined; + Type: ClientAuthenticationType | string | undefined; } -export namespace EnableLDAPSRequest { - export const filterSensitiveLog = (obj: EnableLDAPSRequest): any => ({ +export namespace EnableClientAuthenticationRequest { + export const filterSensitiveLog = (obj: EnableClientAuthenticationRequest): any => ({ ...obj, }); } -export interface EnableLDAPSResult {} +export interface EnableClientAuthenticationResult {} -export namespace EnableLDAPSResult { - export const filterSensitiveLog = (obj: EnableLDAPSResult): any => ({ +export namespace EnableClientAuthenticationResult { + export const filterSensitiveLog = (obj: EnableClientAuthenticationResult): any => ({ ...obj, }); } @@ -3258,11 +3346,38 @@ export interface NoAvailableCertificateException extends __SmithyException, $Met /** *

The AWS request identifier.

*/ - RequestId?: string; + RequestId?: string; +} + +export namespace NoAvailableCertificateException { + export const filterSensitiveLog = (obj: NoAvailableCertificateException): any => ({ + ...obj, + }); +} + +export interface EnableLDAPSRequest { + /** + *

The identifier of the directory.

+ */ + DirectoryId: string | undefined; + + /** + *

The type of LDAP security to enable. Currently only the value Client is + * supported.

+ */ + Type: LDAPSType | string | undefined; } -export namespace NoAvailableCertificateException { - export const filterSensitiveLog = (obj: NoAvailableCertificateException): any => ({ +export namespace EnableLDAPSRequest { + export const filterSensitiveLog = (obj: EnableLDAPSRequest): any => ({ + ...obj, + }); +} + +export interface EnableLDAPSResult {} + +export namespace EnableLDAPSResult { + export const filterSensitiveLog = (obj: EnableLDAPSResult): any => ({ ...obj, }); } @@ -3392,14 +3507,14 @@ export namespace GetSnapshotLimitsRequest { */ export interface SnapshotLimits { /** - *

The current number of manual snapshots of the directory.

+ *

The maximum number of manual snapshots allowed.

*/ - ManualSnapshotsCurrentCount?: number; + ManualSnapshotsLimit?: number; /** - *

The maximum number of manual snapshots allowed.

+ *

The current number of manual snapshots of the directory.

*/ - ManualSnapshotsLimit?: number; + ManualSnapshotsCurrentCount?: number; /** *

Indicates if the manual snapshot limit has been reached.

@@ -3432,9 +3547,9 @@ export namespace GetSnapshotLimitsResult { export interface ListCertificatesRequest { /** - *

The number of items that should show up on one page

+ *

The identifier of the directory.

*/ - Limit?: number; + DirectoryId: string | undefined; /** *

A token for requesting another page of certificates if the NextToken response @@ -3445,9 +3560,9 @@ export interface ListCertificatesRequest { NextToken?: string; /** - *

The identifier of the directory.

+ *

The number of items that should show up on one page

*/ - DirectoryId: string | undefined; + Limit?: number; } export namespace ListCertificatesRequest { @@ -3477,6 +3592,11 @@ export namespace ListCertificatesResult { } export interface ListIpRoutesRequest { + /** + *

Identifier (ID) of the directory for which you want to retrieve the IP addresses.

+ */ + DirectoryId: string | undefined; + /** *

The ListIpRoutes.NextToken value from a previous call to * ListIpRoutes. Pass null if this is the first call.

@@ -3487,11 +3607,6 @@ export interface ListIpRoutesRequest { *

Maximum number of items to return. If this value is zero, the maximum number of items is specified by the limitations of the operation.

*/ Limit?: number; - - /** - *

Identifier (ID) of the directory for which you want to retrieve the IP addresses.

- */ - DirectoryId: string | undefined; } export namespace ListIpRoutesRequest { @@ -3514,14 +3629,14 @@ export enum IpRouteStatusMsg { */ export interface IpRouteInfo { /** - *

IP address block in the IpRoute.

+ *

Identifier (ID) of the directory associated with the IP addresses.

*/ - CidrIp?: string; + DirectoryId?: string; /** - *

The date and time the address block was added to the directory.

+ *

IP address block in the IpRoute.

*/ - AddedDateTime?: Date; + CidrIp?: string; /** *

The status of the IP address block.

@@ -3529,19 +3644,19 @@ export interface IpRouteInfo { IpRouteStatusMsg?: IpRouteStatusMsg | string; /** - *

Description of the IpRouteInfo.

+ *

The date and time the address block was added to the directory.

*/ - Description?: string; + AddedDateTime?: Date; /** - *

Identifier (ID) of the directory associated with the IP addresses.

+ *

The reason for the IpRouteStatusMsg.

*/ - DirectoryId?: string; + IpRouteStatusReason?: string; /** - *

The reason for the IpRouteStatusMsg.

+ *

Description of the IpRouteInfo.

*/ - IpRouteStatusReason?: string; + Description?: string; } export namespace IpRouteInfo { @@ -3570,11 +3685,6 @@ export namespace ListIpRoutesResult { } export interface ListLogSubscriptionsRequest { - /** - *

The token for the next set of items to return.

- */ - NextToken?: string; - /** *

If a DirectoryID is provided, lists only the log subscription * associated with that directory. If no DirectoryId is provided, lists all @@ -3583,6 +3693,11 @@ export interface ListLogSubscriptionsRequest { */ DirectoryId?: string; + /** + *

The token for the next set of items to return.

+ */ + NextToken?: string; + /** *

The maximum number of items returned.

*/ @@ -3600,6 +3715,12 @@ export namespace ListLogSubscriptionsRequest { * specified destination.

*/ export interface LogSubscription { + /** + *

Identifier (ID) of the directory that you want to associate with the log + * subscription.

+ */ + DirectoryId?: string; + /** *

The name of the log group.

*/ @@ -3609,12 +3730,6 @@ export interface LogSubscription { *

The date and time that the log subscription was created.

*/ SubscriptionCreatedDateTime?: Date; - - /** - *

Identifier (ID) of the directory that you want to associate with the log - * subscription.

- */ - DirectoryId?: string; } export namespace LogSubscription { @@ -3643,11 +3758,6 @@ export namespace ListLogSubscriptionsResult { } export interface ListSchemaExtensionsRequest { - /** - *

The maximum number of items to return.

- */ - Limit?: number; - /** *

The identifier of the directory from which to retrieve the schema extension information.

*/ @@ -3657,6 +3767,11 @@ export interface ListSchemaExtensionsRequest { *

The ListSchemaExtensions.NextToken value from a previous call to ListSchemaExtensions. Pass null if this is the first call.

*/ NextToken?: string; + + /** + *

The maximum number of items to return.

+ */ + Limit?: number; } export namespace ListSchemaExtensionsRequest { @@ -3682,9 +3797,9 @@ export enum SchemaExtensionStatus { */ export interface SchemaExtensionInfo { /** - *

The date and time that the schema extension started being applied to the directory.

+ *

The identifier of the directory to which the schema extension is applied.

*/ - StartDateTime?: Date; + DirectoryId?: string; /** *

The identifier of the schema extension.

@@ -3692,9 +3807,9 @@ export interface SchemaExtensionInfo { SchemaExtensionId?: string; /** - *

The identifier of the directory to which the schema extension is applied.

+ *

A description of the schema extension.

*/ - DirectoryId?: string; + Description?: string; /** *

The current status of the schema extension.

@@ -3707,9 +3822,9 @@ export interface SchemaExtensionInfo { SchemaExtensionStatusReason?: string; /** - *

A description of the schema extension.

+ *

The date and time that the schema extension started being applied to the directory.

*/ - Description?: string; + StartDateTime?: Date; /** *

The date and time that the schema extension was completed.

@@ -3725,14 +3840,14 @@ export namespace SchemaExtensionInfo { export interface ListSchemaExtensionsResult { /** - *

If not null, more results are available. Pass this value for the NextToken parameter in a subsequent call to ListSchemaExtensions to retrieve the next set of items.

+ *

Information about the schema extensions applied to the directory.

*/ - NextToken?: string; + SchemaExtensionsInfo?: SchemaExtensionInfo[]; /** - *

Information about the schema extensions applied to the directory.

+ *

If not null, more results are available. Pass this value for the NextToken parameter in a subsequent call to ListSchemaExtensions to retrieve the next set of items.

*/ - SchemaExtensionsInfo?: SchemaExtensionInfo[]; + NextToken?: string; } export namespace ListSchemaExtensionsResult { @@ -3743,19 +3858,19 @@ export namespace ListSchemaExtensionsResult { export interface ListTagsForResourceRequest { /** - *

Reserved for future use.

+ *

Identifier (ID) of the directory for which you want to retrieve tags.

*/ - NextToken?: string; + ResourceId: string | undefined; /** *

Reserved for future use.

*/ - Limit?: number; + NextToken?: string; /** - *

Identifier (ID) of the directory for which you want to retrieve tags.

+ *

Reserved for future use.

*/ - ResourceId: string | undefined; + Limit?: number; } export namespace ListTagsForResourceRequest { @@ -3815,6 +3930,16 @@ export interface RegisterCertificateRequest { *

The certificate PEM string that needs to be registered.

*/ CertificateData: string | undefined; + + /** + *

The certificate type to register for the request.

+ */ + Type?: CertificateType | string; + + /** + *

Contains information about the client certificate authentication settings, such as ClientLDAPS or ClientCertAuth.

+ */ + ClientCertAuthSettings?: ClientCertAuthSettings; } export namespace RegisterCertificateRequest { @@ -3841,14 +3966,14 @@ export namespace RegisterCertificateResult { */ export interface RegisterEventTopicRequest { /** - *

The SNS topic name to which the directory will publish status messages. This SNS topic must be in the same region as the specified Directory ID.

+ *

The Directory ID that will publish status messages to the SNS topic.

*/ - TopicName: string | undefined; + DirectoryId: string | undefined; /** - *

The Directory ID that will publish status messages to the SNS topic.

+ *

The SNS topic name to which the directory will publish status messages. This SNS topic must be in the same region as the specified Directory ID.

*/ - DirectoryId: string | undefined; + TopicName: string | undefined; } export namespace RegisterEventTopicRequest { @@ -3944,14 +4069,14 @@ export namespace RemoveRegionResult { export interface RemoveTagsFromResourceRequest { /** - *

The tag key (name) of the tag to be removed.

+ *

Identifier (ID) of the directory from which to remove the tag.

*/ - TagKeys: string[] | undefined; + ResourceId: string | undefined; /** - *

Identifier (ID) of the directory from which to remove the tag.

+ *

The tag key (name) of the tag to be removed.

*/ - ResourceId: string | undefined; + TagKeys: string[] | undefined; } export namespace RemoveTagsFromResourceRequest { @@ -3999,14 +4124,14 @@ export interface ResetUserPasswordRequest { DirectoryId: string | undefined; /** - *

The new password that will be reset.

+ *

The user name of the user whose password will be reset.

*/ - NewPassword: string | undefined; + UserName: string | undefined; /** - *

The user name of the user whose password will be reset.

+ *

The new password that will be reset.

*/ - UserName: string | undefined; + NewPassword: string | undefined; } export namespace ResetUserPasswordRequest { @@ -4031,14 +4156,14 @@ export interface UserDoesNotExistException extends __SmithyException, $MetadataB name: "UserDoesNotExistException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace UserDoesNotExistException { @@ -4081,14 +4206,14 @@ export interface InvalidTargetException extends __SmithyException, $MetadataBear name: "InvalidTargetException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace InvalidTargetException { @@ -4129,14 +4254,14 @@ export enum TargetType { */ export interface ShareTarget { /** - *

Type of identifier to be used in the Id field.

+ *

Identifier of the directory consumer account.

*/ - Type: TargetType | string | undefined; + Id: string | undefined; /** - *

Identifier of the directory consumer account.

+ *

Type of identifier to be used in the Id field.

*/ - Id: string | undefined; + Type: TargetType | string | undefined; } export namespace ShareTarget { @@ -4152,6 +4277,13 @@ export interface ShareDirectoryRequest { */ DirectoryId: string | undefined; + /** + *

A directory share request that is sent by the directory owner to the directory consumer. + * The request includes a typed message to help the directory consumer administrator determine + * whether to approve or reject the share invitation.

+ */ + ShareNotes?: string; + /** *

Identifier for the directory consumer account with whom the directory is to be * shared.

@@ -4164,13 +4296,6 @@ export interface ShareDirectoryRequest { * sending a directory sharing request (HANDSHAKE).

*/ ShareMethod: ShareMethod | string | undefined; - - /** - *

A directory share request that is sent by the directory owner to the directory consumer. - * The request includes a typed message to help the directory consumer administrator determine - * whether to approve or reject the share invitation.

- */ - ShareNotes?: string; } export namespace ShareDirectoryRequest { @@ -4201,14 +4326,14 @@ export interface ShareLimitExceededException extends __SmithyException, $Metadat name: "ShareLimitExceededException"; $fault: "client"; /** - *

The AWS request identifier.

+ *

The descriptive message for the exception.

*/ - RequestId?: string; + Message?: string; /** - *

The descriptive message for the exception.

+ *

The AWS request identifier.

*/ - Message?: string; + RequestId?: string; } export namespace ShareLimitExceededException { @@ -4219,14 +4344,14 @@ export namespace ShareLimitExceededException { export interface StartSchemaExtensionRequest { /** - *

A description of the schema extension.

+ *

The identifier of the directory for which the schema extension will be applied to.

*/ - Description: string | undefined; + DirectoryId: string | undefined; /** - *

The identifier of the directory for which the schema extension will be applied to.

+ *

If true, creates a snapshot of the directory before applying the schema extension.

*/ - DirectoryId: string | undefined; + CreateSnapshotBeforeSchemaExtension: boolean | undefined; /** *

The LDIF file represented as a string. To construct the LdifContent string, precede each line as it would be formatted in an ldif file with \n. See the example request below for more details. The file size can be no larger than 1MB.

@@ -4234,9 +4359,9 @@ export interface StartSchemaExtensionRequest { LdifContent: string | undefined; /** - *

If true, creates a snapshot of the directory before applying the schema extension.

+ *

A description of the schema extension.

*/ - CreateSnapshotBeforeSchemaExtension: boolean | undefined; + Description: string | undefined; } export namespace StartSchemaExtensionRequest { @@ -4281,17 +4406,17 @@ export namespace UnshareTarget { } export interface UnshareDirectoryRequest { - /** - *

Identifier for the directory consumer account with whom the directory has to be - * unshared.

- */ - UnshareTarget: UnshareTarget | undefined; - /** *

The identifier of the AWS Managed Microsoft AD directory that you want to stop * sharing.

*/ DirectoryId: string | undefined; + + /** + *

Identifier for the directory consumer account with whom the directory has to be + * unshared.

+ */ + UnshareTarget: UnshareTarget | undefined; } export namespace UnshareDirectoryRequest { @@ -4324,14 +4449,14 @@ export interface UpdateConditionalForwarderRequest { DirectoryId: string | undefined; /** - *

The updated IP addresses of the remote DNS server associated with the conditional forwarder.

+ *

The fully qualified domain name (FQDN) of the remote domain with which you will set up a trust relationship.

*/ - DnsIpAddrs: string[] | undefined; + RemoteDomainName: string | undefined; /** - *

The fully qualified domain name (FQDN) of the remote domain with which you will set up a trust relationship.

+ *

The updated IP addresses of the remote DNS server associated with the conditional forwarder.

*/ - RemoteDomainName: string | undefined; + DnsIpAddrs: string[] | undefined; } export namespace UpdateConditionalForwarderRequest { @@ -4376,14 +4501,14 @@ export namespace DomainControllerLimitExceededException { export interface UpdateNumberOfDomainControllersRequest { /** - *

The number of domain controllers desired in the directory.

+ *

Identifier of the directory to which the domain controllers will be added or removed.

*/ - DesiredNumber: number | undefined; + DirectoryId: string | undefined; /** - *

Identifier of the directory to which the domain controllers will be added or removed.

+ *

The number of domain controllers desired in the directory.

*/ - DirectoryId: string | undefined; + DesiredNumber: number | undefined; } export namespace UpdateNumberOfDomainControllersRequest { @@ -4435,14 +4560,14 @@ export namespace UpdateRadiusResult { export interface UpdateTrustRequest { /** - *

Updates selective authentication for the trust.

+ *

Identifier of the trust relationship.

*/ - SelectiveAuth?: SelectiveAuth | string; + TrustId: string | undefined; /** - *

Identifier of the trust relationship.

+ *

Updates selective authentication for the trust.

*/ - TrustId: string | undefined; + SelectiveAuth?: SelectiveAuth | string; } export namespace UpdateTrustRequest { @@ -4453,14 +4578,14 @@ export namespace UpdateTrustRequest { export interface UpdateTrustResult { /** - *

Identifier of the trust relationship.

+ *

The AWS request identifier.

*/ - TrustId?: string; + RequestId?: string; /** - *

The AWS request identifier.

+ *

Identifier of the trust relationship.

*/ - RequestId?: string; + TrustId?: string; } export namespace UpdateTrustResult { diff --git a/clients/client-directory-service/protocols/Aws_json1_1.ts b/clients/client-directory-service/protocols/Aws_json1_1.ts index 0f9ce1044fdb..e3f544e00bfc 100644 --- a/clients/client-directory-service/protocols/Aws_json1_1.ts +++ b/clients/client-directory-service/protocols/Aws_json1_1.ts @@ -74,9 +74,17 @@ import { } from "../commands/DescribeSharedDirectoriesCommand"; import { DescribeSnapshotsCommandInput, DescribeSnapshotsCommandOutput } from "../commands/DescribeSnapshotsCommand"; import { DescribeTrustsCommandInput, DescribeTrustsCommandOutput } from "../commands/DescribeTrustsCommand"; +import { + DisableClientAuthenticationCommandInput, + DisableClientAuthenticationCommandOutput, +} from "../commands/DisableClientAuthenticationCommand"; import { DisableLDAPSCommandInput, DisableLDAPSCommandOutput } from "../commands/DisableLDAPSCommand"; import { DisableRadiusCommandInput, DisableRadiusCommandOutput } from "../commands/DisableRadiusCommand"; import { DisableSsoCommandInput, DisableSsoCommandOutput } from "../commands/DisableSsoCommand"; +import { + EnableClientAuthenticationCommandInput, + EnableClientAuthenticationCommandOutput, +} from "../commands/EnableClientAuthenticationCommand"; import { EnableLDAPSCommandInput, EnableLDAPSCommandOutput } from "../commands/EnableLDAPSCommand"; import { EnableRadiusCommandInput, EnableRadiusCommandOutput } from "../commands/EnableRadiusCommand"; import { EnableSsoCommandInput, EnableSsoCommandOutput } from "../commands/EnableSsoCommand"; @@ -153,6 +161,7 @@ import { CertificateInUseException, CertificateInfo, CertificateLimitExceededException, + ClientCertAuthSettings, ClientException, Computer, ConditionalForwarder, @@ -220,6 +229,8 @@ import { DirectoryUnavailableException, DirectoryVpcSettings, DirectoryVpcSettingsDescription, + DisableClientAuthenticationRequest, + DisableClientAuthenticationResult, DisableLDAPSRequest, DisableLDAPSResult, DisableRadiusRequest, @@ -228,6 +239,8 @@ import { DisableSsoResult, DomainController, DomainControllerLimitExceededException, + EnableClientAuthenticationRequest, + EnableClientAuthenticationResult, EnableLDAPSRequest, EnableLDAPSResult, EnableRadiusRequest, @@ -243,6 +256,7 @@ import { GetSnapshotLimitsResult, InsufficientPermissionsException, InvalidCertificateException, + InvalidClientAuthStatusException, InvalidLDAPSStatusException, InvalidNextTokenException, InvalidParameterException, @@ -730,6 +744,19 @@ export const serializeAws_json1_1DescribeTrustsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DisableClientAuthenticationCommand = async ( + input: DisableClientAuthenticationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "DirectoryService_20150416.DisableClientAuthentication", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DisableClientAuthenticationRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DisableLDAPSCommand = async ( input: DisableLDAPSCommandInput, context: __SerdeContext @@ -769,6 +796,19 @@ export const serializeAws_json1_1DisableSsoCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1EnableClientAuthenticationCommand = async ( + input: EnableClientAuthenticationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "DirectoryService_20150416.EnableClientAuthentication", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1EnableClientAuthenticationRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1EnableLDAPSCommand = async ( input: EnableLDAPSCommandInput, context: __SerdeContext @@ -3932,6 +3972,101 @@ const deserializeAws_json1_1DescribeTrustsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1DisableClientAuthenticationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DisableClientAuthenticationCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DisableClientAuthenticationResult(data, context); + const response: DisableClientAuthenticationCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DisableClientAuthenticationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.directoryservice#AccessDeniedException": + response = { + ...(await deserializeAws_json1_1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ClientException": + case "com.amazonaws.directoryservice#ClientException": + response = { + ...(await deserializeAws_json1_1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "DirectoryDoesNotExistException": + case "com.amazonaws.directoryservice#DirectoryDoesNotExistException": + response = { + ...(await deserializeAws_json1_1DirectoryDoesNotExistExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidClientAuthStatusException": + case "com.amazonaws.directoryservice#InvalidClientAuthStatusException": + response = { + ...(await deserializeAws_json1_1InvalidClientAuthStatusExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceException": + case "com.amazonaws.directoryservice#ServiceException": + response = { + ...(await deserializeAws_json1_1ServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedOperationException": + case "com.amazonaws.directoryservice#UnsupportedOperationException": + response = { + ...(await deserializeAws_json1_1UnsupportedOperationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1DisableLDAPSCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -4193,6 +4328,109 @@ const deserializeAws_json1_1DisableSsoCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1EnableClientAuthenticationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1EnableClientAuthenticationCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1EnableClientAuthenticationResult(data, context); + const response: EnableClientAuthenticationCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1EnableClientAuthenticationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.directoryservice#AccessDeniedException": + response = { + ...(await deserializeAws_json1_1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ClientException": + case "com.amazonaws.directoryservice#ClientException": + response = { + ...(await deserializeAws_json1_1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "DirectoryDoesNotExistException": + case "com.amazonaws.directoryservice#DirectoryDoesNotExistException": + response = { + ...(await deserializeAws_json1_1DirectoryDoesNotExistExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidClientAuthStatusException": + case "com.amazonaws.directoryservice#InvalidClientAuthStatusException": + response = { + ...(await deserializeAws_json1_1InvalidClientAuthStatusExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "NoAvailableCertificateException": + case "com.amazonaws.directoryservice#NoAvailableCertificateException": + response = { + ...(await deserializeAws_json1_1NoAvailableCertificateExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceException": + case "com.amazonaws.directoryservice#ServiceException": + response = { + ...(await deserializeAws_json1_1ServiceExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedOperationException": + case "com.amazonaws.directoryservice#UnsupportedOperationException": + response = { + ...(await deserializeAws_json1_1UnsupportedOperationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1EnableLDAPSCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -6797,6 +7035,21 @@ const deserializeAws_json1_1InvalidCertificateExceptionResponse = async ( return contents; }; +const deserializeAws_json1_1InvalidClientAuthStatusExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1InvalidClientAuthStatusException(body, context); + const contents: InvalidClientAuthStatusException = { + name: "InvalidClientAuthStatusException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + const deserializeAws_json1_1InvalidLDAPSStatusExceptionResponse = async ( parsedOutput: any, context: __SerdeContext @@ -7086,6 +7339,12 @@ const serializeAws_json1_1CidrIps = (input: string[], context: __SerdeContext): return input.map((entry) => entry); }; +const serializeAws_json1_1ClientCertAuthSettings = (input: ClientCertAuthSettings, context: __SerdeContext): any => { + return { + ...(input.OCSPUrl !== undefined && { OCSPUrl: input.OCSPUrl }), + }; +}; + const serializeAws_json1_1ConnectDirectoryRequest = (input: ConnectDirectoryRequest, context: __SerdeContext): any => { return { ...(input.ConnectSettings !== undefined && { @@ -7395,6 +7654,16 @@ const serializeAws_json1_1DirectoryVpcSettings = (input: DirectoryVpcSettings, c }; }; +const serializeAws_json1_1DisableClientAuthenticationRequest = ( + input: DisableClientAuthenticationRequest, + context: __SerdeContext +): any => { + return { + ...(input.DirectoryId !== undefined && { DirectoryId: input.DirectoryId }), + ...(input.Type !== undefined && { Type: input.Type }), + }; +}; + const serializeAws_json1_1DisableLDAPSRequest = (input: DisableLDAPSRequest, context: __SerdeContext): any => { return { ...(input.DirectoryId !== undefined && { DirectoryId: input.DirectoryId }), @@ -7424,6 +7693,16 @@ const serializeAws_json1_1DomainControllerIds = (input: string[], context: __Ser return input.map((entry) => entry); }; +const serializeAws_json1_1EnableClientAuthenticationRequest = ( + input: EnableClientAuthenticationRequest, + context: __SerdeContext +): any => { + return { + ...(input.DirectoryId !== undefined && { DirectoryId: input.DirectoryId }), + ...(input.Type !== undefined && { Type: input.Type }), + }; +}; + const serializeAws_json1_1EnableLDAPSRequest = (input: EnableLDAPSRequest, context: __SerdeContext): any => { return { ...(input.DirectoryId !== undefined && { DirectoryId: input.DirectoryId }), @@ -7545,7 +7824,11 @@ const serializeAws_json1_1RegisterCertificateRequest = ( ): any => { return { ...(input.CertificateData !== undefined && { CertificateData: input.CertificateData }), + ...(input.ClientCertAuthSettings !== undefined && { + ClientCertAuthSettings: serializeAws_json1_1ClientCertAuthSettings(input.ClientCertAuthSettings, context), + }), ...(input.DirectoryId !== undefined && { DirectoryId: input.DirectoryId }), + ...(input.Type !== undefined && { Type: input.Type }), }; }; @@ -7815,6 +8098,10 @@ const deserializeAws_json1_1Certificate = (output: any, context: __SerdeContext) return { CertificateId: output.CertificateId !== undefined && output.CertificateId !== null ? output.CertificateId : undefined, + ClientCertAuthSettings: + output.ClientCertAuthSettings !== undefined && output.ClientCertAuthSettings !== null + ? deserializeAws_json1_1ClientCertAuthSettings(output.ClientCertAuthSettings, context) + : undefined, CommonName: output.CommonName !== undefined && output.CommonName !== null ? output.CommonName : undefined, ExpiryDateTime: output.ExpiryDateTime !== undefined && output.ExpiryDateTime !== null @@ -7826,6 +8113,7 @@ const deserializeAws_json1_1Certificate = (output: any, context: __SerdeContext) : undefined, State: output.State !== undefined && output.State !== null ? output.State : undefined, StateReason: output.StateReason !== undefined && output.StateReason !== null ? output.StateReason : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, } as any; }; @@ -7859,6 +8147,7 @@ const deserializeAws_json1_1CertificateInfo = (output: any, context: __SerdeCont ? new Date(Math.round(output.ExpiryDateTime * 1000)) : undefined, State: output.State !== undefined && output.State !== null ? output.State : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, } as any; }; @@ -7886,6 +8175,12 @@ const deserializeAws_json1_1CertificatesInfo = (output: any, context: __SerdeCon return (output || []).map((entry: any) => deserializeAws_json1_1CertificateInfo(entry, context)); }; +const deserializeAws_json1_1ClientCertAuthSettings = (output: any, context: __SerdeContext): ClientCertAuthSettings => { + return { + OCSPUrl: output.OCSPUrl !== undefined && output.OCSPUrl !== null ? output.OCSPUrl : undefined, + } as any; +}; + const deserializeAws_json1_1ClientException = (output: any, context: __SerdeContext): ClientException => { return { Message: output.Message !== undefined && output.Message !== null ? output.Message : undefined, @@ -8367,6 +8662,13 @@ const deserializeAws_json1_1DirectoryVpcSettingsDescription = ( } as any; }; +const deserializeAws_json1_1DisableClientAuthenticationResult = ( + output: any, + context: __SerdeContext +): DisableClientAuthenticationResult => { + return {} as any; +}; + const deserializeAws_json1_1DisableLDAPSResult = (output: any, context: __SerdeContext): DisableLDAPSResult => { return {} as any; }; @@ -8422,6 +8724,13 @@ const deserializeAws_json1_1DomainControllers = (output: any, context: __SerdeCo return (output || []).map((entry: any) => deserializeAws_json1_1DomainController(entry, context)); }; +const deserializeAws_json1_1EnableClientAuthenticationResult = ( + output: any, + context: __SerdeContext +): EnableClientAuthenticationResult => { + return {} as any; +}; + const deserializeAws_json1_1EnableLDAPSResult = (output: any, context: __SerdeContext): EnableLDAPSResult => { return {} as any; }; @@ -8515,6 +8824,16 @@ const deserializeAws_json1_1InvalidCertificateException = ( } as any; }; +const deserializeAws_json1_1InvalidClientAuthStatusException = ( + output: any, + context: __SerdeContext +): InvalidClientAuthStatusException => { + return { + Message: output.Message !== undefined && output.Message !== null ? output.Message : undefined, + RequestId: output.RequestId !== undefined && output.RequestId !== null ? output.RequestId : undefined, + } as any; +}; + const deserializeAws_json1_1InvalidLDAPSStatusException = ( output: any, context: __SerdeContext diff --git a/clients/client-ec2/EC2.ts b/clients/client-ec2/EC2.ts index 143b94134be1..57470db5bd07 100644 --- a/clients/client-ec2/EC2.ts +++ b/clients/client-ec2/EC2.ts @@ -2987,7 +2987,7 @@ export class EC2 extends EC2Client { *

Attaches an EBS volume to a running or stopped instance and exposes it to the instance * with the specified device name.

*

Encrypted EBS volumes must be attached to instances that support Amazon EBS encryption. For - * more information, see Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide.

+ * more information, see Amazon EBS encryption in the Amazon Elastic Compute Cloud User Guide.

*

After you attach an EBS volume, you must make it available. For more information, see * Making an EBS volume available for use.

*

If a volume has an AWS Marketplace product code:

@@ -4871,7 +4871,7 @@ export class EC2 extends EC2Client { * source volume are propagated to the snapshot.

*

You can take a snapshot of an attached volume that is in use. However, snapshots only * capture data that has been written to your EBS volume at the time the snapshot command is - * issued; this may exclude any data that has been cached by any applications or the operating + * issued; this might exclude any data that has been cached by any applications or the operating * system. If you can pause any file systems on the volume long enough to take a snapshot, your * snapshot should be complete. However, if you cannot pause all file writes to the volume, you * should unmount the volume from within the instance, issue the snapshot command, and then @@ -4884,7 +4884,7 @@ export class EC2 extends EC2Client { * and any associated snapshots always remain protected.

*

You can tag your snapshots during creation. For more information, see Tagging your Amazon EC2 * resources in the Amazon Elastic Compute Cloud User Guide.

- *

For more information, see Amazon Elastic Block Store and Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information, see Amazon Elastic Block Store and Amazon EBS encryption in the Amazon Elastic Compute Cloud User Guide.

*/ public createSnapshot( args: CreateSnapshotCommandInput, @@ -5460,15 +5460,12 @@ export class EC2 extends EC2Client { } /** - *

Creates an EBS volume that can be attached to an instance in the same Availability Zone. - * The volume is created in the regional endpoint that you send the HTTP request to. For more - * information see Regions and - * Endpoints.

+ *

Creates an EBS volume that can be attached to an instance in the same Availability Zone.

*

You can create a new empty volume or restore a volume from an EBS snapshot. * Any AWS Marketplace product codes from the snapshot are propagated to the volume.

*

You can create encrypted volumes. Encrypted volumes must be attached to instances that * support Amazon EBS encryption. Volumes that are created from encrypted snapshots are also automatically - * encrypted. For more information, see Amazon EBS Encryption + * encrypted. For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*

You can tag your volumes during creation. For more information, see Tagging your Amazon EC2 * resources in the Amazon Elastic Compute Cloud User Guide.

@@ -10445,7 +10442,7 @@ export class EC2 extends EC2Client { /** *

Describes the specified attribute of the specified snapshot. You can specify only one * attribute at a time.

- *

For more information about EBS snapshots, see Amazon EBS Snapshots in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS snapshots, see Amazon EBS snapshots in the Amazon Elastic Compute Cloud User Guide.

*/ public describeSnapshotAttribute( args: DescribeSnapshotAttributeCommandInput, @@ -10523,7 +10520,7 @@ export class EC2 extends EC2Client { * passed to a subsequent DescribeSnapshots request to retrieve the remaining * results.

*

To get the state of fast snapshot restores for a snapshot, use DescribeFastSnapshotRestores.

- *

For more information about EBS snapshots, see Amazon EBS Snapshots in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS snapshots, see Amazon EBS snapshots in the Amazon Elastic Compute Cloud User Guide.

*/ public describeSnapshots( args: DescribeSnapshotsCommandInput, @@ -11165,7 +11162,7 @@ export class EC2 extends EC2Client { /** *

Describes the specified attribute of the specified volume. You can specify only one * attribute at a time.

- *

For more information about EBS volumes, see Amazon EBS Volumes in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS volumes, see Amazon EBS volumes in the Amazon Elastic Compute Cloud User Guide.

*/ public describeVolumeAttribute( args: DescribeVolumeAttributeCommandInput, @@ -11204,7 +11201,7 @@ export class EC2 extends EC2Client { * then that number of results is returned along with a NextToken value that can be * passed to a subsequent DescribeVolumes request to retrieve the remaining * results.

- *

For more information about EBS volumes, see Amazon EBS Volumes in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS volumes, see Amazon EBS volumes in the Amazon Elastic Compute Cloud User Guide.

*/ public describeVolumes( args: DescribeVolumesCommandInput, @@ -11289,18 +11286,18 @@ export class EC2 extends EC2Client { * values are ok, impaired , warning, or * insufficient-data. If all checks pass, the overall status of the volume is * ok. If the check fails, the overall status is impaired. If the - * status is insufficient-data, then the checks may still be taking place on your + * status is insufficient-data, then the checks might still be taking place on your * volume at the time. We recommend that you retry the request. For more information about volume * status, see Monitoring the status of your volumes in the * Amazon Elastic Compute Cloud User Guide.

*

- * Events: Reflect the cause of a volume status and may require you to + * Events: Reflect the cause of a volume status and might require you to * take action. For example, if your volume returns an impaired status, then the * volume event might be potential-data-inconsistency. This means that your volume * has been affected by an issue with the underlying host, has all I/O operations disabled, and - * may have inconsistent data.

+ * might have inconsistent data.

*

- * Actions: Reflect the actions you may have to take in response to an + * Actions: Reflect the actions you might have to take in response to an * event. For example, if the status of the volume is impaired and the volume event * shows potential-data-inconsistency, then the action shows * enable-volume-io. This means that you may want to enable the I/O operations for @@ -11951,7 +11948,7 @@ export class EC2 extends EC2Client { * enabling encryption when you create each volume.

*

Disabling encryption by default does not change the encryption status of your * existing volumes.

- *

For more information, see Amazon EBS Encryption in the + *

For more information, see Amazon EBS encryption in the * Amazon Elastic Compute Cloud User Guide.

*/ public disableEbsEncryptionByDefault( @@ -12481,7 +12478,7 @@ export class EC2 extends EC2Client { *

Enables EBS encryption by default for your account in the current Region.

*

After you enable encryption by default, the EBS volumes that you create are * are always encrypted, either using the default CMK or the CMK that you specified - * when you created each volume. For more information, see Amazon EBS Encryption in the + * when you created each volume. For more information, see Amazon EBS encryption in the * Amazon Elastic Compute Cloud User Guide.

*

You can specify the default CMK for encryption by default using ModifyEbsDefaultKmsKeyId * or ResetEbsDefaultKmsKeyId.

@@ -13116,7 +13113,7 @@ export class EC2 extends EC2Client { *

Describes the default customer master key (CMK) for EBS encryption by default for your account in this Region. * You can change the default CMK for encryption by default using ModifyEbsDefaultKmsKeyId or * ResetEbsDefaultKmsKeyId.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ public getEbsDefaultKmsKeyId( @@ -13151,7 +13148,7 @@ export class EC2 extends EC2Client { /** *

Describes whether EBS encryption by default is enabled for your account in the current * Region.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ public getEbsEncryptionByDefault( @@ -13953,7 +13950,7 @@ export class EC2 extends EC2Client { * managed CMK. To reset the default CMK to the AWS managed CMK for EBS, use ResetEbsDefaultKmsKeyId. Amazon EBS does not support asymmetric CMKs.

*

If you delete or disable the customer managed CMK that you specified for use with * encryption by default, your instances will fail to launch.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ public modifyEbsDefaultKmsKeyId( @@ -14959,10 +14956,10 @@ export class EC2 extends EC2Client { /** *

You can modify several parameters of an existing EBS volume, including volume size, volume * type, and IOPS capacity. If your EBS volume is attached to a current-generation EC2 instance - * type, you may be able to apply these changes without stopping the instance or detaching the + * type, you might be able to apply these changes without stopping the instance or detaching the * volume from it. For more information about modifying an EBS volume running Linux, see Modifying the size, IOPS, or * type of an EBS volume on Linux. For more information about modifying an EBS volume - * running Windows, see Modifying the size, IOPS, or type of an EBS volume on Windows.

+ * running Windows, see Modifying the size, IOPS, or type of an EBS volume on Windows.

*

When you complete a resize operation on your volume, you need to extend the volume's * file-system size to take advantage of the new storage capacity. For information about * extending a Linux file system, see Extending a Linux @@ -14973,11 +14970,10 @@ export class EC2 extends EC2Client { * modification using DescribeVolumesModifications. For information * about tracking status changes using either method, see Monitoring volume * modifications.

- *

With previous-generation instance types, resizing an EBS volume may require detaching and + *

With previous-generation instance types, resizing an EBS volume might require detaching and * reattaching the volume or stopping and restarting the instance. For more information, see - * Modifying the size, - * IOPS, or type of an EBS volume on Linux and Modifying the size, IOPS, or type of an EBS - * volume on Windows.

+ * Amazon EBS Elastic + * Volumes (Linux) or Amazon EBS Elastic Volumes (Windows).

*

If you reach the maximum volume modification rate per volume limit, you will need to wait * at least six hours before applying further modifications to the affected EBS volume.

*/ @@ -16478,7 +16474,7 @@ export class EC2 extends EC2Client { * to the AWS managed CMK for EBS.

*

After resetting the default CMK to the AWS managed CMK, you can continue to encrypt by a * customer managed CMK by specifying it when you create the volume. For more information, see - * Amazon EBS Encryption + * Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ public resetEbsDefaultKmsKeyId( diff --git a/clients/client-ec2/commands/AttachVolumeCommand.ts b/clients/client-ec2/commands/AttachVolumeCommand.ts index 9f98f8032dfd..89e03b3b123a 100644 --- a/clients/client-ec2/commands/AttachVolumeCommand.ts +++ b/clients/client-ec2/commands/AttachVolumeCommand.ts @@ -21,7 +21,7 @@ export type AttachVolumeCommandOutput = VolumeAttachment & __MetadataBearer; *

Attaches an EBS volume to a running or stopped instance and exposes it to the instance * with the specified device name.

*

Encrypted EBS volumes must be attached to instances that support Amazon EBS encryption. For - * more information, see Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide.

+ * more information, see Amazon EBS encryption in the Amazon Elastic Compute Cloud User Guide.

*

After you attach an EBS volume, you must make it available. For more information, see * Making an EBS volume available for use.

*

If a volume has an AWS Marketplace product code:

diff --git a/clients/client-ec2/commands/CreateSnapshotCommand.ts b/clients/client-ec2/commands/CreateSnapshotCommand.ts index 7bdfcc334d6a..3de04f423c72 100644 --- a/clients/client-ec2/commands/CreateSnapshotCommand.ts +++ b/clients/client-ec2/commands/CreateSnapshotCommand.ts @@ -25,7 +25,7 @@ export type CreateSnapshotCommandOutput = Snapshot & __MetadataBearer; * source volume are propagated to the snapshot.

*

You can take a snapshot of an attached volume that is in use. However, snapshots only * capture data that has been written to your EBS volume at the time the snapshot command is - * issued; this may exclude any data that has been cached by any applications or the operating + * issued; this might exclude any data that has been cached by any applications or the operating * system. If you can pause any file systems on the volume long enough to take a snapshot, your * snapshot should be complete. However, if you cannot pause all file writes to the volume, you * should unmount the volume from within the instance, issue the snapshot command, and then @@ -38,7 +38,7 @@ export type CreateSnapshotCommandOutput = Snapshot & __MetadataBearer; * and any associated snapshots always remain protected.

*

You can tag your snapshots during creation. For more information, see Tagging your Amazon EC2 * resources in the Amazon Elastic Compute Cloud User Guide.

- *

For more information, see Amazon Elastic Block Store and Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information, see Amazon Elastic Block Store and Amazon EBS encryption in the Amazon Elastic Compute Cloud User Guide.

*/ export class CreateSnapshotCommand extends $Command< CreateSnapshotCommandInput, diff --git a/clients/client-ec2/commands/CreateVolumeCommand.ts b/clients/client-ec2/commands/CreateVolumeCommand.ts index 0ad13d901229..c53b94e15068 100644 --- a/clients/client-ec2/commands/CreateVolumeCommand.ts +++ b/clients/client-ec2/commands/CreateVolumeCommand.ts @@ -18,15 +18,12 @@ export type CreateVolumeCommandInput = CreateVolumeRequest; export type CreateVolumeCommandOutput = Volume & __MetadataBearer; /** - *

Creates an EBS volume that can be attached to an instance in the same Availability Zone. - * The volume is created in the regional endpoint that you send the HTTP request to. For more - * information see Regions and - * Endpoints.

+ *

Creates an EBS volume that can be attached to an instance in the same Availability Zone.

*

You can create a new empty volume or restore a volume from an EBS snapshot. * Any AWS Marketplace product codes from the snapshot are propagated to the volume.

*

You can create encrypted volumes. Encrypted volumes must be attached to instances that * support Amazon EBS encryption. Volumes that are created from encrypted snapshots are also automatically - * encrypted. For more information, see Amazon EBS Encryption + * encrypted. For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*

You can tag your volumes during creation. For more information, see Tagging your Amazon EC2 * resources in the Amazon Elastic Compute Cloud User Guide.

diff --git a/clients/client-ec2/commands/DescribeSnapshotAttributeCommand.ts b/clients/client-ec2/commands/DescribeSnapshotAttributeCommand.ts index 05bf43eeeb82..53c04dfaceba 100644 --- a/clients/client-ec2/commands/DescribeSnapshotAttributeCommand.ts +++ b/clients/client-ec2/commands/DescribeSnapshotAttributeCommand.ts @@ -23,7 +23,7 @@ export type DescribeSnapshotAttributeCommandOutput = DescribeSnapshotAttributeRe /** *

Describes the specified attribute of the specified snapshot. You can specify only one * attribute at a time.

- *

For more information about EBS snapshots, see Amazon EBS Snapshots in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS snapshots, see Amazon EBS snapshots in the Amazon Elastic Compute Cloud User Guide.

*/ export class DescribeSnapshotAttributeCommand extends $Command< DescribeSnapshotAttributeCommandInput, diff --git a/clients/client-ec2/commands/DescribeSnapshotsCommand.ts b/clients/client-ec2/commands/DescribeSnapshotsCommand.ts index 977ed0730688..0890c3d017e8 100644 --- a/clients/client-ec2/commands/DescribeSnapshotsCommand.ts +++ b/clients/client-ec2/commands/DescribeSnapshotsCommand.ts @@ -67,7 +67,7 @@ export type DescribeSnapshotsCommandOutput = DescribeSnapshotsResult & __Metadat * passed to a subsequent DescribeSnapshots request to retrieve the remaining * results.

*

To get the state of fast snapshot restores for a snapshot, use DescribeFastSnapshotRestores.

- *

For more information about EBS snapshots, see Amazon EBS Snapshots in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS snapshots, see Amazon EBS snapshots in the Amazon Elastic Compute Cloud User Guide.

*/ export class DescribeSnapshotsCommand extends $Command< DescribeSnapshotsCommandInput, diff --git a/clients/client-ec2/commands/DescribeVolumeAttributeCommand.ts b/clients/client-ec2/commands/DescribeVolumeAttributeCommand.ts index dbc332947fea..a70b98b0eb59 100644 --- a/clients/client-ec2/commands/DescribeVolumeAttributeCommand.ts +++ b/clients/client-ec2/commands/DescribeVolumeAttributeCommand.ts @@ -23,7 +23,7 @@ export type DescribeVolumeAttributeCommandOutput = DescribeVolumeAttributeResult /** *

Describes the specified attribute of the specified volume. You can specify only one * attribute at a time.

- *

For more information about EBS volumes, see Amazon EBS Volumes in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS volumes, see Amazon EBS volumes in the Amazon Elastic Compute Cloud User Guide.

*/ export class DescribeVolumeAttributeCommand extends $Command< DescribeVolumeAttributeCommandInput, diff --git a/clients/client-ec2/commands/DescribeVolumeStatusCommand.ts b/clients/client-ec2/commands/DescribeVolumeStatusCommand.ts index f2b1bdd8f366..c5e036cb16a6 100644 --- a/clients/client-ec2/commands/DescribeVolumeStatusCommand.ts +++ b/clients/client-ec2/commands/DescribeVolumeStatusCommand.ts @@ -35,18 +35,18 @@ export type DescribeVolumeStatusCommandOutput = DescribeVolumeStatusResult & __M * values are ok, impaired , warning, or * insufficient-data. If all checks pass, the overall status of the volume is * ok. If the check fails, the overall status is impaired. If the - * status is insufficient-data, then the checks may still be taking place on your + * status is insufficient-data, then the checks might still be taking place on your * volume at the time. We recommend that you retry the request. For more information about volume * status, see Monitoring the status of your volumes in the * Amazon Elastic Compute Cloud User Guide.

*

- * Events: Reflect the cause of a volume status and may require you to + * Events: Reflect the cause of a volume status and might require you to * take action. For example, if your volume returns an impaired status, then the * volume event might be potential-data-inconsistency. This means that your volume * has been affected by an issue with the underlying host, has all I/O operations disabled, and - * may have inconsistent data.

+ * might have inconsistent data.

*

- * Actions: Reflect the actions you may have to take in response to an + * Actions: Reflect the actions you might have to take in response to an * event. For example, if the status of the volume is impaired and the volume event * shows potential-data-inconsistency, then the action shows * enable-volume-io. This means that you may want to enable the I/O operations for diff --git a/clients/client-ec2/commands/DescribeVolumesCommand.ts b/clients/client-ec2/commands/DescribeVolumesCommand.ts index d4c6ddf07345..18d1ce7d6a08 100644 --- a/clients/client-ec2/commands/DescribeVolumesCommand.ts +++ b/clients/client-ec2/commands/DescribeVolumesCommand.ts @@ -25,7 +25,7 @@ export type DescribeVolumesCommandOutput = DescribeVolumesResult & __MetadataBea * then that number of results is returned along with a NextToken value that can be * passed to a subsequent DescribeVolumes request to retrieve the remaining * results.

- *

For more information about EBS volumes, see Amazon EBS Volumes in the Amazon Elastic Compute Cloud User Guide.

+ *

For more information about EBS volumes, see Amazon EBS volumes in the Amazon Elastic Compute Cloud User Guide.

*/ export class DescribeVolumesCommand extends $Command< DescribeVolumesCommandInput, diff --git a/clients/client-ec2/commands/DisableEbsEncryptionByDefaultCommand.ts b/clients/client-ec2/commands/DisableEbsEncryptionByDefaultCommand.ts index e72a6b56b13c..8e0f21d713f7 100644 --- a/clients/client-ec2/commands/DisableEbsEncryptionByDefaultCommand.ts +++ b/clients/client-ec2/commands/DisableEbsEncryptionByDefaultCommand.ts @@ -26,7 +26,7 @@ export type DisableEbsEncryptionByDefaultCommandOutput = DisableEbsEncryptionByD * enabling encryption when you create each volume.

*

Disabling encryption by default does not change the encryption status of your * existing volumes.

- *

For more information, see Amazon EBS Encryption in the + *

For more information, see Amazon EBS encryption in the * Amazon Elastic Compute Cloud User Guide.

*/ export class DisableEbsEncryptionByDefaultCommand extends $Command< diff --git a/clients/client-ec2/commands/EnableEbsEncryptionByDefaultCommand.ts b/clients/client-ec2/commands/EnableEbsEncryptionByDefaultCommand.ts index 8195ca4f07e4..226d7239cecc 100644 --- a/clients/client-ec2/commands/EnableEbsEncryptionByDefaultCommand.ts +++ b/clients/client-ec2/commands/EnableEbsEncryptionByDefaultCommand.ts @@ -24,7 +24,7 @@ export type EnableEbsEncryptionByDefaultCommandOutput = EnableEbsEncryptionByDef *

Enables EBS encryption by default for your account in the current Region.

*

After you enable encryption by default, the EBS volumes that you create are * are always encrypted, either using the default CMK or the CMK that you specified - * when you created each volume. For more information, see Amazon EBS Encryption in the + * when you created each volume. For more information, see Amazon EBS encryption in the * Amazon Elastic Compute Cloud User Guide.

*

You can specify the default CMK for encryption by default using ModifyEbsDefaultKmsKeyId * or ResetEbsDefaultKmsKeyId.

diff --git a/clients/client-ec2/commands/GetEbsDefaultKmsKeyIdCommand.ts b/clients/client-ec2/commands/GetEbsDefaultKmsKeyIdCommand.ts index 51ee20192920..61a87a161b03 100644 --- a/clients/client-ec2/commands/GetEbsDefaultKmsKeyIdCommand.ts +++ b/clients/client-ec2/commands/GetEbsDefaultKmsKeyIdCommand.ts @@ -24,7 +24,7 @@ export type GetEbsDefaultKmsKeyIdCommandOutput = GetEbsDefaultKmsKeyIdResult & _ *

Describes the default customer master key (CMK) for EBS encryption by default for your account in this Region. * You can change the default CMK for encryption by default using ModifyEbsDefaultKmsKeyId or * ResetEbsDefaultKmsKeyId.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ export class GetEbsDefaultKmsKeyIdCommand extends $Command< diff --git a/clients/client-ec2/commands/GetEbsEncryptionByDefaultCommand.ts b/clients/client-ec2/commands/GetEbsEncryptionByDefaultCommand.ts index 33c28a518983..eee47651f2cb 100644 --- a/clients/client-ec2/commands/GetEbsEncryptionByDefaultCommand.ts +++ b/clients/client-ec2/commands/GetEbsEncryptionByDefaultCommand.ts @@ -23,7 +23,7 @@ export type GetEbsEncryptionByDefaultCommandOutput = GetEbsEncryptionByDefaultRe /** *

Describes whether EBS encryption by default is enabled for your account in the current * Region.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ export class GetEbsEncryptionByDefaultCommand extends $Command< diff --git a/clients/client-ec2/commands/ModifyEbsDefaultKmsKeyIdCommand.ts b/clients/client-ec2/commands/ModifyEbsDefaultKmsKeyIdCommand.ts index 6c80d8e9b02c..e67d56f436c1 100644 --- a/clients/client-ec2/commands/ModifyEbsDefaultKmsKeyIdCommand.ts +++ b/clients/client-ec2/commands/ModifyEbsDefaultKmsKeyIdCommand.ts @@ -27,7 +27,7 @@ export type ModifyEbsDefaultKmsKeyIdCommandOutput = ModifyEbsDefaultKmsKeyIdResu * managed CMK. To reset the default CMK to the AWS managed CMK for EBS, use ResetEbsDefaultKmsKeyId. Amazon EBS does not support asymmetric CMKs.

*

If you delete or disable the customer managed CMK that you specified for use with * encryption by default, your instances will fail to launch.

- *

For more information, see Amazon EBS Encryption + *

For more information, see Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ export class ModifyEbsDefaultKmsKeyIdCommand extends $Command< diff --git a/clients/client-ec2/commands/ModifyVolumeCommand.ts b/clients/client-ec2/commands/ModifyVolumeCommand.ts index 85ca3b162bfc..ede6c022af9e 100644 --- a/clients/client-ec2/commands/ModifyVolumeCommand.ts +++ b/clients/client-ec2/commands/ModifyVolumeCommand.ts @@ -20,10 +20,10 @@ export type ModifyVolumeCommandOutput = ModifyVolumeResult & __MetadataBearer; /** *

You can modify several parameters of an existing EBS volume, including volume size, volume * type, and IOPS capacity. If your EBS volume is attached to a current-generation EC2 instance - * type, you may be able to apply these changes without stopping the instance or detaching the + * type, you might be able to apply these changes without stopping the instance or detaching the * volume from it. For more information about modifying an EBS volume running Linux, see Modifying the size, IOPS, or * type of an EBS volume on Linux. For more information about modifying an EBS volume - * running Windows, see Modifying the size, IOPS, or type of an EBS volume on Windows.

+ * running Windows, see Modifying the size, IOPS, or type of an EBS volume on Windows.

*

When you complete a resize operation on your volume, you need to extend the volume's * file-system size to take advantage of the new storage capacity. For information about * extending a Linux file system, see Extending a Linux @@ -34,11 +34,10 @@ export type ModifyVolumeCommandOutput = ModifyVolumeResult & __MetadataBearer; * modification using DescribeVolumesModifications. For information * about tracking status changes using either method, see Monitoring volume * modifications.

- *

With previous-generation instance types, resizing an EBS volume may require detaching and + *

With previous-generation instance types, resizing an EBS volume might require detaching and * reattaching the volume or stopping and restarting the instance. For more information, see - * Modifying the size, - * IOPS, or type of an EBS volume on Linux and Modifying the size, IOPS, or type of an EBS - * volume on Windows.

+ * Amazon EBS Elastic + * Volumes (Linux) or Amazon EBS Elastic Volumes (Windows).

*

If you reach the maximum volume modification rate per volume limit, you will need to wait * at least six hours before applying further modifications to the affected EBS volume.

*/ diff --git a/clients/client-ec2/commands/ResetEbsDefaultKmsKeyIdCommand.ts b/clients/client-ec2/commands/ResetEbsDefaultKmsKeyIdCommand.ts index b26d3dcef473..2ae1f0bed5d8 100644 --- a/clients/client-ec2/commands/ResetEbsDefaultKmsKeyIdCommand.ts +++ b/clients/client-ec2/commands/ResetEbsDefaultKmsKeyIdCommand.ts @@ -25,7 +25,7 @@ export type ResetEbsDefaultKmsKeyIdCommandOutput = ResetEbsDefaultKmsKeyIdResult * to the AWS managed CMK for EBS.

*

After resetting the default CMK to the AWS managed CMK, you can continue to encrypt by a * customer managed CMK by specifying it when you create the volume. For more information, see - * Amazon EBS Encryption + * Amazon EBS encryption * in the Amazon Elastic Compute Cloud User Guide.

*/ export class ResetEbsDefaultKmsKeyIdCommand extends $Command< diff --git a/clients/client-ec2/models/models_0.ts b/clients/client-ec2/models/models_0.ts index 5284e753c43c..221913a13c66 100644 --- a/clients/client-ec2/models/models_0.ts +++ b/clients/client-ec2/models/models_0.ts @@ -3814,7 +3814,7 @@ export interface CopySnapshotRequest { *

To encrypt a copy of an unencrypted snapshot if encryption by default is not enabled, * enable encryption using this parameter. Otherwise, omit this parameter. Encrypted snapshots * are encrypted, even if you omit this parameter and encryption by default is not enabled. You - * cannot set this parameter to false. For more information, see Amazon EBS Encryption in the + * cannot set this parameter to false. For more information, see Amazon EBS encryption in the * Amazon Elastic Compute Cloud User Guide.

*/ Encrypted?: boolean; @@ -3847,13 +3847,13 @@ export interface CopySnapshotRequest { *

When you copy an encrypted source snapshot using the Amazon EC2 Query API, you must supply a * pre-signed URL. This parameter is optional for unencrypted snapshots. For more information, * see Query - * Requests.

+ * requests.

*

The PresignedUrl should use the snapshot source endpoint, the * CopySnapshot action, and include the SourceRegion, * SourceSnapshotId, and DestinationRegion parameters. The * PresignedUrl must be signed using AWS Signature Version 4. Because EBS * snapshots are stored in Amazon S3, the signing algorithm for this parameter uses the same logic - * that is described in Authenticating Requests by Using Query + * that is described in Authenticating Requests: Using Query * Parameters (AWS Signature Version 4) in the Amazon Simple Storage Service API Reference. An * invalid or improperly signed PresignedUrl will cause the copy operation to fail * asynchronously, and the snapshot will move to an error state.

@@ -5443,6 +5443,16 @@ export type _InstanceType = | "d2.4xlarge" | "d2.8xlarge" | "d2.xlarge" + | "d3.2xlarge" + | "d3.4xlarge" + | "d3.8xlarge" + | "d3.xlarge" + | "d3en.12xlarge" + | "d3en.2xlarge" + | "d3en.4xlarge" + | "d3en.6xlarge" + | "d3en.8xlarge" + | "d3en.xlarge" | "f1.16xlarge" | "f1.2xlarge" | "f1.4xlarge" @@ -5555,6 +5565,13 @@ export type _InstanceType = | "m5n.8xlarge" | "m5n.large" | "m5n.xlarge" + | "m5zn.12xlarge" + | "m5zn.2xlarge" + | "m5zn.3xlarge" + | "m5zn.6xlarge" + | "m5zn.large" + | "m5zn.metal" + | "m5zn.xlarge" | "m6g.12xlarge" | "m6g.16xlarge" | "m6g.2xlarge" @@ -5618,6 +5635,15 @@ export type _InstanceType = | "r5ad.8xlarge" | "r5ad.large" | "r5ad.xlarge" + | "r5b.12xlarge" + | "r5b.16xlarge" + | "r5b.24xlarge" + | "r5b.2xlarge" + | "r5b.4xlarge" + | "r5b.8xlarge" + | "r5b.large" + | "r5b.metal" + | "r5b.xlarge" | "r5d.12xlarge" | "r5d.16xlarge" | "r5d.24xlarge" @@ -6669,7 +6695,7 @@ export namespace CreateFpgaImageResult { }); } -export type VolumeType = "gp2" | "io1" | "io2" | "sc1" | "st1" | "standard"; +export type VolumeType = "gp2" | "gp3" | "io1" | "io2" | "sc1" | "st1" | "standard"; /** *

Describes a block device for an EBS volume.

@@ -6683,22 +6709,31 @@ export interface EbsBlockDevice { DeleteOnTermination?: boolean; /** - *

The number of I/O operations per second (IOPS) that the volume supports. For - * io1 and io2 volumes, this represents the number of IOPS that are provisioned - * for the volume. For gp2 volumes, this represents the baseline performance - * of the volume and the rate at which the volume accumulates I/O credits for bursting. For - * more information, see Amazon EBS volume types in the - * Amazon Elastic Compute Cloud User Guide.

- *

Constraints: Range is 100-16,000 IOPS for gp2 volumes and - * 100 to 64,000 IOPS for io1 and io2 volumes in - * most Regions. Maximum io1 and io2 IOPS of 64,000 is guaranteed - * only on Nitro-based - * instances. Other instance families guarantee performance up to - * 32,000 IOPS. For more information, see Amazon EBS Volume - * Types in the Amazon Elastic Compute Cloud User Guide.

- *

Condition: This parameter is required for requests to create io1 and io2 volumes; - * it is not used in requests to create gp2, st1, - * sc1, or standard volumes.

+ *

The number of I/O operations per second (IOPS). For gp3, io1, and io2 volumes, this + * represents the number of IOPS that are provisioned for the volume. For gp2 volumes, this + * represents the baseline performance of the volume and the rate at which the volume accumulates + * I/O credits for bursting.

+ *

The following are the supported values for each volume type:

+ *
    + *
  • + *

    + * gp3: 3,000-16,000 IOPS

    + *
  • + *
  • + *

    + * io1: 100-64,000 IOPS

    + *
  • + *
  • + *

    + * io2: 100-64,000 IOPS

    + *
  • + *
+ *

For io1 and io2 volumes, we guarantee 64,000 IOPS only for + * Instances built on the Nitro System. Other instance families guarantee performance + * up to 32,000 IOPS.

+ *

This parameter is required for io1 and io2 volumes. + * The default for gp3 volumes is 3,000 IOPS. + * This parameter is not supported for gp2, st1, sc1, or standard volumes.

*/ Iops?: number; @@ -6708,24 +6743,39 @@ export interface EbsBlockDevice { SnapshotId?: string; /** - *

The size of the volume, in GiB.

- *

Default: If you're creating the volume from a snapshot and don't specify a volume - * size, the default is the snapshot size.

- *

Constraints: 1-16384 for General Purpose SSD (gp2), 4-16384 for - * Provisioned IOPS SSD (io1 and io2), 500-16384 for Throughput Optimized HDD - * (st1), 500-16384 for Cold HDD (sc1), and 1-1024 for - * Magnetic (standard) volumes. If you specify a snapshot, the volume size - * must be equal to or larger than the snapshot size.

+ *

The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size. + * If you specify a snapshot, the default is the snapshot size. You can specify a volume + * size that is equal to or larger than the snapshot size.

+ *

The following are the supported volumes sizes for each volume type:

+ *
    + *
  • + *

    + * gp2 and gp3:1-16,384

    + *
  • + *
  • + *

    + * io1 and io2: 4-16,384

    + *
  • + *
  • + *

    + * st1: 500-16,384

    + *
  • + *
  • + *

    + * sc1: 500-16,384

    + *
  • + *
  • + *

    + * standard: 1-1,024

    + *
  • + *
*/ VolumeSize?: number; /** - *

The volume type. If you set the type to io1 or io2, you must also specify - * the Iops parameter. If you set the type to gp2, - * st1, sc1, or standard, you must omit - * the Iops parameter.

- *

Default: gp2 - *

+ *

The volume type. For more information, see Amazon EBS volume types in the + * Amazon Elastic Compute Cloud User Guide. If the volume type is io1 or io2, + * you must specify the IOPS that the volume supports.

*/ VolumeType?: VolumeType | string; @@ -6738,6 +6788,13 @@ export interface EbsBlockDevice { */ KmsKeyId?: string; + /** + *

The throughput that the volume supports, in MiB/s.

+ *

This parameter is valid only for gp3 volumes.

+ *

Valid Range: Minimum value of 125. Maximum value of 1000.

+ */ + Throughput?: number; + /** *

Indicates whether the encryption state of an EBS volume is changed while being * restored from a backing snapshot. @@ -7177,7 +7234,8 @@ export namespace KeyPair { */ export interface LaunchTemplateEbsBlockDeviceRequest { /** - *

Indicates whether the EBS volume is encrypted. Encrypted volumes can only be attached to instances that support Amazon EBS encryption. If you are creating a volume from a snapshot, you can't specify an encryption value.

+ *

Indicates whether the EBS volume is encrypted. Encrypted volumes can only be attached to instances that support Amazon EBS encryption. + * If you are creating a volume from a snapshot, you can't specify an encryption value.

*/ Encrypted?: boolean; @@ -7187,13 +7245,31 @@ export interface LaunchTemplateEbsBlockDeviceRequest { DeleteOnTermination?: boolean; /** - *

The number of I/O operations per second (IOPS) to provision for an io1 or io2 volume, with a maximum - * ratio of 50 IOPS/GiB for io1, and 500 IOPS/GiB for io2. Range is 100 to 64,000 IOPS for - * volumes in most Regions. Maximum IOPS of 64,000 is guaranteed only on - * Nitro-based instances. Other instance families guarantee performance up to - * 32,000 IOPS. For more information, see Amazon EBS Volume Types in the - * Amazon Elastic Compute Cloud User Guide.

- *

This parameter is valid only for Provisioned IOPS SSD (io1 and io2) volumes.

+ *

The number of I/O operations per second (IOPS). For gp3, io1, and io2 + * volumes, this represents the number of IOPS that are provisioned for the volume. For gp2 volumes, + * this represents the baseline performance of the volume and the rate at which the volume accumulates I/O credits + * for bursting.

+ *

The following are the supported values for each volume type:

+ *
    + *
  • + *

    + * gp3: 3,000-16,000 IOPS

    + *
  • + *
  • + *

    + * io1: 100-64,000 IOPS

    + *
  • + *
  • + *

    + * io2: 100-64,000 IOPS

    + *
  • + *
+ *

For io1 and io2 volumes, we guarantee 64,000 IOPS + * only for Instances built on the Nitro System. Other instance families guarantee performance up + * to 32,000 IOPS.

+ *

This parameter is required for io1 and io2 volumes. + * The default for gp3 volumes is 3,000 IOPS. + * This parameter is not supported for gp2, st1, sc1, or standard volumes.

*/ Iops?: number; @@ -7209,15 +7285,42 @@ export interface LaunchTemplateEbsBlockDeviceRequest { SnapshotId?: string; /** - *

The size of the volume, in GiB.

- *

Default: If you're creating the volume from a snapshot and don't specify a volume size, the default is the snapshot size.

+ *

The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size. + * If you specify a snapshot, the default is the snapshot size. You can specify a volume + * size that is equal to or larger than the snapshot size.

+ *

The following are the supported volumes sizes for each volume type:

+ *
    + *
  • + *

    + * gp2 and gp3: 1-16,384

    + *
  • + *
  • + *

    + * io1 and io2: 4-16,384

    + *
  • + *
  • + *

    + * st1 and sc1: 125-16,384

    + *
  • + *
  • + *

    + * standard: 1-1,024

    + *
  • + *
*/ VolumeSize?: number; /** - *

The volume type.

+ *

The volume type. The default is gp2. For more information, see Amazon EBS volume types in the + * Amazon Elastic Compute Cloud User Guide.

*/ VolumeType?: VolumeType | string; + + /** + *

The throughput to provision for a gp3 volume, with a maximum of 1,000 MiB/s.

+ *

Valid Range: Minimum value of 125. Maximum value of 1000.

+ */ + Throughput?: number; } export namespace LaunchTemplateEbsBlockDeviceRequest { diff --git a/clients/client-ec2/models/models_1.ts b/clients/client-ec2/models/models_1.ts index 326bc1e2e50b..ba9303ed838b 100644 --- a/clients/client-ec2/models/models_1.ts +++ b/clients/client-ec2/models/models_1.ts @@ -713,6 +713,11 @@ export interface LaunchTemplateEbsBlockDevice { *

The volume type.

*/ VolumeType?: VolumeType | string; + + /** + *

The throughput that the volume supports, in MiB/s.

+ */ + Throughput?: number; } export namespace LaunchTemplateEbsBlockDevice { @@ -5174,7 +5179,7 @@ export interface CreateVolumeRequest { AvailabilityZone: string | undefined; /** - *

Specifies whether the volume should be encrypted. + *

Indicates whether the volume should be encrypted. * The effect of setting the encryption state to true depends on * the volume origin (new or from a snapshot), starting encryption state, ownership, and whether encryption by default is enabled. * For more information, see Encryption by default @@ -5186,13 +5191,30 @@ export interface CreateVolumeRequest { Encrypted?: boolean; /** - *

The number of I/O operations per second (IOPS) to provision for an io1 or io2 volume, with a maximum - * ratio of 50 IOPS/GiB for io1, and 500 IOPS/GiB for io2. Range is 100 to 64,000 IOPS for - * volumes in most Regions. Maximum IOPS of 64,000 is guaranteed only on - * Nitro-based instances. Other instance families guarantee performance up to - * 32,000 IOPS. For more information, see Amazon EBS volume types in the - * Amazon Elastic Compute Cloud User Guide.

- *

This parameter is valid only for Provisioned IOPS SSD (io1 and io2) volumes.

+ *

The number of I/O operations per second (IOPS). For gp3, io1, and io2 volumes, this represents + * the number of IOPS that are provisioned for the volume. For gp2 volumes, this represents the baseline + * performance of the volume and the rate at which the volume accumulates I/O credits for bursting.

+ *

The following are the supported values for each volume type:

+ *
    + *
  • + *

    + * gp3: 3,000-16,000 IOPS

    + *
  • + *
  • + *

    + * io1: 100-64,000 IOPS

    + *
  • + *
  • + *

    + * io2: 100-64,000 IOPS

    + *
  • + *
+ *

For io1 and io2 volumes, we guarantee 64,000 IOPS only for + * Instances built on the Nitro System. Other instance families guarantee performance + * up to 32,000 IOPS.

+ *

This parameter is required for io1 and io2 volumes. + * The default for gp3 volumes is 3,000 IOPS. + * This parameter is not supported for gp2, st1, sc1, or standard volumes.

*/ Iops?: number; @@ -5226,14 +5248,28 @@ export interface CreateVolumeRequest { OutpostArn?: string; /** - *

The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size.

- *

Constraints: 1-16,384 for gp2, - * 4-16,384 for io1 and io2, 500-16,384 for - * st1, 500-16,384 for sc1, and - * 1-1,024 for standard. If you specify a - * snapshot, the volume size must be equal to or larger than the snapshot size.

- *

Default: If you're creating the volume from a snapshot and don't specify a volume size, - * the default is the snapshot size.

+ *

The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size. + * If you specify a snapshot, the default is the snapshot size. You can specify a volume + * size that is equal to or larger than the snapshot size.

+ *

The following are the supported volumes sizes for each volume type:

+ *
    + *
  • + *

    + * gp2 and gp3: 1-16,384

    + *
  • + *
  • + *

    + * io1 and io2: 4-16,384

    + *
  • + *
  • + *

    + * st1 and sc1: 125-16,384

    + *
  • + *
  • + *

    + * standard: 1-1,024

    + *
  • + *
*/ Size?: number; @@ -5243,9 +5279,31 @@ export interface CreateVolumeRequest { SnapshotId?: string; /** - *

The volume type. This can be gp2 for General Purpose SSD, io1 or io2 for Provisioned IOPS SSD, - * st1 for Throughput Optimized HDD, sc1 for Cold HDD, or - * standard for Magnetic volumes.

+ *

The volume type. This parameter can be one of the following values:

+ *
    + *
  • + *

    General Purpose SSD: gp2 | gp3 + *

    + *
  • + *
  • + *

    Provisioned IOPS SSD: io1 | io2 + *

    + *
  • + *
  • + *

    Throughput Optimized HDD: st1 + *

    + *
  • + *
  • + *

    Cold HDD: sc1 + *

    + *
  • + *
  • + *

    Magnetic: standard + *

    + *
  • + *
+ *

For more information, see Amazon EBS volume types in the + * Amazon Elastic Compute Cloud User Guide.

*

Default: gp2 *

*/ @@ -5264,12 +5322,20 @@ export interface CreateVolumeRequest { TagSpecifications?: TagSpecification[]; /** - *

Specifies whether to enable Amazon EBS Multi-Attach. If you enable Multi-Attach, you can attach the - * volume to up to 16 Nitro-based instances in the same Availability Zone. For more information, + *

Indicates whether to enable Amazon EBS Multi-Attach. If you enable Multi-Attach, you can attach the + * volume to up to 16 Instances built on the Nitro System in the same Availability Zone. This parameter is + * supported with io1 volumes only. For more information, * see * Amazon EBS Multi-Attach in the Amazon Elastic Compute Cloud User Guide.

*/ MultiAttachEnabled?: boolean; + + /** + *

The throughput to provision for a volume, with a maximum of 1,000 MiB/s.

+ *

This parameter is valid only for gp3 volumes.

+ *

Valid Range: Minimum value of 125. Maximum value of 1000.

+ */ + Throughput?: number; } export namespace CreateVolumeRequest { @@ -5336,19 +5402,9 @@ export interface Volume { VolumeId?: string; /** - *

The number of I/O operations per second (IOPS) that the volume supports. For Provisioned IOPS SSD - * volumes, this represents the number of IOPS that are provisioned for the volume. For General Purpose SSD - * volumes, this represents the baseline performance of the volume and the rate at which the - * volume accumulates I/O credits for bursting. For more information, see Amazon EBS volume types in - * the Amazon Elastic Compute Cloud User Guide.

- *

Constraints: Range is 100-16,000 IOPS for gp2 volumes and 100 - * to 64,000 IOPS for io1 and io2 volumes, in most Regions. The maximum - * IOPS for io1 and io2 of 64,000 is guaranteed only on Nitro-based - * instances. Other instance families guarantee performance up to - * 32,000 IOPS.

- *

Condition: This parameter is required for requests to create io1 and io2 volumes; - * it is not used in requests to create gp2, st1, - * sc1, or standard volumes.

+ *

The number of I/O operations per second (IOPS). For gp3, io1, and io2 volumes, this represents + * the number of IOPS that are provisioned for the volume. For gp2 volumes, this represents the baseline + * performance of the volume and the rate at which the volume accumulates I/O credits for bursting.

*/ Iops?: number; @@ -5358,9 +5414,7 @@ export interface Volume { Tags?: Tag[]; /** - *

The volume type. This can be gp2 for General Purpose SSD, io1 or io2 for Provisioned IOPS SSD, - * st1 for Throughput Optimized HDD, sc1 for Cold HDD, or - * standard for Magnetic volumes.

+ *

The volume type.

*/ VolumeType?: VolumeType | string; @@ -5373,6 +5427,11 @@ export interface Volume { *

Indicates whether Amazon EBS Multi-Attach is enabled.

*/ MultiAttachEnabled?: boolean; + + /** + *

The throughput that the volume supports, in MiB/s.

+ */ + Throughput?: number; } export namespace Volume { diff --git a/clients/client-ec2/models/models_3.ts b/clients/client-ec2/models/models_3.ts index baeb794dabd7..0dfe05df2416 100644 --- a/clients/client-ec2/models/models_3.ts +++ b/clients/client-ec2/models/models_3.ts @@ -3765,8 +3765,8 @@ export interface DescribeSnapshotsRequest { * MaxResults results in a single page along with a NextToken * response element. The remaining results of the initial request can be seen by sending another * DescribeSnapshots request with the returned NextToken value. This - * value can be between 5 and 1000; if MaxResults is given a value larger than 1000, - * only 1000 results are returned. If this parameter is not used, then + * value can be between 5 and 1,000; if MaxResults is given a value larger than 1,000, + * only 1,000 results are returned. If this parameter is not used, then * DescribeSnapshots returns all results. You cannot specify this parameter and * the snapshot IDs parameter in the same request.

*/ @@ -6846,9 +6846,8 @@ export interface DescribeVolumesRequest { * *
  • *

    - * volume-type - The Amazon EBS volume type. This can be gp2 - * for General Purpose SSD, io1 or io2 for Provisioned IOPS SSD, st1 for Throughput Optimized HDD, - * sc1 for Cold HDD, or standard for Magnetic volumes.

    + * volume-type - The Amazon EBS volume type (gp2 | gp3 | io1 | io2 | + * st1 | sc1| standard)

    *
  • * */ @@ -7039,6 +7038,11 @@ export interface VolumeModification { */ TargetVolumeType?: VolumeType | string; + /** + *

    The target throughput of the volume, in MiB/s.

    + */ + TargetThroughput?: number; + /** *

    The original size of the volume, in GiB.

    */ @@ -7054,6 +7058,11 @@ export interface VolumeModification { */ OriginalVolumeType?: VolumeType | string; + /** + *

    The original throughput of the volume, in MiB/s.

    + */ + OriginalThroughput?: number; + /** *

    The modification progress, from 0 to 100 percent complete.

    */ @@ -7166,8 +7175,8 @@ export interface DescribeVolumeStatusRequest { * paginated output. When this parameter is used, the request only returns * MaxResults results in a single page along with a NextToken * response element. The remaining results of the initial request can be seen by sending another - * request with the returned NextToken value. This value can be between 5 and 1000; - * if MaxResults is given a value larger than 1000, only 1000 results are returned. + * request with the returned NextToken value. This value can be between 5 and 1,000; + * if MaxResults is given a value larger than 1,000, only 1,000 results are returned. * If this parameter is not used, then DescribeVolumeStatus returns all results. You * cannot specify this parameter and the volume IDs parameter in the same request.

    */ diff --git a/clients/client-ec2/models/models_4.ts b/clients/client-ec2/models/models_4.ts index b48ea87ad2a4..4fea82fbc6e9 100644 --- a/clients/client-ec2/models/models_4.ts +++ b/clients/client-ec2/models/models_4.ts @@ -4121,27 +4121,64 @@ export interface ModifyVolumeRequest { /** *

    The target size of the volume, in GiB. The target volume size must be greater than or - * equal to than the existing size of the volume. For information about available EBS volume - * sizes, see Amazon EBS Volume - * Types.

    + * equal to the existing size of the volume.

    + *

    The following are the supported volumes sizes for each volume type:

    + *
      + *
    • + *

      + * gp2 and gp3: 1-16,384

      + *
    • + *
    • + *

      + * io1 and io2: 4-16,384

      + *
    • + *
    • + *

      + * st1 and sc1: 125-16,384

      + *
    • + *
    • + *

      + * standard: 1-1,024

      + *
    • + *
    *

    Default: If no size is specified, the existing size is retained.

    */ Size?: number; /** - *

    The target EBS volume type of the volume.

    + *

    The target EBS volume type of the volume. For more information, see Amazon EBS volume types in the Amazon Elastic Compute Cloud User Guide.

    *

    Default: If no type is specified, the existing type is retained.

    */ VolumeType?: VolumeType | string; /** - *

    The target IOPS rate of the volume.

    - *

    This is only valid for Provisioned IOPS SSD (io1 and io2) volumes. For moreinformation, see - * - * Provisioned IOPS SSD (io1 and io2) volumes.

    + *

    The target IOPS rate of the volume. This parameter is valid only for gp3, io1, and io2 volumes.

    + *

    The following are the supported values for each volume type:

    + *
      + *
    • + *

      + * gp3: 3,000-16,000 IOPS

      + *
    • + *
    • + *

      + * io1: 100-64,000 IOPS

      + *
    • + *
    • + *

      + * io2: 100-64,000 IOPS

      + *
    • + *
    *

    Default: If no IOPS value is specified, the existing value is retained.

    */ Iops?: number; + + /** + *

    The target throughput of the volume, in MiB/s. This parameter is valid only for gp3 volumes. + * The maximum value is 1,000.

    + *

    Default: If no throughput value is specified, the existing value is retained.

    + *

    Valid Range: Minimum value of 125. Maximum value of 1000.

    + */ + Throughput?: number; } export namespace ModifyVolumeRequest { diff --git a/clients/client-ec2/protocols/Aws_ec2.ts b/clients/client-ec2/protocols/Aws_ec2.ts index ad2c49799beb..f39ea0f621c5 100644 --- a/clients/client-ec2/protocols/Aws_ec2.ts +++ b/clients/client-ec2/protocols/Aws_ec2.ts @@ -31638,6 +31638,9 @@ const serializeAws_ec2CreateVolumeRequest = (input: CreateVolumeRequest, context if (input.MultiAttachEnabled !== undefined) { entries["MultiAttachEnabled"] = input.MultiAttachEnabled; } + if (input.Throughput !== undefined) { + entries["Throughput"] = input.Throughput; + } return entries; }; @@ -36464,6 +36467,9 @@ const serializeAws_ec2EbsBlockDevice = (input: EbsBlockDevice, context: __SerdeC if (input.KmsKeyId !== undefined) { entries["KmsKeyId"] = input.KmsKeyId; } + if (input.Throughput !== undefined) { + entries["Throughput"] = input.Throughput; + } if (input.Encrypted !== undefined) { entries["Encrypted"] = input.Encrypted; } @@ -38580,6 +38586,9 @@ const serializeAws_ec2LaunchTemplateEbsBlockDeviceRequest = ( if (input.VolumeType !== undefined) { entries["VolumeType"] = input.VolumeType; } + if (input.Throughput !== undefined) { + entries["Throughput"] = input.Throughput; + } return entries; }; @@ -40192,6 +40201,9 @@ const serializeAws_ec2ModifyVolumeRequest = (input: ModifyVolumeRequest, context if (input.Iops !== undefined) { entries["Iops"] = input.Iops; } + if (input.Throughput !== undefined) { + entries["Throughput"] = input.Throughput; + } return entries; }; @@ -51396,6 +51408,7 @@ const deserializeAws_ec2EbsBlockDevice = (output: any, context: __SerdeContext): VolumeSize: undefined, VolumeType: undefined, KmsKeyId: undefined, + Throughput: undefined, Encrypted: undefined, }; if (output["deleteOnTermination"] !== undefined) { @@ -51416,6 +51429,9 @@ const deserializeAws_ec2EbsBlockDevice = (output: any, context: __SerdeContext): if (output["KmsKeyId"] !== undefined) { contents.KmsKeyId = output["KmsKeyId"]; } + if (output["throughput"] !== undefined) { + contents.Throughput = parseInt(output["throughput"]); + } if (output["encrypted"] !== undefined) { contents.Encrypted = output["encrypted"] == "true"; } @@ -56027,6 +56043,7 @@ const deserializeAws_ec2LaunchTemplateEbsBlockDevice = ( SnapshotId: undefined, VolumeSize: undefined, VolumeType: undefined, + Throughput: undefined, }; if (output["encrypted"] !== undefined) { contents.Encrypted = output["encrypted"] == "true"; @@ -56049,6 +56066,9 @@ const deserializeAws_ec2LaunchTemplateEbsBlockDevice = ( if (output["volumeType"] !== undefined) { contents.VolumeType = output["volumeType"]; } + if (output["throughput"] !== undefined) { + contents.Throughput = parseInt(output["throughput"]); + } return contents; }; @@ -63748,6 +63768,7 @@ const deserializeAws_ec2Volume = (output: any, context: __SerdeContext): Volume VolumeType: undefined, FastRestored: undefined, MultiAttachEnabled: undefined, + Throughput: undefined, }; if (output.attachmentSet === "") { contents.Attachments = []; @@ -63803,6 +63824,9 @@ const deserializeAws_ec2Volume = (output: any, context: __SerdeContext): Volume if (output["multiAttachEnabled"] !== undefined) { contents.MultiAttachEnabled = output["multiAttachEnabled"] == "true"; } + if (output["throughput"] !== undefined) { + contents.Throughput = parseInt(output["throughput"]); + } return contents; }; @@ -63852,9 +63876,11 @@ const deserializeAws_ec2VolumeModification = (output: any, context: __SerdeConte TargetSize: undefined, TargetIops: undefined, TargetVolumeType: undefined, + TargetThroughput: undefined, OriginalSize: undefined, OriginalIops: undefined, OriginalVolumeType: undefined, + OriginalThroughput: undefined, Progress: undefined, StartTime: undefined, EndTime: undefined, @@ -63877,6 +63903,9 @@ const deserializeAws_ec2VolumeModification = (output: any, context: __SerdeConte if (output["targetVolumeType"] !== undefined) { contents.TargetVolumeType = output["targetVolumeType"]; } + if (output["targetThroughput"] !== undefined) { + contents.TargetThroughput = parseInt(output["targetThroughput"]); + } if (output["originalSize"] !== undefined) { contents.OriginalSize = parseInt(output["originalSize"]); } @@ -63886,6 +63915,9 @@ const deserializeAws_ec2VolumeModification = (output: any, context: __SerdeConte if (output["originalVolumeType"] !== undefined) { contents.OriginalVolumeType = output["originalVolumeType"]; } + if (output["originalThroughput"] !== undefined) { + contents.OriginalThroughput = parseInt(output["originalThroughput"]); + } if (output["progress"] !== undefined) { contents.Progress = parseInt(output["progress"]); } diff --git a/clients/client-ecr-public/.gitignore b/clients/client-ecr-public/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-ecr-public/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-ecr-public/.npmignore b/clients/client-ecr-public/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-ecr-public/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-ecr-public/ECRPUBLIC.ts b/clients/client-ecr-public/ECRPUBLIC.ts new file mode 100644 index 000000000000..7d07b0f42ad6 --- /dev/null +++ b/clients/client-ecr-public/ECRPUBLIC.ts @@ -0,0 +1,796 @@ +import { ECRPUBLICClient } from "./ECRPUBLICClient"; +import { + BatchCheckLayerAvailabilityCommand, + BatchCheckLayerAvailabilityCommandInput, + BatchCheckLayerAvailabilityCommandOutput, +} from "./commands/BatchCheckLayerAvailabilityCommand"; +import { + BatchDeleteImageCommand, + BatchDeleteImageCommandInput, + BatchDeleteImageCommandOutput, +} from "./commands/BatchDeleteImageCommand"; +import { + CompleteLayerUploadCommand, + CompleteLayerUploadCommandInput, + CompleteLayerUploadCommandOutput, +} from "./commands/CompleteLayerUploadCommand"; +import { + CreateRepositoryCommand, + CreateRepositoryCommandInput, + CreateRepositoryCommandOutput, +} from "./commands/CreateRepositoryCommand"; +import { + DeleteRepositoryCommand, + DeleteRepositoryCommandInput, + DeleteRepositoryCommandOutput, +} from "./commands/DeleteRepositoryCommand"; +import { + DeleteRepositoryPolicyCommand, + DeleteRepositoryPolicyCommandInput, + DeleteRepositoryPolicyCommandOutput, +} from "./commands/DeleteRepositoryPolicyCommand"; +import { + DescribeImageTagsCommand, + DescribeImageTagsCommandInput, + DescribeImageTagsCommandOutput, +} from "./commands/DescribeImageTagsCommand"; +import { + DescribeImagesCommand, + DescribeImagesCommandInput, + DescribeImagesCommandOutput, +} from "./commands/DescribeImagesCommand"; +import { + DescribeRegistriesCommand, + DescribeRegistriesCommandInput, + DescribeRegistriesCommandOutput, +} from "./commands/DescribeRegistriesCommand"; +import { + DescribeRepositoriesCommand, + DescribeRepositoriesCommandInput, + DescribeRepositoriesCommandOutput, +} from "./commands/DescribeRepositoriesCommand"; +import { + GetAuthorizationTokenCommand, + GetAuthorizationTokenCommandInput, + GetAuthorizationTokenCommandOutput, +} from "./commands/GetAuthorizationTokenCommand"; +import { + GetRegistryCatalogDataCommand, + GetRegistryCatalogDataCommandInput, + GetRegistryCatalogDataCommandOutput, +} from "./commands/GetRegistryCatalogDataCommand"; +import { + GetRepositoryCatalogDataCommand, + GetRepositoryCatalogDataCommandInput, + GetRepositoryCatalogDataCommandOutput, +} from "./commands/GetRepositoryCatalogDataCommand"; +import { + GetRepositoryPolicyCommand, + GetRepositoryPolicyCommandInput, + GetRepositoryPolicyCommandOutput, +} from "./commands/GetRepositoryPolicyCommand"; +import { + InitiateLayerUploadCommand, + InitiateLayerUploadCommandInput, + InitiateLayerUploadCommandOutput, +} from "./commands/InitiateLayerUploadCommand"; +import { PutImageCommand, PutImageCommandInput, PutImageCommandOutput } from "./commands/PutImageCommand"; +import { + PutRegistryCatalogDataCommand, + PutRegistryCatalogDataCommandInput, + PutRegistryCatalogDataCommandOutput, +} from "./commands/PutRegistryCatalogDataCommand"; +import { + PutRepositoryCatalogDataCommand, + PutRepositoryCatalogDataCommandInput, + PutRepositoryCatalogDataCommandOutput, +} from "./commands/PutRepositoryCatalogDataCommand"; +import { + SetRepositoryPolicyCommand, + SetRepositoryPolicyCommandInput, + SetRepositoryPolicyCommandOutput, +} from "./commands/SetRepositoryPolicyCommand"; +import { + UploadLayerPartCommand, + UploadLayerPartCommandInput, + UploadLayerPartCommandOutput, +} from "./commands/UploadLayerPartCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + * Amazon Elastic Container Registry Public + *

    Amazon Elastic Container Registry (Amazon ECR) is a managed container image registry service. Amazon ECR provides both + * public and private registries to host your container images. You can use the familiar + * Docker CLI, or their preferred client, to push, pull, and manage images. Amazon ECR provides a + * secure, scalable, and reliable registry for your Docker or Open Container Initiative (OCI) + * images. Amazon ECR supports public repositories with this API. For information about the Amazon ECR + * API for private repositories, see Amazon Elastic Container Registry API Reference.

    + */ +export class ECRPUBLIC extends ECRPUBLICClient { + /** + *

    Checks the availability of one or more image layers within a repository in a public + * registry. When an image is pushed to a repository, each image layer is checked to verify if + * it has been uploaded before. If it has been uploaded, then the image layer is + * skipped.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ + public batchCheckLayerAvailability( + args: BatchCheckLayerAvailabilityCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchCheckLayerAvailability( + args: BatchCheckLayerAvailabilityCommandInput, + cb: (err: any, data?: BatchCheckLayerAvailabilityCommandOutput) => void + ): void; + public batchCheckLayerAvailability( + args: BatchCheckLayerAvailabilityCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchCheckLayerAvailabilityCommandOutput) => void + ): void; + public batchCheckLayerAvailability( + args: BatchCheckLayerAvailabilityCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchCheckLayerAvailabilityCommandOutput) => void), + cb?: (err: any, data?: BatchCheckLayerAvailabilityCommandOutput) => void + ): Promise | void { + const command = new BatchCheckLayerAvailabilityCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes a list of specified images within a repository in a public registry. Images are + * specified with either an imageTag or imageDigest.

    + *

    You can remove a tag from an image by specifying the image's tag in your request. When + * you remove the last tag from an image, the image is deleted from your repository.

    + *

    You can completely delete an image (and all of its tags) by specifying the image's + * digest in your request.

    + */ + public batchDeleteImage( + args: BatchDeleteImageCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchDeleteImage( + args: BatchDeleteImageCommandInput, + cb: (err: any, data?: BatchDeleteImageCommandOutput) => void + ): void; + public batchDeleteImage( + args: BatchDeleteImageCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchDeleteImageCommandOutput) => void + ): void; + public batchDeleteImage( + args: BatchDeleteImageCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchDeleteImageCommandOutput) => void), + cb?: (err: any, data?: BatchDeleteImageCommandOutput) => void + ): Promise | void { + const command = new BatchDeleteImageCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Informs Amazon ECR that the image layer upload has completed for a specified public registry, + * repository name, and upload ID. You can optionally provide a sha256 digest of + * the image layer for data validation purposes.

    + *

    When an image is pushed, the CompleteLayerUpload API is called once per each new image + * layer to verify that the upload has completed.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ + public completeLayerUpload( + args: CompleteLayerUploadCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public completeLayerUpload( + args: CompleteLayerUploadCommandInput, + cb: (err: any, data?: CompleteLayerUploadCommandOutput) => void + ): void; + public completeLayerUpload( + args: CompleteLayerUploadCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CompleteLayerUploadCommandOutput) => void + ): void; + public completeLayerUpload( + args: CompleteLayerUploadCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CompleteLayerUploadCommandOutput) => void), + cb?: (err: any, data?: CompleteLayerUploadCommandOutput) => void + ): Promise | void { + const command = new CompleteLayerUploadCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Creates a repository in a public registry. For more information, see Amazon ECR + * repositories in the Amazon Elastic Container Registry User Guide.

    + */ + public createRepository( + args: CreateRepositoryCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createRepository( + args: CreateRepositoryCommandInput, + cb: (err: any, data?: CreateRepositoryCommandOutput) => void + ): void; + public createRepository( + args: CreateRepositoryCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateRepositoryCommandOutput) => void + ): void; + public createRepository( + args: CreateRepositoryCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateRepositoryCommandOutput) => void), + cb?: (err: any, data?: CreateRepositoryCommandOutput) => void + ): Promise | void { + const command = new CreateRepositoryCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes a repository in a public registry. If the repository contains images, you must + * either delete all images in the repository or use the force option which + * deletes all images on your behalf before deleting the repository.

    + */ + public deleteRepository( + args: DeleteRepositoryCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteRepository( + args: DeleteRepositoryCommandInput, + cb: (err: any, data?: DeleteRepositoryCommandOutput) => void + ): void; + public deleteRepository( + args: DeleteRepositoryCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteRepositoryCommandOutput) => void + ): void; + public deleteRepository( + args: DeleteRepositoryCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteRepositoryCommandOutput) => void), + cb?: (err: any, data?: DeleteRepositoryCommandOutput) => void + ): Promise | void { + const command = new DeleteRepositoryCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes the repository policy associated with the specified repository.

    + */ + public deleteRepositoryPolicy( + args: DeleteRepositoryPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteRepositoryPolicy( + args: DeleteRepositoryPolicyCommandInput, + cb: (err: any, data?: DeleteRepositoryPolicyCommandOutput) => void + ): void; + public deleteRepositoryPolicy( + args: DeleteRepositoryPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteRepositoryPolicyCommandOutput) => void + ): void; + public deleteRepositoryPolicy( + args: DeleteRepositoryPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteRepositoryPolicyCommandOutput) => void), + cb?: (err: any, data?: DeleteRepositoryPolicyCommandOutput) => void + ): Promise | void { + const command = new DeleteRepositoryPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Returns metadata about the images in a repository in a public registry.

    + * + *

    Beginning with Docker version 1.9, the Docker client compresses image layers before + * pushing them to a V2 Docker registry. The output of the docker images + * command shows the uncompressed image size, so it may return a larger image size than the + * image sizes returned by DescribeImages.

    + *
    + */ + public describeImages( + args: DescribeImagesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeImages( + args: DescribeImagesCommandInput, + cb: (err: any, data?: DescribeImagesCommandOutput) => void + ): void; + public describeImages( + args: DescribeImagesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeImagesCommandOutput) => void + ): void; + public describeImages( + args: DescribeImagesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeImagesCommandOutput) => void), + cb?: (err: any, data?: DescribeImagesCommandOutput) => void + ): Promise | void { + const command = new DescribeImagesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Returns the image tag details for a repository in a public registry.

    + */ + public describeImageTags( + args: DescribeImageTagsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeImageTags( + args: DescribeImageTagsCommandInput, + cb: (err: any, data?: DescribeImageTagsCommandOutput) => void + ): void; + public describeImageTags( + args: DescribeImageTagsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeImageTagsCommandOutput) => void + ): void; + public describeImageTags( + args: DescribeImageTagsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeImageTagsCommandOutput) => void), + cb?: (err: any, data?: DescribeImageTagsCommandOutput) => void + ): Promise | void { + const command = new DescribeImageTagsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Returns details for a public registry.

    + */ + public describeRegistries( + args: DescribeRegistriesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeRegistries( + args: DescribeRegistriesCommandInput, + cb: (err: any, data?: DescribeRegistriesCommandOutput) => void + ): void; + public describeRegistries( + args: DescribeRegistriesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeRegistriesCommandOutput) => void + ): void; + public describeRegistries( + args: DescribeRegistriesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeRegistriesCommandOutput) => void), + cb?: (err: any, data?: DescribeRegistriesCommandOutput) => void + ): Promise | void { + const command = new DescribeRegistriesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Describes repositories in a public registry.

    + */ + public describeRepositories( + args: DescribeRepositoriesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeRepositories( + args: DescribeRepositoriesCommandInput, + cb: (err: any, data?: DescribeRepositoriesCommandOutput) => void + ): void; + public describeRepositories( + args: DescribeRepositoriesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeRepositoriesCommandOutput) => void + ): void; + public describeRepositories( + args: DescribeRepositoriesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeRepositoriesCommandOutput) => void), + cb?: (err: any, data?: DescribeRepositoriesCommandOutput) => void + ): Promise | void { + const command = new DescribeRepositoriesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Retrieves an authorization token. An authorization token represents your IAM + * authentication credentials and can be used to access any Amazon ECR registry that your IAM + * principal has access to. The authorization token is valid for 12 hours. This API requires + * the ecr-public:GetAuthorizationToken and + * sts:GetServiceBearerToken permissions.

    + */ + public getAuthorizationToken( + args: GetAuthorizationTokenCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getAuthorizationToken( + args: GetAuthorizationTokenCommandInput, + cb: (err: any, data?: GetAuthorizationTokenCommandOutput) => void + ): void; + public getAuthorizationToken( + args: GetAuthorizationTokenCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetAuthorizationTokenCommandOutput) => void + ): void; + public getAuthorizationToken( + args: GetAuthorizationTokenCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetAuthorizationTokenCommandOutput) => void), + cb?: (err: any, data?: GetAuthorizationTokenCommandOutput) => void + ): Promise | void { + const command = new GetAuthorizationTokenCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Retrieves catalog metadata for a public registry.

    + */ + public getRegistryCatalogData( + args: GetRegistryCatalogDataCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getRegistryCatalogData( + args: GetRegistryCatalogDataCommandInput, + cb: (err: any, data?: GetRegistryCatalogDataCommandOutput) => void + ): void; + public getRegistryCatalogData( + args: GetRegistryCatalogDataCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetRegistryCatalogDataCommandOutput) => void + ): void; + public getRegistryCatalogData( + args: GetRegistryCatalogDataCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetRegistryCatalogDataCommandOutput) => void), + cb?: (err: any, data?: GetRegistryCatalogDataCommandOutput) => void + ): Promise | void { + const command = new GetRegistryCatalogDataCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Retrieve catalog metadata for a repository in a public registry. This metadata is + * displayed publicly in the Amazon ECR Public Gallery.

    + */ + public getRepositoryCatalogData( + args: GetRepositoryCatalogDataCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getRepositoryCatalogData( + args: GetRepositoryCatalogDataCommandInput, + cb: (err: any, data?: GetRepositoryCatalogDataCommandOutput) => void + ): void; + public getRepositoryCatalogData( + args: GetRepositoryCatalogDataCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetRepositoryCatalogDataCommandOutput) => void + ): void; + public getRepositoryCatalogData( + args: GetRepositoryCatalogDataCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetRepositoryCatalogDataCommandOutput) => void), + cb?: (err: any, data?: GetRepositoryCatalogDataCommandOutput) => void + ): Promise | void { + const command = new GetRepositoryCatalogDataCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Retrieves the repository policy for the specified repository.

    + */ + public getRepositoryPolicy( + args: GetRepositoryPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getRepositoryPolicy( + args: GetRepositoryPolicyCommandInput, + cb: (err: any, data?: GetRepositoryPolicyCommandOutput) => void + ): void; + public getRepositoryPolicy( + args: GetRepositoryPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetRepositoryPolicyCommandOutput) => void + ): void; + public getRepositoryPolicy( + args: GetRepositoryPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetRepositoryPolicyCommandOutput) => void), + cb?: (err: any, data?: GetRepositoryPolicyCommandOutput) => void + ): Promise | void { + const command = new GetRepositoryPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Notifies Amazon ECR that you intend to upload an image layer.

    + *

    When an image is pushed, the InitiateLayerUpload API is called once per image layer that + * has not already been uploaded. Whether or not an image layer has been uploaded is + * determined by the BatchCheckLayerAvailability API action.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ + public initiateLayerUpload( + args: InitiateLayerUploadCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public initiateLayerUpload( + args: InitiateLayerUploadCommandInput, + cb: (err: any, data?: InitiateLayerUploadCommandOutput) => void + ): void; + public initiateLayerUpload( + args: InitiateLayerUploadCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: InitiateLayerUploadCommandOutput) => void + ): void; + public initiateLayerUpload( + args: InitiateLayerUploadCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: InitiateLayerUploadCommandOutput) => void), + cb?: (err: any, data?: InitiateLayerUploadCommandOutput) => void + ): Promise | void { + const command = new InitiateLayerUploadCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Creates or updates the image manifest and tags associated with an image.

    + *

    When an image is pushed and all new image layers have been uploaded, the PutImage API is + * called once to create or update the image manifest and the tags associated with the + * image.

    + * + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ + public putImage(args: PutImageCommandInput, options?: __HttpHandlerOptions): Promise; + public putImage(args: PutImageCommandInput, cb: (err: any, data?: PutImageCommandOutput) => void): void; + public putImage( + args: PutImageCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutImageCommandOutput) => void + ): void; + public putImage( + args: PutImageCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutImageCommandOutput) => void), + cb?: (err: any, data?: PutImageCommandOutput) => void + ): Promise | void { + const command = new PutImageCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Create or updates the catalog data for a public registry.

    + */ + public putRegistryCatalogData( + args: PutRegistryCatalogDataCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public putRegistryCatalogData( + args: PutRegistryCatalogDataCommandInput, + cb: (err: any, data?: PutRegistryCatalogDataCommandOutput) => void + ): void; + public putRegistryCatalogData( + args: PutRegistryCatalogDataCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutRegistryCatalogDataCommandOutput) => void + ): void; + public putRegistryCatalogData( + args: PutRegistryCatalogDataCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutRegistryCatalogDataCommandOutput) => void), + cb?: (err: any, data?: PutRegistryCatalogDataCommandOutput) => void + ): Promise | void { + const command = new PutRegistryCatalogDataCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Creates or updates the catalog data for a repository in a public registry.

    + */ + public putRepositoryCatalogData( + args: PutRepositoryCatalogDataCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public putRepositoryCatalogData( + args: PutRepositoryCatalogDataCommandInput, + cb: (err: any, data?: PutRepositoryCatalogDataCommandOutput) => void + ): void; + public putRepositoryCatalogData( + args: PutRepositoryCatalogDataCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutRepositoryCatalogDataCommandOutput) => void + ): void; + public putRepositoryCatalogData( + args: PutRepositoryCatalogDataCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutRepositoryCatalogDataCommandOutput) => void), + cb?: (err: any, data?: PutRepositoryCatalogDataCommandOutput) => void + ): Promise | void { + const command = new PutRepositoryCatalogDataCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Applies a repository policy to the specified public repository to control access + * permissions. For more information, see Amazon ECR Repository + * Policies in the Amazon Elastic Container Registry User Guide.

    + */ + public setRepositoryPolicy( + args: SetRepositoryPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public setRepositoryPolicy( + args: SetRepositoryPolicyCommandInput, + cb: (err: any, data?: SetRepositoryPolicyCommandOutput) => void + ): void; + public setRepositoryPolicy( + args: SetRepositoryPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: SetRepositoryPolicyCommandOutput) => void + ): void; + public setRepositoryPolicy( + args: SetRepositoryPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: SetRepositoryPolicyCommandOutput) => void), + cb?: (err: any, data?: SetRepositoryPolicyCommandOutput) => void + ): Promise | void { + const command = new SetRepositoryPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Uploads an image layer part to Amazon ECR.

    + *

    When an image is pushed, each new image layer is uploaded in parts. The maximum size of + * each image layer part can be 20971520 bytes (or about 20MB). The UploadLayerPart API is + * called once per each new image layer part.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ + public uploadLayerPart( + args: UploadLayerPartCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public uploadLayerPart( + args: UploadLayerPartCommandInput, + cb: (err: any, data?: UploadLayerPartCommandOutput) => void + ): void; + public uploadLayerPart( + args: UploadLayerPartCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UploadLayerPartCommandOutput) => void + ): void; + public uploadLayerPart( + args: UploadLayerPartCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UploadLayerPartCommandOutput) => void), + cb?: (err: any, data?: UploadLayerPartCommandOutput) => void + ): Promise | void { + const command = new UploadLayerPartCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-ecr-public/ECRPUBLICClient.ts b/clients/client-ecr-public/ECRPUBLICClient.ts new file mode 100644 index 000000000000..f15c762e04fd --- /dev/null +++ b/clients/client-ecr-public/ECRPUBLICClient.ts @@ -0,0 +1,303 @@ +import { + BatchCheckLayerAvailabilityCommandInput, + BatchCheckLayerAvailabilityCommandOutput, +} from "./commands/BatchCheckLayerAvailabilityCommand"; +import { BatchDeleteImageCommandInput, BatchDeleteImageCommandOutput } from "./commands/BatchDeleteImageCommand"; +import { + CompleteLayerUploadCommandInput, + CompleteLayerUploadCommandOutput, +} from "./commands/CompleteLayerUploadCommand"; +import { CreateRepositoryCommandInput, CreateRepositoryCommandOutput } from "./commands/CreateRepositoryCommand"; +import { DeleteRepositoryCommandInput, DeleteRepositoryCommandOutput } from "./commands/DeleteRepositoryCommand"; +import { + DeleteRepositoryPolicyCommandInput, + DeleteRepositoryPolicyCommandOutput, +} from "./commands/DeleteRepositoryPolicyCommand"; +import { DescribeImageTagsCommandInput, DescribeImageTagsCommandOutput } from "./commands/DescribeImageTagsCommand"; +import { DescribeImagesCommandInput, DescribeImagesCommandOutput } from "./commands/DescribeImagesCommand"; +import { DescribeRegistriesCommandInput, DescribeRegistriesCommandOutput } from "./commands/DescribeRegistriesCommand"; +import { + DescribeRepositoriesCommandInput, + DescribeRepositoriesCommandOutput, +} from "./commands/DescribeRepositoriesCommand"; +import { + GetAuthorizationTokenCommandInput, + GetAuthorizationTokenCommandOutput, +} from "./commands/GetAuthorizationTokenCommand"; +import { + GetRegistryCatalogDataCommandInput, + GetRegistryCatalogDataCommandOutput, +} from "./commands/GetRegistryCatalogDataCommand"; +import { + GetRepositoryCatalogDataCommandInput, + GetRepositoryCatalogDataCommandOutput, +} from "./commands/GetRepositoryCatalogDataCommand"; +import { + GetRepositoryPolicyCommandInput, + GetRepositoryPolicyCommandOutput, +} from "./commands/GetRepositoryPolicyCommand"; +import { + InitiateLayerUploadCommandInput, + InitiateLayerUploadCommandOutput, +} from "./commands/InitiateLayerUploadCommand"; +import { PutImageCommandInput, PutImageCommandOutput } from "./commands/PutImageCommand"; +import { + PutRegistryCatalogDataCommandInput, + PutRegistryCatalogDataCommandOutput, +} from "./commands/PutRegistryCatalogDataCommand"; +import { + PutRepositoryCatalogDataCommandInput, + PutRepositoryCatalogDataCommandOutput, +} from "./commands/PutRepositoryCatalogDataCommand"; +import { + SetRepositoryPolicyCommandInput, + SetRepositoryPolicyCommandOutput, +} from "./commands/SetRepositoryPolicyCommand"; +import { UploadLayerPartCommandInput, UploadLayerPartCommandOutput } from "./commands/UploadLayerPartCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = + | BatchCheckLayerAvailabilityCommandInput + | BatchDeleteImageCommandInput + | CompleteLayerUploadCommandInput + | CreateRepositoryCommandInput + | DeleteRepositoryCommandInput + | DeleteRepositoryPolicyCommandInput + | DescribeImageTagsCommandInput + | DescribeImagesCommandInput + | DescribeRegistriesCommandInput + | DescribeRepositoriesCommandInput + | GetAuthorizationTokenCommandInput + | GetRegistryCatalogDataCommandInput + | GetRepositoryCatalogDataCommandInput + | GetRepositoryPolicyCommandInput + | InitiateLayerUploadCommandInput + | PutImageCommandInput + | PutRegistryCatalogDataCommandInput + | PutRepositoryCatalogDataCommandInput + | SetRepositoryPolicyCommandInput + | UploadLayerPartCommandInput; + +export type ServiceOutputTypes = + | BatchCheckLayerAvailabilityCommandOutput + | BatchDeleteImageCommandOutput + | CompleteLayerUploadCommandOutput + | CreateRepositoryCommandOutput + | DeleteRepositoryCommandOutput + | DeleteRepositoryPolicyCommandOutput + | DescribeImageTagsCommandOutput + | DescribeImagesCommandOutput + | DescribeRegistriesCommandOutput + | DescribeRepositoriesCommandOutput + | GetAuthorizationTokenCommandOutput + | GetRegistryCatalogDataCommandOutput + | GetRepositoryCatalogDataCommandOutput + | GetRepositoryPolicyCommandOutput + | InitiateLayerUploadCommandOutput + | PutImageCommandOutput + | PutRegistryCatalogDataCommandOutput + | PutRepositoryCatalogDataCommandOutput + | SetRepositoryPolicyCommandOutput + | UploadLayerPartCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type ECRPUBLICClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type ECRPUBLICClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + * Amazon Elastic Container Registry Public + *

    Amazon Elastic Container Registry (Amazon ECR) is a managed container image registry service. Amazon ECR provides both + * public and private registries to host your container images. You can use the familiar + * Docker CLI, or their preferred client, to push, pull, and manage images. Amazon ECR provides a + * secure, scalable, and reliable registry for your Docker or Open Container Initiative (OCI) + * images. Amazon ECR supports public repositories with this API. For information about the Amazon ECR + * API for private repositories, see Amazon Elastic Container Registry API Reference.

    + */ +export class ECRPUBLICClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + ECRPUBLICClientResolvedConfig +> { + readonly config: ECRPUBLICClientResolvedConfig; + + constructor(configuration: ECRPUBLICClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-ecr-public/LICENSE b/clients/client-ecr-public/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-ecr-public/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-ecr-public/README.md b/clients/client-ecr-public/README.md new file mode 100644 index 000000000000..3699b5256baa --- /dev/null +++ b/clients/client-ecr-public/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-ecr-public + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-ecr-public/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-ecr-public) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-ecr-public.svg)](https://www.npmjs.com/package/@aws-sdk/client-ecr-public) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-ecr-public/commands/BatchCheckLayerAvailabilityCommand.ts b/clients/client-ecr-public/commands/BatchCheckLayerAvailabilityCommand.ts new file mode 100644 index 000000000000..e1c5008b4e06 --- /dev/null +++ b/clients/client-ecr-public/commands/BatchCheckLayerAvailabilityCommand.ts @@ -0,0 +1,97 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { BatchCheckLayerAvailabilityRequest, BatchCheckLayerAvailabilityResponse } from "../models/models_0"; +import { + deserializeAws_json1_1BatchCheckLayerAvailabilityCommand, + serializeAws_json1_1BatchCheckLayerAvailabilityCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchCheckLayerAvailabilityCommandInput = BatchCheckLayerAvailabilityRequest; +export type BatchCheckLayerAvailabilityCommandOutput = BatchCheckLayerAvailabilityResponse & __MetadataBearer; + +/** + *

    Checks the availability of one or more image layers within a repository in a public + * registry. When an image is pushed to a repository, each image layer is checked to verify if + * it has been uploaded before. If it has been uploaded, then the image layer is + * skipped.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ +export class BatchCheckLayerAvailabilityCommand extends $Command< + BatchCheckLayerAvailabilityCommandInput, + BatchCheckLayerAvailabilityCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchCheckLayerAvailabilityCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "BatchCheckLayerAvailabilityCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchCheckLayerAvailabilityRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchCheckLayerAvailabilityResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchCheckLayerAvailabilityCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1BatchCheckLayerAvailabilityCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1BatchCheckLayerAvailabilityCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/BatchDeleteImageCommand.ts b/clients/client-ecr-public/commands/BatchDeleteImageCommand.ts new file mode 100644 index 000000000000..b83482e4e67b --- /dev/null +++ b/clients/client-ecr-public/commands/BatchDeleteImageCommand.ts @@ -0,0 +1,93 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { BatchDeleteImageRequest, BatchDeleteImageResponse } from "../models/models_0"; +import { + deserializeAws_json1_1BatchDeleteImageCommand, + serializeAws_json1_1BatchDeleteImageCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchDeleteImageCommandInput = BatchDeleteImageRequest; +export type BatchDeleteImageCommandOutput = BatchDeleteImageResponse & __MetadataBearer; + +/** + *

    Deletes a list of specified images within a repository in a public registry. Images are + * specified with either an imageTag or imageDigest.

    + *

    You can remove a tag from an image by specifying the image's tag in your request. When + * you remove the last tag from an image, the image is deleted from your repository.

    + *

    You can completely delete an image (and all of its tags) by specifying the image's + * digest in your request.

    + */ +export class BatchDeleteImageCommand extends $Command< + BatchDeleteImageCommandInput, + BatchDeleteImageCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchDeleteImageCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "BatchDeleteImageCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchDeleteImageRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchDeleteImageResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchDeleteImageCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1BatchDeleteImageCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1BatchDeleteImageCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/CompleteLayerUploadCommand.ts b/clients/client-ecr-public/commands/CompleteLayerUploadCommand.ts new file mode 100644 index 000000000000..c30d89f4080c --- /dev/null +++ b/clients/client-ecr-public/commands/CompleteLayerUploadCommand.ts @@ -0,0 +1,95 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { CompleteLayerUploadRequest, CompleteLayerUploadResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CompleteLayerUploadCommand, + serializeAws_json1_1CompleteLayerUploadCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CompleteLayerUploadCommandInput = CompleteLayerUploadRequest; +export type CompleteLayerUploadCommandOutput = CompleteLayerUploadResponse & __MetadataBearer; + +/** + *

    Informs Amazon ECR that the image layer upload has completed for a specified public registry, + * repository name, and upload ID. You can optionally provide a sha256 digest of + * the image layer for data validation purposes.

    + *

    When an image is pushed, the CompleteLayerUpload API is called once per each new image + * layer to verify that the upload has completed.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ +export class CompleteLayerUploadCommand extends $Command< + CompleteLayerUploadCommandInput, + CompleteLayerUploadCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CompleteLayerUploadCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "CompleteLayerUploadCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CompleteLayerUploadRequest.filterSensitiveLog, + outputFilterSensitiveLog: CompleteLayerUploadResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CompleteLayerUploadCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CompleteLayerUploadCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CompleteLayerUploadCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/CreateRepositoryCommand.ts b/clients/client-ecr-public/commands/CreateRepositoryCommand.ts new file mode 100644 index 000000000000..2e570973eb73 --- /dev/null +++ b/clients/client-ecr-public/commands/CreateRepositoryCommand.ts @@ -0,0 +1,89 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { CreateRepositoryRequest, CreateRepositoryResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreateRepositoryCommand, + serializeAws_json1_1CreateRepositoryCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateRepositoryCommandInput = CreateRepositoryRequest; +export type CreateRepositoryCommandOutput = CreateRepositoryResponse & __MetadataBearer; + +/** + *

    Creates a repository in a public registry. For more information, see Amazon ECR + * repositories in the Amazon Elastic Container Registry User Guide.

    + */ +export class CreateRepositoryCommand extends $Command< + CreateRepositoryCommandInput, + CreateRepositoryCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateRepositoryCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "CreateRepositoryCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateRepositoryRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateRepositoryResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateRepositoryCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateRepositoryCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateRepositoryCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DeleteRepositoryCommand.ts b/clients/client-ecr-public/commands/DeleteRepositoryCommand.ts new file mode 100644 index 000000000000..b6a02766d289 --- /dev/null +++ b/clients/client-ecr-public/commands/DeleteRepositoryCommand.ts @@ -0,0 +1,90 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DeleteRepositoryRequest, DeleteRepositoryResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DeleteRepositoryCommand, + serializeAws_json1_1DeleteRepositoryCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteRepositoryCommandInput = DeleteRepositoryRequest; +export type DeleteRepositoryCommandOutput = DeleteRepositoryResponse & __MetadataBearer; + +/** + *

    Deletes a repository in a public registry. If the repository contains images, you must + * either delete all images in the repository or use the force option which + * deletes all images on your behalf before deleting the repository.

    + */ +export class DeleteRepositoryCommand extends $Command< + DeleteRepositoryCommandInput, + DeleteRepositoryCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteRepositoryCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DeleteRepositoryCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteRepositoryRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteRepositoryResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteRepositoryCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteRepositoryCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteRepositoryCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DeleteRepositoryPolicyCommand.ts b/clients/client-ecr-public/commands/DeleteRepositoryPolicyCommand.ts new file mode 100644 index 000000000000..a591e873654b --- /dev/null +++ b/clients/client-ecr-public/commands/DeleteRepositoryPolicyCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DeleteRepositoryPolicyRequest, DeleteRepositoryPolicyResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DeleteRepositoryPolicyCommand, + serializeAws_json1_1DeleteRepositoryPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteRepositoryPolicyCommandInput = DeleteRepositoryPolicyRequest; +export type DeleteRepositoryPolicyCommandOutput = DeleteRepositoryPolicyResponse & __MetadataBearer; + +/** + *

    Deletes the repository policy associated with the specified repository.

    + */ +export class DeleteRepositoryPolicyCommand extends $Command< + DeleteRepositoryPolicyCommandInput, + DeleteRepositoryPolicyCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteRepositoryPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DeleteRepositoryPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteRepositoryPolicyRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteRepositoryPolicyResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteRepositoryPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteRepositoryPolicyCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteRepositoryPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DescribeImageTagsCommand.ts b/clients/client-ecr-public/commands/DescribeImageTagsCommand.ts new file mode 100644 index 000000000000..135bfab6ea74 --- /dev/null +++ b/clients/client-ecr-public/commands/DescribeImageTagsCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DescribeImageTagsRequest, DescribeImageTagsResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DescribeImageTagsCommand, + serializeAws_json1_1DescribeImageTagsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeImageTagsCommandInput = DescribeImageTagsRequest; +export type DescribeImageTagsCommandOutput = DescribeImageTagsResponse & __MetadataBearer; + +/** + *

    Returns the image tag details for a repository in a public registry.

    + */ +export class DescribeImageTagsCommand extends $Command< + DescribeImageTagsCommandInput, + DescribeImageTagsCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeImageTagsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DescribeImageTagsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeImageTagsRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeImageTagsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeImageTagsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeImageTagsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeImageTagsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DescribeImagesCommand.ts b/clients/client-ecr-public/commands/DescribeImagesCommand.ts new file mode 100644 index 000000000000..3a90f4095139 --- /dev/null +++ b/clients/client-ecr-public/commands/DescribeImagesCommand.ts @@ -0,0 +1,94 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DescribeImagesRequest, DescribeImagesResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DescribeImagesCommand, + serializeAws_json1_1DescribeImagesCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeImagesCommandInput = DescribeImagesRequest; +export type DescribeImagesCommandOutput = DescribeImagesResponse & __MetadataBearer; + +/** + *

    Returns metadata about the images in a repository in a public registry.

    + * + *

    Beginning with Docker version 1.9, the Docker client compresses image layers before + * pushing them to a V2 Docker registry. The output of the docker images + * command shows the uncompressed image size, so it may return a larger image size than the + * image sizes returned by DescribeImages.

    + *
    + */ +export class DescribeImagesCommand extends $Command< + DescribeImagesCommandInput, + DescribeImagesCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeImagesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DescribeImagesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeImagesRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeImagesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeImagesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeImagesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeImagesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DescribeRegistriesCommand.ts b/clients/client-ecr-public/commands/DescribeRegistriesCommand.ts new file mode 100644 index 000000000000..0d664b07440a --- /dev/null +++ b/clients/client-ecr-public/commands/DescribeRegistriesCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DescribeRegistriesRequest, DescribeRegistriesResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DescribeRegistriesCommand, + serializeAws_json1_1DescribeRegistriesCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeRegistriesCommandInput = DescribeRegistriesRequest; +export type DescribeRegistriesCommandOutput = DescribeRegistriesResponse & __MetadataBearer; + +/** + *

    Returns details for a public registry.

    + */ +export class DescribeRegistriesCommand extends $Command< + DescribeRegistriesCommandInput, + DescribeRegistriesCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeRegistriesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DescribeRegistriesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeRegistriesRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeRegistriesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeRegistriesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeRegistriesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeRegistriesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/DescribeRepositoriesCommand.ts b/clients/client-ecr-public/commands/DescribeRepositoriesCommand.ts new file mode 100644 index 000000000000..2efbd6cdd1cf --- /dev/null +++ b/clients/client-ecr-public/commands/DescribeRepositoriesCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { DescribeRepositoriesRequest, DescribeRepositoriesResponse } from "../models/models_0"; +import { + deserializeAws_json1_1DescribeRepositoriesCommand, + serializeAws_json1_1DescribeRepositoriesCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeRepositoriesCommandInput = DescribeRepositoriesRequest; +export type DescribeRepositoriesCommandOutput = DescribeRepositoriesResponse & __MetadataBearer; + +/** + *

    Describes repositories in a public registry.

    + */ +export class DescribeRepositoriesCommand extends $Command< + DescribeRepositoriesCommandInput, + DescribeRepositoriesCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeRepositoriesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "DescribeRepositoriesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeRepositoriesRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeRepositoriesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeRepositoriesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeRepositoriesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeRepositoriesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/GetAuthorizationTokenCommand.ts b/clients/client-ecr-public/commands/GetAuthorizationTokenCommand.ts new file mode 100644 index 000000000000..45d2d42522b3 --- /dev/null +++ b/clients/client-ecr-public/commands/GetAuthorizationTokenCommand.ts @@ -0,0 +1,92 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { GetAuthorizationTokenRequest, GetAuthorizationTokenResponse } from "../models/models_0"; +import { + deserializeAws_json1_1GetAuthorizationTokenCommand, + serializeAws_json1_1GetAuthorizationTokenCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetAuthorizationTokenCommandInput = GetAuthorizationTokenRequest; +export type GetAuthorizationTokenCommandOutput = GetAuthorizationTokenResponse & __MetadataBearer; + +/** + *

    Retrieves an authorization token. An authorization token represents your IAM + * authentication credentials and can be used to access any Amazon ECR registry that your IAM + * principal has access to. The authorization token is valid for 12 hours. This API requires + * the ecr-public:GetAuthorizationToken and + * sts:GetServiceBearerToken permissions.

    + */ +export class GetAuthorizationTokenCommand extends $Command< + GetAuthorizationTokenCommandInput, + GetAuthorizationTokenCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetAuthorizationTokenCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "GetAuthorizationTokenCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetAuthorizationTokenRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetAuthorizationTokenResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetAuthorizationTokenCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1GetAuthorizationTokenCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1GetAuthorizationTokenCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/GetRegistryCatalogDataCommand.ts b/clients/client-ecr-public/commands/GetRegistryCatalogDataCommand.ts new file mode 100644 index 000000000000..755e0103e1b0 --- /dev/null +++ b/clients/client-ecr-public/commands/GetRegistryCatalogDataCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { GetRegistryCatalogDataRequest, GetRegistryCatalogDataResponse } from "../models/models_0"; +import { + deserializeAws_json1_1GetRegistryCatalogDataCommand, + serializeAws_json1_1GetRegistryCatalogDataCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetRegistryCatalogDataCommandInput = GetRegistryCatalogDataRequest; +export type GetRegistryCatalogDataCommandOutput = GetRegistryCatalogDataResponse & __MetadataBearer; + +/** + *

    Retrieves catalog metadata for a public registry.

    + */ +export class GetRegistryCatalogDataCommand extends $Command< + GetRegistryCatalogDataCommandInput, + GetRegistryCatalogDataCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetRegistryCatalogDataCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "GetRegistryCatalogDataCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetRegistryCatalogDataRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetRegistryCatalogDataResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetRegistryCatalogDataCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1GetRegistryCatalogDataCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1GetRegistryCatalogDataCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/GetRepositoryCatalogDataCommand.ts b/clients/client-ecr-public/commands/GetRepositoryCatalogDataCommand.ts new file mode 100644 index 000000000000..741c00eb2f8a --- /dev/null +++ b/clients/client-ecr-public/commands/GetRepositoryCatalogDataCommand.ts @@ -0,0 +1,89 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { GetRepositoryCatalogDataRequest, GetRepositoryCatalogDataResponse } from "../models/models_0"; +import { + deserializeAws_json1_1GetRepositoryCatalogDataCommand, + serializeAws_json1_1GetRepositoryCatalogDataCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetRepositoryCatalogDataCommandInput = GetRepositoryCatalogDataRequest; +export type GetRepositoryCatalogDataCommandOutput = GetRepositoryCatalogDataResponse & __MetadataBearer; + +/** + *

    Retrieve catalog metadata for a repository in a public registry. This metadata is + * displayed publicly in the Amazon ECR Public Gallery.

    + */ +export class GetRepositoryCatalogDataCommand extends $Command< + GetRepositoryCatalogDataCommandInput, + GetRepositoryCatalogDataCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetRepositoryCatalogDataCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "GetRepositoryCatalogDataCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetRepositoryCatalogDataRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetRepositoryCatalogDataResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetRepositoryCatalogDataCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1GetRepositoryCatalogDataCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1GetRepositoryCatalogDataCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/GetRepositoryPolicyCommand.ts b/clients/client-ecr-public/commands/GetRepositoryPolicyCommand.ts new file mode 100644 index 000000000000..83eb54090748 --- /dev/null +++ b/clients/client-ecr-public/commands/GetRepositoryPolicyCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { GetRepositoryPolicyRequest, GetRepositoryPolicyResponse } from "../models/models_0"; +import { + deserializeAws_json1_1GetRepositoryPolicyCommand, + serializeAws_json1_1GetRepositoryPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetRepositoryPolicyCommandInput = GetRepositoryPolicyRequest; +export type GetRepositoryPolicyCommandOutput = GetRepositoryPolicyResponse & __MetadataBearer; + +/** + *

    Retrieves the repository policy for the specified repository.

    + */ +export class GetRepositoryPolicyCommand extends $Command< + GetRepositoryPolicyCommandInput, + GetRepositoryPolicyCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetRepositoryPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "GetRepositoryPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetRepositoryPolicyRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetRepositoryPolicyResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetRepositoryPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1GetRepositoryPolicyCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1GetRepositoryPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/InitiateLayerUploadCommand.ts b/clients/client-ecr-public/commands/InitiateLayerUploadCommand.ts new file mode 100644 index 000000000000..75d0611f719e --- /dev/null +++ b/clients/client-ecr-public/commands/InitiateLayerUploadCommand.ts @@ -0,0 +1,94 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { InitiateLayerUploadRequest, InitiateLayerUploadResponse } from "../models/models_0"; +import { + deserializeAws_json1_1InitiateLayerUploadCommand, + serializeAws_json1_1InitiateLayerUploadCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type InitiateLayerUploadCommandInput = InitiateLayerUploadRequest; +export type InitiateLayerUploadCommandOutput = InitiateLayerUploadResponse & __MetadataBearer; + +/** + *

    Notifies Amazon ECR that you intend to upload an image layer.

    + *

    When an image is pushed, the InitiateLayerUpload API is called once per image layer that + * has not already been uploaded. Whether or not an image layer has been uploaded is + * determined by the BatchCheckLayerAvailability API action.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ +export class InitiateLayerUploadCommand extends $Command< + InitiateLayerUploadCommandInput, + InitiateLayerUploadCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: InitiateLayerUploadCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "InitiateLayerUploadCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: InitiateLayerUploadRequest.filterSensitiveLog, + outputFilterSensitiveLog: InitiateLayerUploadResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: InitiateLayerUploadCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1InitiateLayerUploadCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1InitiateLayerUploadCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/PutImageCommand.ts b/clients/client-ecr-public/commands/PutImageCommand.ts new file mode 100644 index 000000000000..a800ce030fe9 --- /dev/null +++ b/clients/client-ecr-public/commands/PutImageCommand.ts @@ -0,0 +1,92 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { PutImageRequest, PutImageResponse } from "../models/models_0"; +import { deserializeAws_json1_1PutImageCommand, serializeAws_json1_1PutImageCommand } from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutImageCommandInput = PutImageRequest; +export type PutImageCommandOutput = PutImageResponse & __MetadataBearer; + +/** + *

    Creates or updates the image manifest and tags associated with an image.

    + *

    When an image is pushed and all new image layers have been uploaded, the PutImage API is + * called once to create or update the image manifest and the tags associated with the + * image.

    + * + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ +export class PutImageCommand extends $Command< + PutImageCommandInput, + PutImageCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutImageCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "PutImageCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutImageRequest.filterSensitiveLog, + outputFilterSensitiveLog: PutImageResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutImageCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1PutImageCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1PutImageCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/PutRegistryCatalogDataCommand.ts b/clients/client-ecr-public/commands/PutRegistryCatalogDataCommand.ts new file mode 100644 index 000000000000..7f7aefe887d3 --- /dev/null +++ b/clients/client-ecr-public/commands/PutRegistryCatalogDataCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { PutRegistryCatalogDataRequest, PutRegistryCatalogDataResponse } from "../models/models_0"; +import { + deserializeAws_json1_1PutRegistryCatalogDataCommand, + serializeAws_json1_1PutRegistryCatalogDataCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutRegistryCatalogDataCommandInput = PutRegistryCatalogDataRequest; +export type PutRegistryCatalogDataCommandOutput = PutRegistryCatalogDataResponse & __MetadataBearer; + +/** + *

    Create or updates the catalog data for a public registry.

    + */ +export class PutRegistryCatalogDataCommand extends $Command< + PutRegistryCatalogDataCommandInput, + PutRegistryCatalogDataCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutRegistryCatalogDataCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "PutRegistryCatalogDataCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutRegistryCatalogDataRequest.filterSensitiveLog, + outputFilterSensitiveLog: PutRegistryCatalogDataResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutRegistryCatalogDataCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1PutRegistryCatalogDataCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1PutRegistryCatalogDataCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/PutRepositoryCatalogDataCommand.ts b/clients/client-ecr-public/commands/PutRepositoryCatalogDataCommand.ts new file mode 100644 index 000000000000..ea72854865d1 --- /dev/null +++ b/clients/client-ecr-public/commands/PutRepositoryCatalogDataCommand.ts @@ -0,0 +1,88 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { PutRepositoryCatalogDataRequest, PutRepositoryCatalogDataResponse } from "../models/models_0"; +import { + deserializeAws_json1_1PutRepositoryCatalogDataCommand, + serializeAws_json1_1PutRepositoryCatalogDataCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutRepositoryCatalogDataCommandInput = PutRepositoryCatalogDataRequest; +export type PutRepositoryCatalogDataCommandOutput = PutRepositoryCatalogDataResponse & __MetadataBearer; + +/** + *

    Creates or updates the catalog data for a repository in a public registry.

    + */ +export class PutRepositoryCatalogDataCommand extends $Command< + PutRepositoryCatalogDataCommandInput, + PutRepositoryCatalogDataCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutRepositoryCatalogDataCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "PutRepositoryCatalogDataCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutRepositoryCatalogDataRequest.filterSensitiveLog, + outputFilterSensitiveLog: PutRepositoryCatalogDataResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutRepositoryCatalogDataCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1PutRepositoryCatalogDataCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1PutRepositoryCatalogDataCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/SetRepositoryPolicyCommand.ts b/clients/client-ecr-public/commands/SetRepositoryPolicyCommand.ts new file mode 100644 index 000000000000..6aa54abebbb6 --- /dev/null +++ b/clients/client-ecr-public/commands/SetRepositoryPolicyCommand.ts @@ -0,0 +1,90 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { SetRepositoryPolicyRequest, SetRepositoryPolicyResponse } from "../models/models_0"; +import { + deserializeAws_json1_1SetRepositoryPolicyCommand, + serializeAws_json1_1SetRepositoryPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type SetRepositoryPolicyCommandInput = SetRepositoryPolicyRequest; +export type SetRepositoryPolicyCommandOutput = SetRepositoryPolicyResponse & __MetadataBearer; + +/** + *

    Applies a repository policy to the specified public repository to control access + * permissions. For more information, see Amazon ECR Repository + * Policies in the Amazon Elastic Container Registry User Guide.

    + */ +export class SetRepositoryPolicyCommand extends $Command< + SetRepositoryPolicyCommandInput, + SetRepositoryPolicyCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: SetRepositoryPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "SetRepositoryPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: SetRepositoryPolicyRequest.filterSensitiveLog, + outputFilterSensitiveLog: SetRepositoryPolicyResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: SetRepositoryPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1SetRepositoryPolicyCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1SetRepositoryPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/commands/UploadLayerPartCommand.ts b/clients/client-ecr-public/commands/UploadLayerPartCommand.ts new file mode 100644 index 000000000000..a22a2465ae0b --- /dev/null +++ b/clients/client-ecr-public/commands/UploadLayerPartCommand.ts @@ -0,0 +1,94 @@ +import { ECRPUBLICClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRPUBLICClient"; +import { UploadLayerPartRequest, UploadLayerPartResponse } from "../models/models_0"; +import { + deserializeAws_json1_1UploadLayerPartCommand, + serializeAws_json1_1UploadLayerPartCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UploadLayerPartCommandInput = UploadLayerPartRequest; +export type UploadLayerPartCommandOutput = UploadLayerPartResponse & __MetadataBearer; + +/** + *

    Uploads an image layer part to Amazon ECR.

    + *

    When an image is pushed, each new image layer is uploaded in parts. The maximum size of + * each image layer part can be 20971520 bytes (or about 20MB). The UploadLayerPart API is + * called once per each new image layer part.

    + * + *

    This operation is used by the Amazon ECR proxy and is not generally used by customers for pulling and pushing images. In most cases, you should use the docker CLI to pull, tag, and push images.

    + *
    + */ +export class UploadLayerPartCommand extends $Command< + UploadLayerPartCommandInput, + UploadLayerPartCommandOutput, + ECRPUBLICClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UploadLayerPartCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: ECRPUBLICClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "ECRPUBLICClient"; + const commandName = "UploadLayerPartCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UploadLayerPartRequest.filterSensitiveLog, + outputFilterSensitiveLog: UploadLayerPartResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UploadLayerPartCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UploadLayerPartCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UploadLayerPartCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-ecr-public/endpoints.ts b/clients/client-ecr-public/endpoints.ts new file mode 100644 index 000000000000..18f9703cb549 --- /dev/null +++ b/clients/client-ecr-public/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "ecr-public.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "ecr-public.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "ecr-public.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "ecr-public.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "ecr-public.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-ecr-public/index.ts b/clients/client-ecr-public/index.ts new file mode 100644 index 000000000000..69c688ebffe2 --- /dev/null +++ b/clients/client-ecr-public/index.ts @@ -0,0 +1,28 @@ +export * from "./ECRPUBLICClient"; +export * from "./ECRPUBLIC"; +export * from "./commands/BatchCheckLayerAvailabilityCommand"; +export * from "./commands/BatchDeleteImageCommand"; +export * from "./commands/CompleteLayerUploadCommand"; +export * from "./commands/CreateRepositoryCommand"; +export * from "./commands/DeleteRepositoryCommand"; +export * from "./commands/DeleteRepositoryPolicyCommand"; +export * from "./commands/DescribeImagesCommand"; +export * from "./pagination/DescribeImagesPaginator"; +export * from "./commands/DescribeImageTagsCommand"; +export * from "./pagination/DescribeImageTagsPaginator"; +export * from "./commands/DescribeRegistriesCommand"; +export * from "./pagination/DescribeRegistriesPaginator"; +export * from "./commands/DescribeRepositoriesCommand"; +export * from "./pagination/DescribeRepositoriesPaginator"; +export * from "./commands/GetAuthorizationTokenCommand"; +export * from "./commands/GetRegistryCatalogDataCommand"; +export * from "./commands/GetRepositoryCatalogDataCommand"; +export * from "./commands/GetRepositoryPolicyCommand"; +export * from "./commands/InitiateLayerUploadCommand"; +export * from "./commands/PutImageCommand"; +export * from "./commands/PutRegistryCatalogDataCommand"; +export * from "./commands/PutRepositoryCatalogDataCommand"; +export * from "./commands/SetRepositoryPolicyCommand"; +export * from "./commands/UploadLayerPartCommand"; +export * from "./pagination/Interfaces"; +export * from "./models/index"; diff --git a/clients/client-ecr-public/models/index.ts b/clients/client-ecr-public/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-ecr-public/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-ecr-public/models/models_0.ts b/clients/client-ecr-public/models/models_0.ts new file mode 100644 index 000000000000..166d5e80e850 --- /dev/null +++ b/clients/client-ecr-public/models/models_0.ts @@ -0,0 +1,1894 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +/** + *

    An authorization token data object that corresponds to a public registry.

    + */ +export interface AuthorizationData { + /** + *

    A base64-encoded string that contains authorization data for a public Amazon ECR registry. + * When the string is decoded, it is presented in the format user:password for + * public registry authentication using docker login.

    + */ + authorizationToken?: string; + + /** + *

    The Unix time in seconds and milliseconds when the authorization token expires. + * Authorization tokens are valid for 12 hours.

    + */ + expiresAt?: Date; +} + +export namespace AuthorizationData { + export const filterSensitiveLog = (obj: AuthorizationData): any => ({ + ...obj, + }); +} + +export interface BatchCheckLayerAvailabilityRequest { + /** + *

    The AWS account ID associated with the public registry that contains the image layers to + * check. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository that is associated with the image layers to check.

    + */ + repositoryName: string | undefined; + + /** + *

    The digests of the image layers to check.

    + */ + layerDigests: string[] | undefined; +} + +export namespace BatchCheckLayerAvailabilityRequest { + export const filterSensitiveLog = (obj: BatchCheckLayerAvailabilityRequest): any => ({ + ...obj, + }); +} + +export enum LayerFailureCode { + InvalidLayerDigest = "InvalidLayerDigest", + MissingLayerDigest = "MissingLayerDigest", +} + +/** + *

    An object representing an Amazon ECR image layer failure.

    + */ +export interface LayerFailure { + /** + *

    The layer digest associated with the failure.

    + */ + layerDigest?: string; + + /** + *

    The failure code associated with the failure.

    + */ + failureCode?: LayerFailureCode | string; + + /** + *

    The reason for the failure.

    + */ + failureReason?: string; +} + +export namespace LayerFailure { + export const filterSensitiveLog = (obj: LayerFailure): any => ({ + ...obj, + }); +} + +export enum LayerAvailability { + AVAILABLE = "AVAILABLE", + UNAVAILABLE = "UNAVAILABLE", +} + +/** + *

    An object representing an Amazon ECR image layer.

    + */ +export interface Layer { + /** + *

    The sha256 digest of the image layer.

    + */ + layerDigest?: string; + + /** + *

    The availability status of the image layer.

    + */ + layerAvailability?: LayerAvailability | string; + + /** + *

    The size, in bytes, of the image layer.

    + */ + layerSize?: number; + + /** + *

    The media type of the layer, such as + * application/vnd.docker.image.rootfs.diff.tar.gzip or + * application/vnd.oci.image.layer.v1.tar+gzip.

    + */ + mediaType?: string; +} + +export namespace Layer { + export const filterSensitiveLog = (obj: Layer): any => ({ + ...obj, + }); +} + +export interface BatchCheckLayerAvailabilityResponse { + /** + *

    A list of image layer objects corresponding to the image layer references in the + * request.

    + */ + layers?: Layer[]; + + /** + *

    Any failures associated with the call.

    + */ + failures?: LayerFailure[]; +} + +export namespace BatchCheckLayerAvailabilityResponse { + export const filterSensitiveLog = (obj: BatchCheckLayerAvailabilityResponse): any => ({ + ...obj, + }); +} + +/** + *

    The specified parameter is invalid. Review the available parameters for the API + * request.

    + */ +export interface InvalidParameterException extends __SmithyException, $MetadataBearer { + name: "InvalidParameterException"; + $fault: "client"; + message?: string; +} + +export namespace InvalidParameterException { + export const filterSensitiveLog = (obj: InvalidParameterException): any => ({ + ...obj, + }); +} + +/** + *

    The registry does not exist.

    + */ +export interface RegistryNotFoundException extends __SmithyException, $MetadataBearer { + name: "RegistryNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace RegistryNotFoundException { + export const filterSensitiveLog = (obj: RegistryNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

    The specified repository could not be found. Check the spelling of the specified + * repository and ensure that you are performing operations on the correct registry.

    + */ +export interface RepositoryNotFoundException extends __SmithyException, $MetadataBearer { + name: "RepositoryNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace RepositoryNotFoundException { + export const filterSensitiveLog = (obj: RepositoryNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

    These errors are usually caused by a server-side issue.

    + */ +export interface ServerException extends __SmithyException, $MetadataBearer { + name: "ServerException"; + $fault: "server"; + message?: string; +} + +export namespace ServerException { + export const filterSensitiveLog = (obj: ServerException): any => ({ + ...obj, + }); +} + +/** + *

    An object with identifying information for an Amazon ECR image.

    + */ +export interface ImageIdentifier { + /** + *

    The sha256 digest of the image manifest.

    + */ + imageDigest?: string; + + /** + *

    The tag used for the image.

    + */ + imageTag?: string; +} + +export namespace ImageIdentifier { + export const filterSensitiveLog = (obj: ImageIdentifier): any => ({ + ...obj, + }); +} + +export interface BatchDeleteImageRequest { + /** + *

    The AWS account ID associated with the registry that contains the image to delete. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The repository in a public registry that contains the image to delete.

    + */ + repositoryName: string | undefined; + + /** + *

    A list of image ID references that correspond to images to delete. The format of the + * imageIds reference is imageTag=tag or + * imageDigest=digest.

    + */ + imageIds: ImageIdentifier[] | undefined; +} + +export namespace BatchDeleteImageRequest { + export const filterSensitiveLog = (obj: BatchDeleteImageRequest): any => ({ + ...obj, + }); +} + +export enum ImageFailureCode { + ImageNotFound = "ImageNotFound", + ImageReferencedByManifestList = "ImageReferencedByManifestList", + ImageTagDoesNotMatchDigest = "ImageTagDoesNotMatchDigest", + InvalidImageDigest = "InvalidImageDigest", + InvalidImageTag = "InvalidImageTag", + KmsError = "KmsError", + MissingDigestAndTag = "MissingDigestAndTag", +} + +/** + *

    An object representing an Amazon ECR image failure.

    + */ +export interface ImageFailure { + /** + *

    The image ID associated with the failure.

    + */ + imageId?: ImageIdentifier; + + /** + *

    The code associated with the failure.

    + */ + failureCode?: ImageFailureCode | string; + + /** + *

    The reason for the failure.

    + */ + failureReason?: string; +} + +export namespace ImageFailure { + export const filterSensitiveLog = (obj: ImageFailure): any => ({ + ...obj, + }); +} + +export interface BatchDeleteImageResponse { + /** + *

    The image IDs of the deleted images.

    + */ + imageIds?: ImageIdentifier[]; + + /** + *

    Any failures associated with the call.

    + */ + failures?: ImageFailure[]; +} + +export namespace BatchDeleteImageResponse { + export const filterSensitiveLog = (obj: BatchDeleteImageResponse): any => ({ + ...obj, + }); +} + +export interface CompleteLayerUploadRequest { + /** + *

    The AWS account ID associated with the registry to which to upload layers. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository in a public registry to associate with the image + * layer.

    + */ + repositoryName: string | undefined; + + /** + *

    The upload ID from a previous InitiateLayerUpload operation to + * associate with the image layer.

    + */ + uploadId: string | undefined; + + /** + *

    The sha256 digest of the image layer.

    + */ + layerDigests: string[] | undefined; +} + +export namespace CompleteLayerUploadRequest { + export const filterSensitiveLog = (obj: CompleteLayerUploadRequest): any => ({ + ...obj, + }); +} + +export interface CompleteLayerUploadResponse { + /** + *

    The public registry ID associated with the request.

    + */ + registryId?: string; + + /** + *

    The repository name associated with the request.

    + */ + repositoryName?: string; + + /** + *

    The upload ID associated with the layer.

    + */ + uploadId?: string; + + /** + *

    The sha256 digest of the image layer.

    + */ + layerDigest?: string; +} + +export namespace CompleteLayerUploadResponse { + export const filterSensitiveLog = (obj: CompleteLayerUploadResponse): any => ({ + ...obj, + }); +} + +/** + *

    The specified layer upload does not contain any layer parts.

    + */ +export interface EmptyUploadException extends __SmithyException, $MetadataBearer { + name: "EmptyUploadException"; + $fault: "client"; + message?: string; +} + +export namespace EmptyUploadException { + export const filterSensitiveLog = (obj: EmptyUploadException): any => ({ + ...obj, + }); +} + +/** + *

    The layer digest calculation performed by Amazon ECR upon receipt of the image layer does not + * match the digest specified.

    + */ +export interface InvalidLayerException extends __SmithyException, $MetadataBearer { + name: "InvalidLayerException"; + $fault: "client"; + message?: string; +} + +export namespace InvalidLayerException { + export const filterSensitiveLog = (obj: InvalidLayerException): any => ({ + ...obj, + }); +} + +/** + *

    The image layer already exists in the associated repository.

    + */ +export interface LayerAlreadyExistsException extends __SmithyException, $MetadataBearer { + name: "LayerAlreadyExistsException"; + $fault: "client"; + message?: string; +} + +export namespace LayerAlreadyExistsException { + export const filterSensitiveLog = (obj: LayerAlreadyExistsException): any => ({ + ...obj, + }); +} + +/** + *

    Layer parts must be at least 5 MiB in size.

    + */ +export interface LayerPartTooSmallException extends __SmithyException, $MetadataBearer { + name: "LayerPartTooSmallException"; + $fault: "client"; + message?: string; +} + +export namespace LayerPartTooSmallException { + export const filterSensitiveLog = (obj: LayerPartTooSmallException): any => ({ + ...obj, + }); +} + +/** + *

    The action is not supported in this Region.

    + */ +export interface UnsupportedCommandException extends __SmithyException, $MetadataBearer { + name: "UnsupportedCommandException"; + $fault: "client"; + message?: string; +} + +export namespace UnsupportedCommandException { + export const filterSensitiveLog = (obj: UnsupportedCommandException): any => ({ + ...obj, + }); +} + +/** + *

    The upload could not be found, or the specified upload ID is not valid for this + * repository.

    + */ +export interface UploadNotFoundException extends __SmithyException, $MetadataBearer { + name: "UploadNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace UploadNotFoundException { + export const filterSensitiveLog = (obj: UploadNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

    An object containing the catalog data for a repository. This data is publicly visible in + * the Amazon ECR Public Gallery.

    + */ +export interface RepositoryCatalogDataInput { + /** + *

    A short description of the contents of the repository. This text appears in both the + * image details and also when searching for repositories on the Amazon ECR Public Gallery.

    + */ + description?: string; + + /** + *

    The system architecture that the images in the repository are compatible with. On the + * Amazon ECR Public Gallery, the following supported architectures will appear as badges on the + * repository and are used as search filters.

    + *
      + *
    • + *

      + * Linux + *

      + *
    • + *
    • + *

      + * Windows + *

      + *
    • + *
    + * + *

    If an unsupported tag is added to your repository catalog data, it will be associated + * with the repository and can be retrieved using the API but will not be discoverable in + * the Amazon ECR Public Gallery.

    + *
    + */ + architectures?: string[]; + + /** + *

    The operating systems that the images in the repository are compatible with. On the + * Amazon ECR Public Gallery, the following supported operating systems will appear as badges on + * the repository and are used as search filters.

    + *
      + *
    • + *

      + * ARM + *

      + *
    • + *
    • + *

      + * ARM 64 + *

      + *
    • + *
    • + *

      + * x86 + *

      + *
    • + *
    • + *

      + * x86-64 + *

      + *
    • + *
    + * + *

    If an unsupported tag is added to your repository catalog data, it will be associated + * with the repository and can be retrieved using the API but will not be discoverable in + * the Amazon ECR Public Gallery.

    + *
    + */ + operatingSystems?: string[]; + + /** + *

    The base64-encoded repository logo payload.

    + * + *

    The repository logo is only publicly visible in the Amazon ECR Public Gallery for verified + * accounts.

    + *
    + */ + logoImageBlob?: Uint8Array; + + /** + *

    A detailed description of the contents of the repository. It is publicly visible in the + * Amazon ECR Public Gallery. The text must be in markdown format.

    + */ + aboutText?: string; + + /** + *

    Detailed information on how to use the contents of the repository. It is publicly + * visible in the Amazon ECR Public Gallery. The usage text provides context, support information, + * and additional usage details for users of the repository. The text must be in markdown + * format.

    + */ + usageText?: string; +} + +export namespace RepositoryCatalogDataInput { + export const filterSensitiveLog = (obj: RepositoryCatalogDataInput): any => ({ + ...obj, + }); +} + +export interface CreateRepositoryRequest { + /** + *

    The name to use for the repository. This appears publicly in the Amazon ECR Public Gallery. + * The repository name may be specified on its own (such as nginx-web-app) or it + * can be prepended with a namespace to group the repository into a category (such as + * project-a/nginx-web-app).

    + */ + repositoryName: string | undefined; + + /** + *

    The details about the repository that are publicly visible in the + * Amazon ECR Public Gallery.

    + */ + catalogData?: RepositoryCatalogDataInput; +} + +export namespace CreateRepositoryRequest { + export const filterSensitiveLog = (obj: CreateRepositoryRequest): any => ({ + ...obj, + }); +} + +/** + *

    The catalog data for a repository. This data is publicly visible in the + * Amazon ECR Public Gallery.

    + */ +export interface RepositoryCatalogData { + /** + *

    The short description of the repository.

    + */ + description?: string; + + /** + *

    The architecture tags that are associated with the repository.

    + * + *

    Only supported operating system tags appear publicly in the Amazon ECR Public Gallery. For + * more information, see RepositoryCatalogDataInput.

    + *
    + */ + architectures?: string[]; + + /** + *

    The operating system tags that are associated with the repository.

    + * + *

    Only supported operating system tags appear publicly in the Amazon ECR Public Gallery. For + * more information, see RepositoryCatalogDataInput.

    + *
    + */ + operatingSystems?: string[]; + + /** + *

    The URL containing the logo associated with the repository.

    + */ + logoUrl?: string; + + /** + *

    The longform description of the contents of the repository. This text appears in the + * repository details on the Amazon ECR Public Gallery.

    + */ + aboutText?: string; + + /** + *

    The longform usage details of the contents of the repository. The usage text provides + * context for users of the repository.

    + */ + usageText?: string; + + /** + *

    Whether or not the repository is certified by AWS Marketplace.

    + */ + marketplaceCertified?: boolean; +} + +export namespace RepositoryCatalogData { + export const filterSensitiveLog = (obj: RepositoryCatalogData): any => ({ + ...obj, + }); +} + +/** + *

    An object representing a repository.

    + */ +export interface Repository { + /** + *

    The Amazon Resource Name (ARN) that identifies the repository. The ARN contains the arn:aws:ecr namespace, followed by the region of the repository, AWS account ID of the repository owner, repository namespace, and repository name. For example, arn:aws:ecr:region:012345678910:repository/test.

    + */ + repositoryArn?: string; + + /** + *

    The AWS account ID associated with the public registry that contains the + * repository.

    + */ + registryId?: string; + + /** + *

    The name of the repository.

    + */ + repositoryName?: string; + + /** + *

    The URI for the repository. You can use this URI for container image push + * and pull operations.

    + */ + repositoryUri?: string; + + /** + *

    The date and time, in JavaScript date format, when the repository was created.

    + */ + createdAt?: Date; +} + +export namespace Repository { + export const filterSensitiveLog = (obj: Repository): any => ({ + ...obj, + }); +} + +export interface CreateRepositoryResponse { + /** + *

    The repository that was created.

    + */ + repository?: Repository; + + /** + *

    The catalog data for a repository. This data is publicly visible in the + * Amazon ECR Public Gallery.

    + */ + catalogData?: RepositoryCatalogData; +} + +export namespace CreateRepositoryResponse { + export const filterSensitiveLog = (obj: CreateRepositoryResponse): any => ({ + ...obj, + }); +} + +/** + *

    The operation did not succeed because it would have exceeded a service limit for your + * account. For more information, see Amazon ECR Service Quotas in the + * Amazon Elastic Container Registry User Guide.

    + */ +export interface LimitExceededException extends __SmithyException, $MetadataBearer { + name: "LimitExceededException"; + $fault: "client"; + message?: string; +} + +export namespace LimitExceededException { + export const filterSensitiveLog = (obj: LimitExceededException): any => ({ + ...obj, + }); +} + +/** + *

    The specified repository already exists in the specified registry.

    + */ +export interface RepositoryAlreadyExistsException extends __SmithyException, $MetadataBearer { + name: "RepositoryAlreadyExistsException"; + $fault: "client"; + message?: string; +} + +export namespace RepositoryAlreadyExistsException { + export const filterSensitiveLog = (obj: RepositoryAlreadyExistsException): any => ({ + ...obj, + }); +} + +export interface DeleteRepositoryRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository to + * delete. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to delete.

    + */ + repositoryName: string | undefined; + + /** + *

    If a repository contains images, forces the deletion.

    + */ + force?: boolean; +} + +export namespace DeleteRepositoryRequest { + export const filterSensitiveLog = (obj: DeleteRepositoryRequest): any => ({ + ...obj, + }); +} + +export interface DeleteRepositoryResponse { + /** + *

    The repository that was deleted.

    + */ + repository?: Repository; +} + +export namespace DeleteRepositoryResponse { + export const filterSensitiveLog = (obj: DeleteRepositoryResponse): any => ({ + ...obj, + }); +} + +/** + *

    The specified repository contains images. To delete a repository that contains images, + * you must force the deletion with the force parameter.

    + */ +export interface RepositoryNotEmptyException extends __SmithyException, $MetadataBearer { + name: "RepositoryNotEmptyException"; + $fault: "client"; + message?: string; +} + +export namespace RepositoryNotEmptyException { + export const filterSensitiveLog = (obj: RepositoryNotEmptyException): any => ({ + ...obj, + }); +} + +export interface DeleteRepositoryPolicyRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository + * policy to delete. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository that is associated with the repository policy to + * delete.

    + */ + repositoryName: string | undefined; +} + +export namespace DeleteRepositoryPolicyRequest { + export const filterSensitiveLog = (obj: DeleteRepositoryPolicyRequest): any => ({ + ...obj, + }); +} + +export interface DeleteRepositoryPolicyResponse { + /** + *

    The registry ID associated with the request.

    + */ + registryId?: string; + + /** + *

    The repository name associated with the request.

    + */ + repositoryName?: string; + + /** + *

    The JSON repository policy that was deleted from the repository.

    + */ + policyText?: string; +} + +export namespace DeleteRepositoryPolicyResponse { + export const filterSensitiveLog = (obj: DeleteRepositoryPolicyResponse): any => ({ + ...obj, + }); +} + +/** + *

    The specified repository and registry combination does not have an associated repository + * policy.

    + */ +export interface RepositoryPolicyNotFoundException extends __SmithyException, $MetadataBearer { + name: "RepositoryPolicyNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace RepositoryPolicyNotFoundException { + export const filterSensitiveLog = (obj: RepositoryPolicyNotFoundException): any => ({ + ...obj, + }); +} + +export interface DescribeImagesRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository in + * which to describe images. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The repository that contains the images to describe.

    + */ + repositoryName: string | undefined; + + /** + *

    The list of image IDs for the requested repository.

    + */ + imageIds?: ImageIdentifier[]; + + /** + *

    The nextToken value returned from a previous paginated + * DescribeImages request where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value. This value is + * null when there are no more results to return. This option cannot be used + * when you specify images with imageIds.

    + */ + nextToken?: string; + + /** + *

    The maximum number of repository results returned by DescribeImages in + * paginated output. When this parameter is used, DescribeImages only returns + * maxResults results in a single page along with a nextToken + * response element. The remaining results of the initial request can be seen by sending + * another DescribeImages request with the returned nextToken value. + * This value can be between 1 and 1000. If this parameter is not + * used, then DescribeImages returns up to 100 results and a + * nextToken value, if applicable. This option cannot be used when you specify + * images with imageIds.

    + */ + maxResults?: number; +} + +export namespace DescribeImagesRequest { + export const filterSensitiveLog = (obj: DescribeImagesRequest): any => ({ + ...obj, + }); +} + +/** + *

    An object that describes an image returned by a DescribeImages + * operation.

    + */ +export interface ImageDetail { + /** + *

    The AWS account ID associated with the public registry to which this image + * belongs.

    + */ + registryId?: string; + + /** + *

    The name of the repository to which this image belongs.

    + */ + repositoryName?: string; + + /** + *

    The sha256 digest of the image manifest.

    + */ + imageDigest?: string; + + /** + *

    The list of tags associated with this image.

    + */ + imageTags?: string[]; + + /** + *

    The size, in bytes, of the image in the repository.

    + *

    If the image is a manifest list, this will be the max size of all manifests in the + * list.

    + * + *

    Beginning with Docker version 1.9, the Docker client compresses image layers before + * pushing them to a V2 Docker registry. The output of the docker images + * command shows the uncompressed image size, so it may return a larger image size than the + * image sizes returned by DescribeImages.

    + *
    + */ + imageSizeInBytes?: number; + + /** + *

    The date and time, expressed in standard JavaScript date format, at which the current + * image was pushed to the repository.

    + */ + imagePushedAt?: Date; + + /** + *

    The media type of the image manifest.

    + */ + imageManifestMediaType?: string; + + /** + *

    The artifact media type of the image.

    + */ + artifactMediaType?: string; +} + +export namespace ImageDetail { + export const filterSensitiveLog = (obj: ImageDetail): any => ({ + ...obj, + }); +} + +export interface DescribeImagesResponse { + /** + *

    A list of ImageDetail objects that contain data about the + * image.

    + */ + imageDetails?: ImageDetail[]; + + /** + *

    The nextToken value to include in a future DescribeImages + * request. When the results of a DescribeImages request exceed + * maxResults, this value can be used to retrieve the next page of results. + * This value is null when there are no more results to return.

    + */ + nextToken?: string; +} + +export namespace DescribeImagesResponse { + export const filterSensitiveLog = (obj: DescribeImagesResponse): any => ({ + ...obj, + }); +} + +/** + *

    The image requested does not exist in the specified repository.

    + */ +export interface ImageNotFoundException extends __SmithyException, $MetadataBearer { + name: "ImageNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace ImageNotFoundException { + export const filterSensitiveLog = (obj: ImageNotFoundException): any => ({ + ...obj, + }); +} + +export interface DescribeImageTagsRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository in + * which to describe images. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository that contains the image tag details to describe.

    + */ + repositoryName: string | undefined; + + /** + *

    The nextToken value returned from a previous paginated + * DescribeImageTags request where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value. This value is + * null when there are no more results to return. This option cannot be used + * when you specify images with imageIds.

    + */ + nextToken?: string; + + /** + *

    The maximum number of repository results returned by DescribeImageTags in + * paginated output. When this parameter is used, DescribeImageTags only returns + * maxResults results in a single page along with a nextToken + * response element. The remaining results of the initial request can be seen by sending + * another DescribeImageTags request with the returned nextToken + * value. This value can be between 1 and 1000. If this parameter + * is not used, then DescribeImageTags returns up to 100 + * results and a nextToken value, if applicable. This option cannot be used when + * you specify images with imageIds.

    + */ + maxResults?: number; +} + +export namespace DescribeImageTagsRequest { + export const filterSensitiveLog = (obj: DescribeImageTagsRequest): any => ({ + ...obj, + }); +} + +/** + *

    An object that describes the image tag details returned by a DescribeImageTags action.

    + */ +export interface ReferencedImageDetail { + /** + *

    The sha256 digest of the image manifest.

    + */ + imageDigest?: string; + + /** + *

    The size, in bytes, of the image in the repository.

    + *

    If the image is a manifest list, this will be the max size of all manifests in the + * list.

    + * + *

    Beginning with Docker version 1.9, the Docker client compresses image layers before + * pushing them to a V2 Docker registry. The output of the docker images + * command shows the uncompressed image size, so it may return a larger image size than the + * image sizes returned by DescribeImages.

    + *
    + */ + imageSizeInBytes?: number; + + /** + *

    The date and time, expressed in standard JavaScript date format, at which the current + * image tag was pushed to the repository.

    + */ + imagePushedAt?: Date; + + /** + *

    The media type of the image manifest.

    + */ + imageManifestMediaType?: string; + + /** + *

    The artifact media type of the image.

    + */ + artifactMediaType?: string; +} + +export namespace ReferencedImageDetail { + export const filterSensitiveLog = (obj: ReferencedImageDetail): any => ({ + ...obj, + }); +} + +/** + *

    An object representing the image tag details for an image.

    + */ +export interface ImageTagDetail { + /** + *

    The tag associated with the image.

    + */ + imageTag?: string; + + /** + *

    The time stamp indicating when the image tag was created.

    + */ + createdAt?: Date; + + /** + *

    An object that describes the details of an image.

    + */ + imageDetail?: ReferencedImageDetail; +} + +export namespace ImageTagDetail { + export const filterSensitiveLog = (obj: ImageTagDetail): any => ({ + ...obj, + }); +} + +export interface DescribeImageTagsResponse { + /** + *

    The image tag details for the images in the requested repository.

    + */ + imageTagDetails?: ImageTagDetail[]; + + /** + *

    The nextToken value to include in a future DescribeImageTags + * request. When the results of a DescribeImageTags request exceed + * maxResults, this value can be used to retrieve the next page of results. + * This value is null when there are no more results to return.

    + */ + nextToken?: string; +} + +export namespace DescribeImageTagsResponse { + export const filterSensitiveLog = (obj: DescribeImageTagsResponse): any => ({ + ...obj, + }); +} + +export interface DescribeRegistriesRequest { + /** + *

    The nextToken value returned from a previous paginated + * DescribeRegistries request where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value. This value is + * null when there are no more results to return.

    + * + *

    This token should be treated as an opaque identifier that is only used to retrieve the next items in a list and not for other programmatic purposes.

    + *
    + */ + nextToken?: string; + + /** + *

    The maximum number of repository results returned by DescribeRegistries in + * paginated output. When this parameter is used, DescribeRegistries only returns + * maxResults results in a single page along with a nextToken + * response element. The remaining results of the initial request can be seen by sending + * another DescribeRegistries request with the returned nextToken + * value. This value can be between 1 and 1000. If this parameter + * is not used, then DescribeRegistries returns up to 100 + * results and a nextToken value, if applicable.

    + */ + maxResults?: number; +} + +export namespace DescribeRegistriesRequest { + export const filterSensitiveLog = (obj: DescribeRegistriesRequest): any => ({ + ...obj, + }); +} + +export enum RegistryAliasStatus { + ACTIVE = "ACTIVE", + PENDING = "PENDING", + REJECTED = "REJECTED", +} + +/** + *

    An object representing the aliases for a public registry. A public registry is given an + * alias upon creation but a custom alias can be set using the Amazon ECR console. For more + * information, see Registries in the + * Amazon Elastic Container Registry User Guide.

    + */ +export interface RegistryAlias { + /** + *

    The name of the registry alias.

    + */ + name: string | undefined; + + /** + *

    The status of the registry alias.

    + */ + status: RegistryAliasStatus | string | undefined; + + /** + *

    Whether or not the registry alias is the primary alias for the registry. If true, the + * alias is the primary registry alias and is displayed in both the repository URL and the + * image URI used in the docker pull commands on the Amazon ECR Public Gallery.

    + * + *

    A registry alias that is not the primary registry alias can be used in the repository + * URI in a docker pull command.

    + *
    + */ + primaryRegistryAlias: boolean | undefined; + + /** + *

    Whether or not the registry alias is the default alias for the registry. When the first + * public repository is created, your public registry is assigned a default registry + * alias.

    + */ + defaultRegistryAlias: boolean | undefined; +} + +export namespace RegistryAlias { + export const filterSensitiveLog = (obj: RegistryAlias): any => ({ + ...obj, + }); +} + +/** + *

    The details of a public registry.

    + */ +export interface Registry { + /** + *

    The AWS account ID associated with the registry. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId: string | undefined; + + /** + *

    The Amazon Resource Name (ARN) of the public registry.

    + */ + registryArn: string | undefined; + + /** + *

    The URI of a public registry. The URI contains a universal prefix and the registry + * alias.

    + */ + registryUri: string | undefined; + + /** + *

    Whether the account is verified. This indicates whether the account is an AWS + * Marketplace vendor. If an account is verified, each public repository will received a + * verified account badge on the Amazon ECR Public Gallery.

    + */ + verified: boolean | undefined; + + /** + *

    An array of objects representing the aliases for a public registry.

    + */ + aliases: RegistryAlias[] | undefined; +} + +export namespace Registry { + export const filterSensitiveLog = (obj: Registry): any => ({ + ...obj, + }); +} + +export interface DescribeRegistriesResponse { + /** + *

    An object containing the details for a public registry.

    + */ + registries: Registry[] | undefined; + + /** + *

    The nextToken value to include in a future + * DescribeRepositories request. When the results of a + * DescribeRepositories request exceed maxResults, this value can + * be used to retrieve the next page of results. This value is null when there + * are no more results to return.

    + */ + nextToken?: string; +} + +export namespace DescribeRegistriesResponse { + export const filterSensitiveLog = (obj: DescribeRegistriesResponse): any => ({ + ...obj, + }); +} + +export interface DescribeRepositoriesRequest { + /** + *

    The AWS account ID associated with the registry that contains the repositories to be + * described. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    A list of repositories to describe. If this parameter is omitted, then all repositories + * in a registry are described.

    + */ + repositoryNames?: string[]; + + /** + *

    The nextToken value returned from a previous paginated + * DescribeRepositories request where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value. This value is + * null when there are no more results to return. This option cannot be used + * when you specify repositories with repositoryNames.

    + * + *

    This token should be treated as an opaque identifier that is only used to retrieve the next items in a list and not for other programmatic purposes.

    + *
    + */ + nextToken?: string; + + /** + *

    The maximum number of repository results returned by DescribeRepositories + * in paginated output. When this parameter is used, DescribeRepositories only + * returns maxResults results in a single page along with a + * nextToken response element. The remaining results of the initial request + * can be seen by sending another DescribeRepositories request with the returned + * nextToken value. This value can be between 1 and + * 1000. If this parameter is not used, then DescribeRepositories + * returns up to 100 results and a nextToken value, if + * applicable. This option cannot be used when you specify repositories with + * repositoryNames.

    + */ + maxResults?: number; +} + +export namespace DescribeRepositoriesRequest { + export const filterSensitiveLog = (obj: DescribeRepositoriesRequest): any => ({ + ...obj, + }); +} + +export interface DescribeRepositoriesResponse { + /** + *

    A list of repository objects corresponding to valid repositories.

    + */ + repositories?: Repository[]; + + /** + *

    The nextToken value to include in a future + * DescribeRepositories request. When the results of a + * DescribeRepositories request exceed maxResults, this value can + * be used to retrieve the next page of results. This value is null when there + * are no more results to return.

    + */ + nextToken?: string; +} + +export namespace DescribeRepositoriesResponse { + export const filterSensitiveLog = (obj: DescribeRepositoriesResponse): any => ({ + ...obj, + }); +} + +export interface GetAuthorizationTokenRequest {} + +export namespace GetAuthorizationTokenRequest { + export const filterSensitiveLog = (obj: GetAuthorizationTokenRequest): any => ({ + ...obj, + }); +} + +export interface GetAuthorizationTokenResponse { + /** + *

    An authorization token data object that corresponds to a public registry.

    + */ + authorizationData?: AuthorizationData; +} + +export namespace GetAuthorizationTokenResponse { + export const filterSensitiveLog = (obj: GetAuthorizationTokenResponse): any => ({ + ...obj, + }); +} + +export interface GetRegistryCatalogDataRequest {} + +export namespace GetRegistryCatalogDataRequest { + export const filterSensitiveLog = (obj: GetRegistryCatalogDataRequest): any => ({ + ...obj, + }); +} + +/** + *

    The metadata for a public registry.

    + */ +export interface RegistryCatalogData { + /** + *

    The display name for a public registry. This appears on the Amazon ECR Public Gallery.

    + * + *

    Only accounts that have the verified account badge can have a registry display + * name.

    + *
    + */ + displayName?: string; +} + +export namespace RegistryCatalogData { + export const filterSensitiveLog = (obj: RegistryCatalogData): any => ({ + ...obj, + }); +} + +export interface GetRegistryCatalogDataResponse { + /** + *

    The catalog metadata for the public registry.

    + */ + registryCatalogData: RegistryCatalogData | undefined; +} + +export namespace GetRegistryCatalogDataResponse { + export const filterSensitiveLog = (obj: GetRegistryCatalogDataResponse): any => ({ + ...obj, + }); +} + +export interface GetRepositoryCatalogDataRequest { + /** + *

    The AWS account ID associated with the registry that contains the repositories to be + * described. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to retrieve the catalog metadata for.

    + */ + repositoryName: string | undefined; +} + +export namespace GetRepositoryCatalogDataRequest { + export const filterSensitiveLog = (obj: GetRepositoryCatalogDataRequest): any => ({ + ...obj, + }); +} + +export interface GetRepositoryCatalogDataResponse { + /** + *

    The catalog metadata for the repository.

    + */ + catalogData?: RepositoryCatalogData; +} + +export namespace GetRepositoryCatalogDataResponse { + export const filterSensitiveLog = (obj: GetRepositoryCatalogDataResponse): any => ({ + ...obj, + }); +} + +export interface GetRepositoryPolicyRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository with the policy to retrieve.

    + */ + repositoryName: string | undefined; +} + +export namespace GetRepositoryPolicyRequest { + export const filterSensitiveLog = (obj: GetRepositoryPolicyRequest): any => ({ + ...obj, + }); +} + +export interface GetRepositoryPolicyResponse { + /** + *

    The registry ID associated with the request.

    + */ + registryId?: string; + + /** + *

    The repository name associated with the request.

    + */ + repositoryName?: string; + + /** + *

    The repository policy text associated with the repository. The policy text will be in + * JSON format.

    + */ + policyText?: string; +} + +export namespace GetRepositoryPolicyResponse { + export const filterSensitiveLog = (obj: GetRepositoryPolicyResponse): any => ({ + ...obj, + }); +} + +/** + *

    An object representing an Amazon ECR image.

    + */ +export interface Image { + /** + *

    The AWS account ID associated with the registry containing the image.

    + */ + registryId?: string; + + /** + *

    The name of the repository associated with the image.

    + */ + repositoryName?: string; + + /** + *

    An object containing the image tag and image digest associated with an image.

    + */ + imageId?: ImageIdentifier; + + /** + *

    The image manifest associated with the image.

    + */ + imageManifest?: string; + + /** + *

    The manifest media type of the image.

    + */ + imageManifestMediaType?: string; +} + +export namespace Image { + export const filterSensitiveLog = (obj: Image): any => ({ + ...obj, + }); +} + +/** + *

    The specified image has already been pushed, and there were no changes to the manifest + * or image tag after the last push.

    + */ +export interface ImageAlreadyExistsException extends __SmithyException, $MetadataBearer { + name: "ImageAlreadyExistsException"; + $fault: "client"; + message?: string; +} + +export namespace ImageAlreadyExistsException { + export const filterSensitiveLog = (obj: ImageAlreadyExistsException): any => ({ + ...obj, + }); +} + +/** + *

    The specified image digest does not match the digest that Amazon ECR calculated for the + * image.

    + */ +export interface ImageDigestDoesNotMatchException extends __SmithyException, $MetadataBearer { + name: "ImageDigestDoesNotMatchException"; + $fault: "client"; + message?: string; +} + +export namespace ImageDigestDoesNotMatchException { + export const filterSensitiveLog = (obj: ImageDigestDoesNotMatchException): any => ({ + ...obj, + }); +} + +/** + *

    The specified image is tagged with a tag that already exists. The repository is + * configured for tag immutability.

    + */ +export interface ImageTagAlreadyExistsException extends __SmithyException, $MetadataBearer { + name: "ImageTagAlreadyExistsException"; + $fault: "client"; + message?: string; +} + +export namespace ImageTagAlreadyExistsException { + export const filterSensitiveLog = (obj: ImageTagAlreadyExistsException): any => ({ + ...obj, + }); +} + +export interface InitiateLayerUploadRequest { + /** + *

    The AWS account ID associated with the registry to which you intend to upload layers. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to which you intend to upload layers.

    + */ + repositoryName: string | undefined; +} + +export namespace InitiateLayerUploadRequest { + export const filterSensitiveLog = (obj: InitiateLayerUploadRequest): any => ({ + ...obj, + }); +} + +export interface InitiateLayerUploadResponse { + /** + *

    The upload ID for the layer upload. This parameter is passed to further UploadLayerPart and CompleteLayerUpload operations.

    + */ + uploadId?: string; + + /** + *

    The size, in bytes, that Amazon ECR expects future layer part uploads to be.

    + */ + partSize?: number; +} + +export namespace InitiateLayerUploadResponse { + export const filterSensitiveLog = (obj: InitiateLayerUploadResponse): any => ({ + ...obj, + }); +} + +/** + *

    The layer part size is not valid, or the first byte specified is not consecutive to the + * last byte of a previous layer part upload.

    + */ +export interface InvalidLayerPartException extends __SmithyException, $MetadataBearer { + name: "InvalidLayerPartException"; + $fault: "client"; + /** + *

    The AWS account ID associated with the layer part.

    + */ + registryId?: string; + + /** + *

    The name of the repository.

    + */ + repositoryName?: string; + + /** + *

    The upload ID associated with the layer part.

    + */ + uploadId?: string; + + /** + *

    The position of the last byte of the layer part.

    + */ + lastValidByteReceived?: number; + + message?: string; +} + +export namespace InvalidLayerPartException { + export const filterSensitiveLog = (obj: InvalidLayerPartException): any => ({ + ...obj, + }); +} + +/** + *

    The specified layers could not be found, or the specified layer is not valid for this + * repository.

    + */ +export interface LayersNotFoundException extends __SmithyException, $MetadataBearer { + name: "LayersNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace LayersNotFoundException { + export const filterSensitiveLog = (obj: LayersNotFoundException): any => ({ + ...obj, + }); +} + +export interface PutImageRequest { + /** + *

    The AWS account ID associated with the public registry that contains the repository in + * which to put the image. If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository in which to put the image.

    + */ + repositoryName: string | undefined; + + /** + *

    The image manifest corresponding to the image to be uploaded.

    + */ + imageManifest: string | undefined; + + /** + *

    The media type of the image manifest. If you push an image manifest that does not + * contain the mediaType field, you must specify the + * imageManifestMediaType in the request.

    + */ + imageManifestMediaType?: string; + + /** + *

    The tag to associate with the image. This parameter is required for images that use the + * Docker Image Manifest V2 Schema 2 or Open Container Initiative (OCI) formats.

    + */ + imageTag?: string; + + /** + *

    The image digest of the image manifest corresponding to the image.

    + */ + imageDigest?: string; +} + +export namespace PutImageRequest { + export const filterSensitiveLog = (obj: PutImageRequest): any => ({ + ...obj, + }); +} + +export interface PutImageResponse { + /** + *

    Details of the image uploaded.

    + */ + image?: Image; +} + +export namespace PutImageResponse { + export const filterSensitiveLog = (obj: PutImageResponse): any => ({ + ...obj, + }); +} + +/** + *

    The manifest list is referencing an image that does not exist.

    + */ +export interface ReferencedImagesNotFoundException extends __SmithyException, $MetadataBearer { + name: "ReferencedImagesNotFoundException"; + $fault: "client"; + message?: string; +} + +export namespace ReferencedImagesNotFoundException { + export const filterSensitiveLog = (obj: ReferencedImagesNotFoundException): any => ({ + ...obj, + }); +} + +export interface PutRegistryCatalogDataRequest { + /** + *

    The display name for a public registry. The display name is shown as the repository + * author in the Amazon ECR Public Gallery.

    + * + *

    The registry display name is only publicly visible in the Amazon ECR Public Gallery for + * verified accounts.

    + *
    + */ + displayName?: string; +} + +export namespace PutRegistryCatalogDataRequest { + export const filterSensitiveLog = (obj: PutRegistryCatalogDataRequest): any => ({ + ...obj, + }); +} + +export interface PutRegistryCatalogDataResponse { + /** + *

    The catalog data for the public registry.

    + */ + registryCatalogData: RegistryCatalogData | undefined; +} + +export namespace PutRegistryCatalogDataResponse { + export const filterSensitiveLog = (obj: PutRegistryCatalogDataResponse): any => ({ + ...obj, + }); +} + +export interface PutRepositoryCatalogDataRequest { + /** + *

    The AWS account ID associated with the public registry the repository is in. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to create or update the catalog data for.

    + */ + repositoryName: string | undefined; + + /** + *

    An object containing the catalog data for a repository. This data is publicly visible in + * the Amazon ECR Public Gallery.

    + */ + catalogData: RepositoryCatalogDataInput | undefined; +} + +export namespace PutRepositoryCatalogDataRequest { + export const filterSensitiveLog = (obj: PutRepositoryCatalogDataRequest): any => ({ + ...obj, + }); +} + +export interface PutRepositoryCatalogDataResponse { + /** + *

    The catalog data for the repository.

    + */ + catalogData?: RepositoryCatalogData; +} + +export namespace PutRepositoryCatalogDataResponse { + export const filterSensitiveLog = (obj: PutRepositoryCatalogDataResponse): any => ({ + ...obj, + }); +} + +export interface SetRepositoryPolicyRequest { + /** + *

    The AWS account ID associated with the registry that contains the repository. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to receive the policy.

    + */ + repositoryName: string | undefined; + + /** + *

    The JSON repository policy text to apply to the repository. For more information, see + * Amazon ECR Repository + * Policies in the Amazon Elastic Container Registry User Guide.

    + */ + policyText: string | undefined; + + /** + *

    If the policy you are attempting to set on a repository policy would prevent you from + * setting another policy in the future, you must force the SetRepositoryPolicy operation. This is intended to prevent accidental + * repository lock outs.

    + */ + force?: boolean; +} + +export namespace SetRepositoryPolicyRequest { + export const filterSensitiveLog = (obj: SetRepositoryPolicyRequest): any => ({ + ...obj, + }); +} + +export interface SetRepositoryPolicyResponse { + /** + *

    The registry ID associated with the request.

    + */ + registryId?: string; + + /** + *

    The repository name associated with the request.

    + */ + repositoryName?: string; + + /** + *

    The JSON repository policy text applied to the repository.

    + */ + policyText?: string; +} + +export namespace SetRepositoryPolicyResponse { + export const filterSensitiveLog = (obj: SetRepositoryPolicyResponse): any => ({ + ...obj, + }); +} + +export interface UploadLayerPartRequest { + /** + *

    The AWS account ID associated with the registry to which you are uploading layer parts. + * If you do not specify a registry, the default public registry is assumed.

    + */ + registryId?: string; + + /** + *

    The name of the repository to which you are uploading layer parts.

    + */ + repositoryName: string | undefined; + + /** + *

    The upload ID from a previous InitiateLayerUpload operation to + * associate with the layer part upload.

    + */ + uploadId: string | undefined; + + /** + *

    The position of the first byte of the layer part witin the overall image layer.

    + */ + partFirstByte: number | undefined; + + /** + *

    The position of the last byte of the layer part within the overall image layer.

    + */ + partLastByte: number | undefined; + + /** + *

    The base64-encoded layer part payload.

    + */ + layerPartBlob: Uint8Array | undefined; +} + +export namespace UploadLayerPartRequest { + export const filterSensitiveLog = (obj: UploadLayerPartRequest): any => ({ + ...obj, + }); +} + +export interface UploadLayerPartResponse { + /** + *

    The registry ID associated with the request.

    + */ + registryId?: string; + + /** + *

    The repository name associated with the request.

    + */ + repositoryName?: string; + + /** + *

    The upload ID associated with the request.

    + */ + uploadId?: string; + + /** + *

    The integer value of the last byte received in the request.

    + */ + lastByteReceived?: number; +} + +export namespace UploadLayerPartResponse { + export const filterSensitiveLog = (obj: UploadLayerPartResponse): any => ({ + ...obj, + }); +} diff --git a/clients/client-ecr-public/package.json b/clients/client-ecr-public/package.json new file mode 100644 index 000000000000..cff3ba16dfb7 --- /dev/null +++ b/clients/client-ecr-public/package.json @@ -0,0 +1,83 @@ +{ + "name": "@aws-sdk/client-ecr-public", + "description": "AWS SDK for JavaScript Ecr Public Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-ecr-public", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-ecr-public" + } +} diff --git a/clients/client-ecr-public/pagination/DescribeImageTagsPaginator.ts b/clients/client-ecr-public/pagination/DescribeImageTagsPaginator.ts new file mode 100644 index 000000000000..93ee7a0ccfd3 --- /dev/null +++ b/clients/client-ecr-public/pagination/DescribeImageTagsPaginator.ts @@ -0,0 +1,57 @@ +import { ECRPUBLIC } from "../ECRPUBLIC"; +import { ECRPUBLICClient } from "../ECRPUBLICClient"; +import { + DescribeImageTagsCommand, + DescribeImageTagsCommandInput, + DescribeImageTagsCommandOutput, +} from "../commands/DescribeImageTagsCommand"; +import { ECRPUBLICPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ECRPUBLICClient, + input: DescribeImageTagsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeImageTagsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: ECRPUBLIC, + input: DescribeImageTagsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeImageTags(input, ...args); +}; +export async function* paginateDescribeImageTags( + config: ECRPUBLICPaginationConfiguration, + input: DescribeImageTagsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeImageTagsCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof ECRPUBLIC) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ECRPUBLICClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected ECRPUBLIC | ECRPUBLICClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-ecr-public/pagination/DescribeImagesPaginator.ts b/clients/client-ecr-public/pagination/DescribeImagesPaginator.ts new file mode 100644 index 000000000000..b7f1ee181295 --- /dev/null +++ b/clients/client-ecr-public/pagination/DescribeImagesPaginator.ts @@ -0,0 +1,57 @@ +import { ECRPUBLIC } from "../ECRPUBLIC"; +import { ECRPUBLICClient } from "../ECRPUBLICClient"; +import { + DescribeImagesCommand, + DescribeImagesCommandInput, + DescribeImagesCommandOutput, +} from "../commands/DescribeImagesCommand"; +import { ECRPUBLICPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ECRPUBLICClient, + input: DescribeImagesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeImagesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: ECRPUBLIC, + input: DescribeImagesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeImages(input, ...args); +}; +export async function* paginateDescribeImages( + config: ECRPUBLICPaginationConfiguration, + input: DescribeImagesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeImagesCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof ECRPUBLIC) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ECRPUBLICClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected ECRPUBLIC | ECRPUBLICClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-ecr-public/pagination/DescribeRegistriesPaginator.ts b/clients/client-ecr-public/pagination/DescribeRegistriesPaginator.ts new file mode 100644 index 000000000000..78745fcc22dd --- /dev/null +++ b/clients/client-ecr-public/pagination/DescribeRegistriesPaginator.ts @@ -0,0 +1,57 @@ +import { ECRPUBLIC } from "../ECRPUBLIC"; +import { ECRPUBLICClient } from "../ECRPUBLICClient"; +import { + DescribeRegistriesCommand, + DescribeRegistriesCommandInput, + DescribeRegistriesCommandOutput, +} from "../commands/DescribeRegistriesCommand"; +import { ECRPUBLICPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ECRPUBLICClient, + input: DescribeRegistriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeRegistriesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: ECRPUBLIC, + input: DescribeRegistriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeRegistries(input, ...args); +}; +export async function* paginateDescribeRegistries( + config: ECRPUBLICPaginationConfiguration, + input: DescribeRegistriesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeRegistriesCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof ECRPUBLIC) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ECRPUBLICClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected ECRPUBLIC | ECRPUBLICClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-ecr-public/pagination/DescribeRepositoriesPaginator.ts b/clients/client-ecr-public/pagination/DescribeRepositoriesPaginator.ts new file mode 100644 index 000000000000..8fe183cb488f --- /dev/null +++ b/clients/client-ecr-public/pagination/DescribeRepositoriesPaginator.ts @@ -0,0 +1,57 @@ +import { ECRPUBLIC } from "../ECRPUBLIC"; +import { ECRPUBLICClient } from "../ECRPUBLICClient"; +import { + DescribeRepositoriesCommand, + DescribeRepositoriesCommandInput, + DescribeRepositoriesCommandOutput, +} from "../commands/DescribeRepositoriesCommand"; +import { ECRPUBLICPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: ECRPUBLICClient, + input: DescribeRepositoriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeRepositoriesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: ECRPUBLIC, + input: DescribeRepositoriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeRepositories(input, ...args); +}; +export async function* paginateDescribeRepositories( + config: ECRPUBLICPaginationConfiguration, + input: DescribeRepositoriesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeRepositoriesCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof ECRPUBLIC) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof ECRPUBLICClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected ECRPUBLIC | ECRPUBLICClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-ecr-public/pagination/Interfaces.ts b/clients/client-ecr-public/pagination/Interfaces.ts new file mode 100644 index 000000000000..d0948182f53d --- /dev/null +++ b/clients/client-ecr-public/pagination/Interfaces.ts @@ -0,0 +1,7 @@ +import { ECRPUBLIC } from "../ECRPUBLIC"; +import { ECRPUBLICClient } from "../ECRPUBLICClient"; +import { PaginationConfiguration } from "@aws-sdk/types"; + +export interface ECRPUBLICPaginationConfiguration extends PaginationConfiguration { + client: ECRPUBLIC | ECRPUBLICClient; +} diff --git a/clients/client-ecr-public/protocols/Aws_json1_1.ts b/clients/client-ecr-public/protocols/Aws_json1_1.ts new file mode 100644 index 000000000000..7d6c4ca17518 --- /dev/null +++ b/clients/client-ecr-public/protocols/Aws_json1_1.ts @@ -0,0 +1,3338 @@ +import { + BatchCheckLayerAvailabilityCommandInput, + BatchCheckLayerAvailabilityCommandOutput, +} from "../commands/BatchCheckLayerAvailabilityCommand"; +import { BatchDeleteImageCommandInput, BatchDeleteImageCommandOutput } from "../commands/BatchDeleteImageCommand"; +import { + CompleteLayerUploadCommandInput, + CompleteLayerUploadCommandOutput, +} from "../commands/CompleteLayerUploadCommand"; +import { CreateRepositoryCommandInput, CreateRepositoryCommandOutput } from "../commands/CreateRepositoryCommand"; +import { DeleteRepositoryCommandInput, DeleteRepositoryCommandOutput } from "../commands/DeleteRepositoryCommand"; +import { + DeleteRepositoryPolicyCommandInput, + DeleteRepositoryPolicyCommandOutput, +} from "../commands/DeleteRepositoryPolicyCommand"; +import { DescribeImageTagsCommandInput, DescribeImageTagsCommandOutput } from "../commands/DescribeImageTagsCommand"; +import { DescribeImagesCommandInput, DescribeImagesCommandOutput } from "../commands/DescribeImagesCommand"; +import { DescribeRegistriesCommandInput, DescribeRegistriesCommandOutput } from "../commands/DescribeRegistriesCommand"; +import { + DescribeRepositoriesCommandInput, + DescribeRepositoriesCommandOutput, +} from "../commands/DescribeRepositoriesCommand"; +import { + GetAuthorizationTokenCommandInput, + GetAuthorizationTokenCommandOutput, +} from "../commands/GetAuthorizationTokenCommand"; +import { + GetRegistryCatalogDataCommandInput, + GetRegistryCatalogDataCommandOutput, +} from "../commands/GetRegistryCatalogDataCommand"; +import { + GetRepositoryCatalogDataCommandInput, + GetRepositoryCatalogDataCommandOutput, +} from "../commands/GetRepositoryCatalogDataCommand"; +import { + GetRepositoryPolicyCommandInput, + GetRepositoryPolicyCommandOutput, +} from "../commands/GetRepositoryPolicyCommand"; +import { + InitiateLayerUploadCommandInput, + InitiateLayerUploadCommandOutput, +} from "../commands/InitiateLayerUploadCommand"; +import { PutImageCommandInput, PutImageCommandOutput } from "../commands/PutImageCommand"; +import { + PutRegistryCatalogDataCommandInput, + PutRegistryCatalogDataCommandOutput, +} from "../commands/PutRegistryCatalogDataCommand"; +import { + PutRepositoryCatalogDataCommandInput, + PutRepositoryCatalogDataCommandOutput, +} from "../commands/PutRepositoryCatalogDataCommand"; +import { + SetRepositoryPolicyCommandInput, + SetRepositoryPolicyCommandOutput, +} from "../commands/SetRepositoryPolicyCommand"; +import { UploadLayerPartCommandInput, UploadLayerPartCommandOutput } from "../commands/UploadLayerPartCommand"; +import { + AuthorizationData, + BatchCheckLayerAvailabilityRequest, + BatchCheckLayerAvailabilityResponse, + BatchDeleteImageRequest, + BatchDeleteImageResponse, + CompleteLayerUploadRequest, + CompleteLayerUploadResponse, + CreateRepositoryRequest, + CreateRepositoryResponse, + DeleteRepositoryPolicyRequest, + DeleteRepositoryPolicyResponse, + DeleteRepositoryRequest, + DeleteRepositoryResponse, + DescribeImageTagsRequest, + DescribeImageTagsResponse, + DescribeImagesRequest, + DescribeImagesResponse, + DescribeRegistriesRequest, + DescribeRegistriesResponse, + DescribeRepositoriesRequest, + DescribeRepositoriesResponse, + EmptyUploadException, + GetAuthorizationTokenRequest, + GetAuthorizationTokenResponse, + GetRegistryCatalogDataRequest, + GetRegistryCatalogDataResponse, + GetRepositoryCatalogDataRequest, + GetRepositoryCatalogDataResponse, + GetRepositoryPolicyRequest, + GetRepositoryPolicyResponse, + Image, + ImageAlreadyExistsException, + ImageDetail, + ImageDigestDoesNotMatchException, + ImageFailure, + ImageIdentifier, + ImageNotFoundException, + ImageTagAlreadyExistsException, + ImageTagDetail, + InitiateLayerUploadRequest, + InitiateLayerUploadResponse, + InvalidLayerException, + InvalidLayerPartException, + InvalidParameterException, + Layer, + LayerAlreadyExistsException, + LayerFailure, + LayerPartTooSmallException, + LayersNotFoundException, + LimitExceededException, + PutImageRequest, + PutImageResponse, + PutRegistryCatalogDataRequest, + PutRegistryCatalogDataResponse, + PutRepositoryCatalogDataRequest, + PutRepositoryCatalogDataResponse, + ReferencedImageDetail, + ReferencedImagesNotFoundException, + Registry, + RegistryAlias, + RegistryCatalogData, + RegistryNotFoundException, + Repository, + RepositoryAlreadyExistsException, + RepositoryCatalogData, + RepositoryCatalogDataInput, + RepositoryNotEmptyException, + RepositoryNotFoundException, + RepositoryPolicyNotFoundException, + ServerException, + SetRepositoryPolicyRequest, + SetRepositoryPolicyResponse, + UnsupportedCommandException, + UploadLayerPartRequest, + UploadLayerPartResponse, + UploadNotFoundException, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + HeaderBag as __HeaderBag, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export const serializeAws_json1_1BatchCheckLayerAvailabilityCommand = async ( + input: BatchCheckLayerAvailabilityCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.BatchCheckLayerAvailability", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1BatchCheckLayerAvailabilityRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1BatchDeleteImageCommand = async ( + input: BatchDeleteImageCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.BatchDeleteImage", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1BatchDeleteImageRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1CompleteLayerUploadCommand = async ( + input: CompleteLayerUploadCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.CompleteLayerUpload", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CompleteLayerUploadRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1CreateRepositoryCommand = async ( + input: CreateRepositoryCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.CreateRepository", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateRepositoryRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteRepositoryCommand = async ( + input: DeleteRepositoryCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DeleteRepository", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteRepositoryRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteRepositoryPolicyCommand = async ( + input: DeleteRepositoryPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DeleteRepositoryPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteRepositoryPolicyRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribeImagesCommand = async ( + input: DescribeImagesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DescribeImages", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeImagesRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribeImageTagsCommand = async ( + input: DescribeImageTagsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DescribeImageTags", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeImageTagsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribeRegistriesCommand = async ( + input: DescribeRegistriesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DescribeRegistries", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeRegistriesRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribeRepositoriesCommand = async ( + input: DescribeRepositoriesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.DescribeRepositories", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeRepositoriesRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetAuthorizationTokenCommand = async ( + input: GetAuthorizationTokenCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.GetAuthorizationToken", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetAuthorizationTokenRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetRegistryCatalogDataCommand = async ( + input: GetRegistryCatalogDataCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.GetRegistryCatalogData", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetRegistryCatalogDataRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetRepositoryCatalogDataCommand = async ( + input: GetRepositoryCatalogDataCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.GetRepositoryCatalogData", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetRepositoryCatalogDataRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetRepositoryPolicyCommand = async ( + input: GetRepositoryPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.GetRepositoryPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetRepositoryPolicyRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1InitiateLayerUploadCommand = async ( + input: InitiateLayerUploadCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.InitiateLayerUpload", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1InitiateLayerUploadRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1PutImageCommand = async ( + input: PutImageCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.PutImage", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1PutImageRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1PutRegistryCatalogDataCommand = async ( + input: PutRegistryCatalogDataCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.PutRegistryCatalogData", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1PutRegistryCatalogDataRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1PutRepositoryCatalogDataCommand = async ( + input: PutRepositoryCatalogDataCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.PutRepositoryCatalogData", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1PutRepositoryCatalogDataRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1SetRepositoryPolicyCommand = async ( + input: SetRepositoryPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.SetRepositoryPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1SetRepositoryPolicyRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1UploadLayerPartCommand = async ( + input: UploadLayerPartCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SpencerFrontendService.UploadLayerPart", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UploadLayerPartRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const deserializeAws_json1_1BatchCheckLayerAvailabilityCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1BatchCheckLayerAvailabilityCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1BatchCheckLayerAvailabilityResponse(data, context); + const response: BatchCheckLayerAvailabilityCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1BatchCheckLayerAvailabilityCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RegistryNotFoundException": + case "com.amazonaws.ecrpublic#RegistryNotFoundException": + response = { + ...(await deserializeAws_json1_1RegistryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1BatchDeleteImageCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1BatchDeleteImageCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1BatchDeleteImageResponse(data, context); + const response: BatchDeleteImageCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1BatchDeleteImageCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1CompleteLayerUploadCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CompleteLayerUploadCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CompleteLayerUploadResponse(data, context); + const response: CompleteLayerUploadCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CompleteLayerUploadCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "EmptyUploadException": + case "com.amazonaws.ecrpublic#EmptyUploadException": + response = { + ...(await deserializeAws_json1_1EmptyUploadExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidLayerException": + case "com.amazonaws.ecrpublic#InvalidLayerException": + response = { + ...(await deserializeAws_json1_1InvalidLayerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LayerAlreadyExistsException": + case "com.amazonaws.ecrpublic#LayerAlreadyExistsException": + response = { + ...(await deserializeAws_json1_1LayerAlreadyExistsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LayerPartTooSmallException": + case "com.amazonaws.ecrpublic#LayerPartTooSmallException": + response = { + ...(await deserializeAws_json1_1LayerPartTooSmallExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RegistryNotFoundException": + case "com.amazonaws.ecrpublic#RegistryNotFoundException": + response = { + ...(await deserializeAws_json1_1RegistryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UploadNotFoundException": + case "com.amazonaws.ecrpublic#UploadNotFoundException": + response = { + ...(await deserializeAws_json1_1UploadNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1CreateRepositoryCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateRepositoryCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateRepositoryResponse(data, context); + const response: CreateRepositoryCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateRepositoryCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LimitExceededException": + case "com.amazonaws.ecrpublic#LimitExceededException": + response = { + ...(await deserializeAws_json1_1LimitExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryAlreadyExistsException": + case "com.amazonaws.ecrpublic#RepositoryAlreadyExistsException": + response = { + ...(await deserializeAws_json1_1RepositoryAlreadyExistsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteRepositoryCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteRepositoryCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteRepositoryResponse(data, context); + const response: DeleteRepositoryCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteRepositoryCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotEmptyException": + case "com.amazonaws.ecrpublic#RepositoryNotEmptyException": + response = { + ...(await deserializeAws_json1_1RepositoryNotEmptyExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteRepositoryPolicyCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteRepositoryPolicyCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteRepositoryPolicyResponse(data, context); + const response: DeleteRepositoryPolicyCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteRepositoryPolicyCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryPolicyNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryPolicyNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryPolicyNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeImagesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeImagesCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeImagesResponse(data, context); + const response: DescribeImagesCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeImagesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ImageNotFoundException": + case "com.amazonaws.ecrpublic#ImageNotFoundException": + response = { + ...(await deserializeAws_json1_1ImageNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeImageTagsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeImageTagsCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeImageTagsResponse(data, context); + const response: DescribeImageTagsCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeImageTagsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeRegistriesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeRegistriesCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeRegistriesResponse(data, context); + const response: DescribeRegistriesCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeRegistriesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeRepositoriesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeRepositoriesCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeRepositoriesResponse(data, context); + const response: DescribeRepositoriesCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeRepositoriesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1GetAuthorizationTokenCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1GetAuthorizationTokenCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1GetAuthorizationTokenResponse(data, context); + const response: GetAuthorizationTokenCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1GetAuthorizationTokenCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1GetRegistryCatalogDataCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1GetRegistryCatalogDataCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1GetRegistryCatalogDataResponse(data, context); + const response: GetRegistryCatalogDataCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1GetRegistryCatalogDataCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1GetRepositoryCatalogDataCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1GetRepositoryCatalogDataCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1GetRepositoryCatalogDataResponse(data, context); + const response: GetRepositoryCatalogDataCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1GetRepositoryCatalogDataCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1GetRepositoryPolicyCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1GetRepositoryPolicyCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1GetRepositoryPolicyResponse(data, context); + const response: GetRepositoryPolicyCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1GetRepositoryPolicyCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryPolicyNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryPolicyNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryPolicyNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1InitiateLayerUploadCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1InitiateLayerUploadCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1InitiateLayerUploadResponse(data, context); + const response: InitiateLayerUploadCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1InitiateLayerUploadCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RegistryNotFoundException": + case "com.amazonaws.ecrpublic#RegistryNotFoundException": + response = { + ...(await deserializeAws_json1_1RegistryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1PutImageCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1PutImageCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1PutImageResponse(data, context); + const response: PutImageCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1PutImageCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ImageAlreadyExistsException": + case "com.amazonaws.ecrpublic#ImageAlreadyExistsException": + response = { + ...(await deserializeAws_json1_1ImageAlreadyExistsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ImageDigestDoesNotMatchException": + case "com.amazonaws.ecrpublic#ImageDigestDoesNotMatchException": + response = { + ...(await deserializeAws_json1_1ImageDigestDoesNotMatchExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ImageTagAlreadyExistsException": + case "com.amazonaws.ecrpublic#ImageTagAlreadyExistsException": + response = { + ...(await deserializeAws_json1_1ImageTagAlreadyExistsExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LayersNotFoundException": + case "com.amazonaws.ecrpublic#LayersNotFoundException": + response = { + ...(await deserializeAws_json1_1LayersNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LimitExceededException": + case "com.amazonaws.ecrpublic#LimitExceededException": + response = { + ...(await deserializeAws_json1_1LimitExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ReferencedImagesNotFoundException": + case "com.amazonaws.ecrpublic#ReferencedImagesNotFoundException": + response = { + ...(await deserializeAws_json1_1ReferencedImagesNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RegistryNotFoundException": + case "com.amazonaws.ecrpublic#RegistryNotFoundException": + response = { + ...(await deserializeAws_json1_1RegistryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1PutRegistryCatalogDataCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1PutRegistryCatalogDataCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1PutRegistryCatalogDataResponse(data, context); + const response: PutRegistryCatalogDataCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1PutRegistryCatalogDataCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1PutRepositoryCatalogDataCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1PutRepositoryCatalogDataCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1PutRepositoryCatalogDataResponse(data, context); + const response: PutRepositoryCatalogDataCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1PutRepositoryCatalogDataCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1SetRepositoryPolicyCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1SetRepositoryPolicyCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1SetRepositoryPolicyResponse(data, context); + const response: SetRepositoryPolicyCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1SetRepositoryPolicyCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1UploadLayerPartCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1UploadLayerPartCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UploadLayerPartResponse(data, context); + const response: UploadLayerPartCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1UploadLayerPartCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "InvalidLayerPartException": + case "com.amazonaws.ecrpublic#InvalidLayerPartException": + response = { + ...(await deserializeAws_json1_1InvalidLayerPartExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.ecrpublic#InvalidParameterException": + response = { + ...(await deserializeAws_json1_1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "LimitExceededException": + case "com.amazonaws.ecrpublic#LimitExceededException": + response = { + ...(await deserializeAws_json1_1LimitExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RegistryNotFoundException": + case "com.amazonaws.ecrpublic#RegistryNotFoundException": + response = { + ...(await deserializeAws_json1_1RegistryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RepositoryNotFoundException": + case "com.amazonaws.ecrpublic#RepositoryNotFoundException": + response = { + ...(await deserializeAws_json1_1RepositoryNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.ecrpublic#ServerException": + response = { + ...(await deserializeAws_json1_1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UnsupportedCommandException": + case "com.amazonaws.ecrpublic#UnsupportedCommandException": + response = { + ...(await deserializeAws_json1_1UnsupportedCommandExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "UploadNotFoundException": + case "com.amazonaws.ecrpublic#UploadNotFoundException": + response = { + ...(await deserializeAws_json1_1UploadNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_json1_1EmptyUploadExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1EmptyUploadException(body, context); + const contents: EmptyUploadException = { + name: "EmptyUploadException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ImageAlreadyExistsExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ImageAlreadyExistsException(body, context); + const contents: ImageAlreadyExistsException = { + name: "ImageAlreadyExistsException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ImageDigestDoesNotMatchExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ImageDigestDoesNotMatchException(body, context); + const contents: ImageDigestDoesNotMatchException = { + name: "ImageDigestDoesNotMatchException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ImageNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ImageNotFoundException(body, context); + const contents: ImageNotFoundException = { + name: "ImageNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ImageTagAlreadyExistsExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ImageTagAlreadyExistsException(body, context); + const contents: ImageTagAlreadyExistsException = { + name: "ImageTagAlreadyExistsException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1InvalidLayerExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1InvalidLayerException(body, context); + const contents: InvalidLayerException = { + name: "InvalidLayerException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1InvalidLayerPartExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1InvalidLayerPartException(body, context); + const contents: InvalidLayerPartException = { + name: "InvalidLayerPartException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1InvalidParameterExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1InvalidParameterException(body, context); + const contents: InvalidParameterException = { + name: "InvalidParameterException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1LayerAlreadyExistsExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1LayerAlreadyExistsException(body, context); + const contents: LayerAlreadyExistsException = { + name: "LayerAlreadyExistsException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1LayerPartTooSmallExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1LayerPartTooSmallException(body, context); + const contents: LayerPartTooSmallException = { + name: "LayerPartTooSmallException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1LayersNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1LayersNotFoundException(body, context); + const contents: LayersNotFoundException = { + name: "LayersNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1LimitExceededExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1LimitExceededException(body, context); + const contents: LimitExceededException = { + name: "LimitExceededException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ReferencedImagesNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ReferencedImagesNotFoundException(body, context); + const contents: ReferencedImagesNotFoundException = { + name: "ReferencedImagesNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1RegistryNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1RegistryNotFoundException(body, context); + const contents: RegistryNotFoundException = { + name: "RegistryNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1RepositoryAlreadyExistsExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1RepositoryAlreadyExistsException(body, context); + const contents: RepositoryAlreadyExistsException = { + name: "RepositoryAlreadyExistsException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1RepositoryNotEmptyExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1RepositoryNotEmptyException(body, context); + const contents: RepositoryNotEmptyException = { + name: "RepositoryNotEmptyException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1RepositoryNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1RepositoryNotFoundException(body, context); + const contents: RepositoryNotFoundException = { + name: "RepositoryNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1RepositoryPolicyNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1RepositoryPolicyNotFoundException(body, context); + const contents: RepositoryPolicyNotFoundException = { + name: "RepositoryPolicyNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1ServerExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1ServerException(body, context); + const contents: ServerException = { + name: "ServerException", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1UnsupportedCommandExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1UnsupportedCommandException(body, context); + const contents: UnsupportedCommandException = { + name: "UnsupportedCommandException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const deserializeAws_json1_1UploadNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const body = parsedOutput.body; + const deserialized: any = deserializeAws_json1_1UploadNotFoundException(body, context); + const contents: UploadNotFoundException = { + name: "UploadNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + ...deserialized, + }; + return contents; +}; + +const serializeAws_json1_1ArchitectureList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1BatchCheckLayerAvailabilityRequest = ( + input: BatchCheckLayerAvailabilityRequest, + context: __SerdeContext +): any => { + return { + ...(input.layerDigests !== undefined && { + layerDigests: serializeAws_json1_1BatchedOperationLayerDigestList(input.layerDigests, context), + }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1BatchDeleteImageRequest = (input: BatchDeleteImageRequest, context: __SerdeContext): any => { + return { + ...(input.imageIds !== undefined && { imageIds: serializeAws_json1_1ImageIdentifierList(input.imageIds, context) }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1BatchedOperationLayerDigestList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1CompleteLayerUploadRequest = ( + input: CompleteLayerUploadRequest, + context: __SerdeContext +): any => { + return { + ...(input.layerDigests !== undefined && { + layerDigests: serializeAws_json1_1LayerDigestList(input.layerDigests, context), + }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + ...(input.uploadId !== undefined && { uploadId: input.uploadId }), + }; +}; + +const serializeAws_json1_1CreateRepositoryRequest = (input: CreateRepositoryRequest, context: __SerdeContext): any => { + return { + ...(input.catalogData !== undefined && { + catalogData: serializeAws_json1_1RepositoryCatalogDataInput(input.catalogData, context), + }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1DeleteRepositoryPolicyRequest = ( + input: DeleteRepositoryPolicyRequest, + context: __SerdeContext +): any => { + return { + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1DeleteRepositoryRequest = (input: DeleteRepositoryRequest, context: __SerdeContext): any => { + return { + ...(input.force !== undefined && { force: input.force }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1DescribeImagesRequest = (input: DescribeImagesRequest, context: __SerdeContext): any => { + return { + ...(input.imageIds !== undefined && { imageIds: serializeAws_json1_1ImageIdentifierList(input.imageIds, context) }), + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1DescribeImageTagsRequest = ( + input: DescribeImageTagsRequest, + context: __SerdeContext +): any => { + return { + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1DescribeRegistriesRequest = ( + input: DescribeRegistriesRequest, + context: __SerdeContext +): any => { + return { + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + }; +}; + +const serializeAws_json1_1DescribeRepositoriesRequest = ( + input: DescribeRepositoriesRequest, + context: __SerdeContext +): any => { + return { + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryNames !== undefined && { + repositoryNames: serializeAws_json1_1RepositoryNameList(input.repositoryNames, context), + }), + }; +}; + +const serializeAws_json1_1GetAuthorizationTokenRequest = ( + input: GetAuthorizationTokenRequest, + context: __SerdeContext +): any => { + return {}; +}; + +const serializeAws_json1_1GetRegistryCatalogDataRequest = ( + input: GetRegistryCatalogDataRequest, + context: __SerdeContext +): any => { + return {}; +}; + +const serializeAws_json1_1GetRepositoryCatalogDataRequest = ( + input: GetRepositoryCatalogDataRequest, + context: __SerdeContext +): any => { + return { + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1GetRepositoryPolicyRequest = ( + input: GetRepositoryPolicyRequest, + context: __SerdeContext +): any => { + return { + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1ImageIdentifier = (input: ImageIdentifier, context: __SerdeContext): any => { + return { + ...(input.imageDigest !== undefined && { imageDigest: input.imageDigest }), + ...(input.imageTag !== undefined && { imageTag: input.imageTag }), + }; +}; + +const serializeAws_json1_1ImageIdentifierList = (input: ImageIdentifier[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1ImageIdentifier(entry, context)); +}; + +const serializeAws_json1_1InitiateLayerUploadRequest = ( + input: InitiateLayerUploadRequest, + context: __SerdeContext +): any => { + return { + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1LayerDigestList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1OperatingSystemList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1PutImageRequest = (input: PutImageRequest, context: __SerdeContext): any => { + return { + ...(input.imageDigest !== undefined && { imageDigest: input.imageDigest }), + ...(input.imageManifest !== undefined && { imageManifest: input.imageManifest }), + ...(input.imageManifestMediaType !== undefined && { imageManifestMediaType: input.imageManifestMediaType }), + ...(input.imageTag !== undefined && { imageTag: input.imageTag }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1PutRegistryCatalogDataRequest = ( + input: PutRegistryCatalogDataRequest, + context: __SerdeContext +): any => { + return { + ...(input.displayName !== undefined && { displayName: input.displayName }), + }; +}; + +const serializeAws_json1_1PutRepositoryCatalogDataRequest = ( + input: PutRepositoryCatalogDataRequest, + context: __SerdeContext +): any => { + return { + ...(input.catalogData !== undefined && { + catalogData: serializeAws_json1_1RepositoryCatalogDataInput(input.catalogData, context), + }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1RepositoryCatalogDataInput = ( + input: RepositoryCatalogDataInput, + context: __SerdeContext +): any => { + return { + ...(input.aboutText !== undefined && { aboutText: input.aboutText }), + ...(input.architectures !== undefined && { + architectures: serializeAws_json1_1ArchitectureList(input.architectures, context), + }), + ...(input.description !== undefined && { description: input.description }), + ...(input.logoImageBlob !== undefined && { logoImageBlob: context.base64Encoder(input.logoImageBlob) }), + ...(input.operatingSystems !== undefined && { + operatingSystems: serializeAws_json1_1OperatingSystemList(input.operatingSystems, context), + }), + ...(input.usageText !== undefined && { usageText: input.usageText }), + }; +}; + +const serializeAws_json1_1RepositoryNameList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1SetRepositoryPolicyRequest = ( + input: SetRepositoryPolicyRequest, + context: __SerdeContext +): any => { + return { + ...(input.force !== undefined && { force: input.force }), + ...(input.policyText !== undefined && { policyText: input.policyText }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + }; +}; + +const serializeAws_json1_1UploadLayerPartRequest = (input: UploadLayerPartRequest, context: __SerdeContext): any => { + return { + ...(input.layerPartBlob !== undefined && { layerPartBlob: context.base64Encoder(input.layerPartBlob) }), + ...(input.partFirstByte !== undefined && { partFirstByte: input.partFirstByte }), + ...(input.partLastByte !== undefined && { partLastByte: input.partLastByte }), + ...(input.registryId !== undefined && { registryId: input.registryId }), + ...(input.repositoryName !== undefined && { repositoryName: input.repositoryName }), + ...(input.uploadId !== undefined && { uploadId: input.uploadId }), + }; +}; + +const deserializeAws_json1_1ArchitectureList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_json1_1AuthorizationData = (output: any, context: __SerdeContext): AuthorizationData => { + return { + authorizationToken: + output.authorizationToken !== undefined && output.authorizationToken !== null + ? output.authorizationToken + : undefined, + expiresAt: + output.expiresAt !== undefined && output.expiresAt !== null + ? new Date(Math.round(output.expiresAt * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_json1_1BatchCheckLayerAvailabilityResponse = ( + output: any, + context: __SerdeContext +): BatchCheckLayerAvailabilityResponse => { + return { + failures: + output.failures !== undefined && output.failures !== null + ? deserializeAws_json1_1LayerFailureList(output.failures, context) + : undefined, + layers: + output.layers !== undefined && output.layers !== null + ? deserializeAws_json1_1LayerList(output.layers, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1BatchDeleteImageResponse = ( + output: any, + context: __SerdeContext +): BatchDeleteImageResponse => { + return { + failures: + output.failures !== undefined && output.failures !== null + ? deserializeAws_json1_1ImageFailureList(output.failures, context) + : undefined, + imageIds: + output.imageIds !== undefined && output.imageIds !== null + ? deserializeAws_json1_1ImageIdentifierList(output.imageIds, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1CompleteLayerUploadResponse = ( + output: any, + context: __SerdeContext +): CompleteLayerUploadResponse => { + return { + layerDigest: output.layerDigest !== undefined && output.layerDigest !== null ? output.layerDigest : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + uploadId: output.uploadId !== undefined && output.uploadId !== null ? output.uploadId : undefined, + } as any; +}; + +const deserializeAws_json1_1CreateRepositoryResponse = ( + output: any, + context: __SerdeContext +): CreateRepositoryResponse => { + return { + catalogData: + output.catalogData !== undefined && output.catalogData !== null + ? deserializeAws_json1_1RepositoryCatalogData(output.catalogData, context) + : undefined, + repository: + output.repository !== undefined && output.repository !== null + ? deserializeAws_json1_1Repository(output.repository, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1DeleteRepositoryPolicyResponse = ( + output: any, + context: __SerdeContext +): DeleteRepositoryPolicyResponse => { + return { + policyText: output.policyText !== undefined && output.policyText !== null ? output.policyText : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + } as any; +}; + +const deserializeAws_json1_1DeleteRepositoryResponse = ( + output: any, + context: __SerdeContext +): DeleteRepositoryResponse => { + return { + repository: + output.repository !== undefined && output.repository !== null + ? deserializeAws_json1_1Repository(output.repository, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeImagesResponse = (output: any, context: __SerdeContext): DescribeImagesResponse => { + return { + imageDetails: + output.imageDetails !== undefined && output.imageDetails !== null + ? deserializeAws_json1_1ImageDetailList(output.imageDetails, context) + : undefined, + nextToken: output.nextToken !== undefined && output.nextToken !== null ? output.nextToken : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeImageTagsResponse = ( + output: any, + context: __SerdeContext +): DescribeImageTagsResponse => { + return { + imageTagDetails: + output.imageTagDetails !== undefined && output.imageTagDetails !== null + ? deserializeAws_json1_1ImageTagDetailList(output.imageTagDetails, context) + : undefined, + nextToken: output.nextToken !== undefined && output.nextToken !== null ? output.nextToken : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeRegistriesResponse = ( + output: any, + context: __SerdeContext +): DescribeRegistriesResponse => { + return { + nextToken: output.nextToken !== undefined && output.nextToken !== null ? output.nextToken : undefined, + registries: + output.registries !== undefined && output.registries !== null + ? deserializeAws_json1_1RegistryList(output.registries, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeRepositoriesResponse = ( + output: any, + context: __SerdeContext +): DescribeRepositoriesResponse => { + return { + nextToken: output.nextToken !== undefined && output.nextToken !== null ? output.nextToken : undefined, + repositories: + output.repositories !== undefined && output.repositories !== null + ? deserializeAws_json1_1RepositoryList(output.repositories, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1EmptyUploadException = (output: any, context: __SerdeContext): EmptyUploadException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1GetAuthorizationTokenResponse = ( + output: any, + context: __SerdeContext +): GetAuthorizationTokenResponse => { + return { + authorizationData: + output.authorizationData !== undefined && output.authorizationData !== null + ? deserializeAws_json1_1AuthorizationData(output.authorizationData, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1GetRegistryCatalogDataResponse = ( + output: any, + context: __SerdeContext +): GetRegistryCatalogDataResponse => { + return { + registryCatalogData: + output.registryCatalogData !== undefined && output.registryCatalogData !== null + ? deserializeAws_json1_1RegistryCatalogData(output.registryCatalogData, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1GetRepositoryCatalogDataResponse = ( + output: any, + context: __SerdeContext +): GetRepositoryCatalogDataResponse => { + return { + catalogData: + output.catalogData !== undefined && output.catalogData !== null + ? deserializeAws_json1_1RepositoryCatalogData(output.catalogData, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1GetRepositoryPolicyResponse = ( + output: any, + context: __SerdeContext +): GetRepositoryPolicyResponse => { + return { + policyText: output.policyText !== undefined && output.policyText !== null ? output.policyText : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + } as any; +}; + +const deserializeAws_json1_1Image = (output: any, context: __SerdeContext): Image => { + return { + imageId: + output.imageId !== undefined && output.imageId !== null + ? deserializeAws_json1_1ImageIdentifier(output.imageId, context) + : undefined, + imageManifest: + output.imageManifest !== undefined && output.imageManifest !== null ? output.imageManifest : undefined, + imageManifestMediaType: + output.imageManifestMediaType !== undefined && output.imageManifestMediaType !== null + ? output.imageManifestMediaType + : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageAlreadyExistsException = ( + output: any, + context: __SerdeContext +): ImageAlreadyExistsException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageDetail = (output: any, context: __SerdeContext): ImageDetail => { + return { + artifactMediaType: + output.artifactMediaType !== undefined && output.artifactMediaType !== null + ? output.artifactMediaType + : undefined, + imageDigest: output.imageDigest !== undefined && output.imageDigest !== null ? output.imageDigest : undefined, + imageManifestMediaType: + output.imageManifestMediaType !== undefined && output.imageManifestMediaType !== null + ? output.imageManifestMediaType + : undefined, + imagePushedAt: + output.imagePushedAt !== undefined && output.imagePushedAt !== null + ? new Date(Math.round(output.imagePushedAt * 1000)) + : undefined, + imageSizeInBytes: + output.imageSizeInBytes !== undefined && output.imageSizeInBytes !== null ? output.imageSizeInBytes : undefined, + imageTags: + output.imageTags !== undefined && output.imageTags !== null + ? deserializeAws_json1_1ImageTagList(output.imageTags, context) + : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageDetailList = (output: any, context: __SerdeContext): ImageDetail[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ImageDetail(entry, context)); +}; + +const deserializeAws_json1_1ImageDigestDoesNotMatchException = ( + output: any, + context: __SerdeContext +): ImageDigestDoesNotMatchException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageFailure = (output: any, context: __SerdeContext): ImageFailure => { + return { + failureCode: output.failureCode !== undefined && output.failureCode !== null ? output.failureCode : undefined, + failureReason: + output.failureReason !== undefined && output.failureReason !== null ? output.failureReason : undefined, + imageId: + output.imageId !== undefined && output.imageId !== null + ? deserializeAws_json1_1ImageIdentifier(output.imageId, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageFailureList = (output: any, context: __SerdeContext): ImageFailure[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ImageFailure(entry, context)); +}; + +const deserializeAws_json1_1ImageIdentifier = (output: any, context: __SerdeContext): ImageIdentifier => { + return { + imageDigest: output.imageDigest !== undefined && output.imageDigest !== null ? output.imageDigest : undefined, + imageTag: output.imageTag !== undefined && output.imageTag !== null ? output.imageTag : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageIdentifierList = (output: any, context: __SerdeContext): ImageIdentifier[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ImageIdentifier(entry, context)); +}; + +const deserializeAws_json1_1ImageNotFoundException = (output: any, context: __SerdeContext): ImageNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageTagAlreadyExistsException = ( + output: any, + context: __SerdeContext +): ImageTagAlreadyExistsException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageTagDetail = (output: any, context: __SerdeContext): ImageTagDetail => { + return { + createdAt: + output.createdAt !== undefined && output.createdAt !== null + ? new Date(Math.round(output.createdAt * 1000)) + : undefined, + imageDetail: + output.imageDetail !== undefined && output.imageDetail !== null + ? deserializeAws_json1_1ReferencedImageDetail(output.imageDetail, context) + : undefined, + imageTag: output.imageTag !== undefined && output.imageTag !== null ? output.imageTag : undefined, + } as any; +}; + +const deserializeAws_json1_1ImageTagDetailList = (output: any, context: __SerdeContext): ImageTagDetail[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ImageTagDetail(entry, context)); +}; + +const deserializeAws_json1_1ImageTagList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_json1_1InitiateLayerUploadResponse = ( + output: any, + context: __SerdeContext +): InitiateLayerUploadResponse => { + return { + partSize: output.partSize !== undefined && output.partSize !== null ? output.partSize : undefined, + uploadId: output.uploadId !== undefined && output.uploadId !== null ? output.uploadId : undefined, + } as any; +}; + +const deserializeAws_json1_1InvalidLayerException = (output: any, context: __SerdeContext): InvalidLayerException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1InvalidLayerPartException = ( + output: any, + context: __SerdeContext +): InvalidLayerPartException => { + return { + lastValidByteReceived: + output.lastValidByteReceived !== undefined && output.lastValidByteReceived !== null + ? output.lastValidByteReceived + : undefined, + message: output.message !== undefined && output.message !== null ? output.message : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + uploadId: output.uploadId !== undefined && output.uploadId !== null ? output.uploadId : undefined, + } as any; +}; + +const deserializeAws_json1_1InvalidParameterException = ( + output: any, + context: __SerdeContext +): InvalidParameterException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1Layer = (output: any, context: __SerdeContext): Layer => { + return { + layerAvailability: + output.layerAvailability !== undefined && output.layerAvailability !== null + ? output.layerAvailability + : undefined, + layerDigest: output.layerDigest !== undefined && output.layerDigest !== null ? output.layerDigest : undefined, + layerSize: output.layerSize !== undefined && output.layerSize !== null ? output.layerSize : undefined, + mediaType: output.mediaType !== undefined && output.mediaType !== null ? output.mediaType : undefined, + } as any; +}; + +const deserializeAws_json1_1LayerAlreadyExistsException = ( + output: any, + context: __SerdeContext +): LayerAlreadyExistsException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1LayerFailure = (output: any, context: __SerdeContext): LayerFailure => { + return { + failureCode: output.failureCode !== undefined && output.failureCode !== null ? output.failureCode : undefined, + failureReason: + output.failureReason !== undefined && output.failureReason !== null ? output.failureReason : undefined, + layerDigest: output.layerDigest !== undefined && output.layerDigest !== null ? output.layerDigest : undefined, + } as any; +}; + +const deserializeAws_json1_1LayerFailureList = (output: any, context: __SerdeContext): LayerFailure[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1LayerFailure(entry, context)); +}; + +const deserializeAws_json1_1LayerList = (output: any, context: __SerdeContext): Layer[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Layer(entry, context)); +}; + +const deserializeAws_json1_1LayerPartTooSmallException = ( + output: any, + context: __SerdeContext +): LayerPartTooSmallException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1LayersNotFoundException = ( + output: any, + context: __SerdeContext +): LayersNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1LimitExceededException = (output: any, context: __SerdeContext): LimitExceededException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1OperatingSystemList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_json1_1PutImageResponse = (output: any, context: __SerdeContext): PutImageResponse => { + return { + image: + output.image !== undefined && output.image !== null + ? deserializeAws_json1_1Image(output.image, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1PutRegistryCatalogDataResponse = ( + output: any, + context: __SerdeContext +): PutRegistryCatalogDataResponse => { + return { + registryCatalogData: + output.registryCatalogData !== undefined && output.registryCatalogData !== null + ? deserializeAws_json1_1RegistryCatalogData(output.registryCatalogData, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1PutRepositoryCatalogDataResponse = ( + output: any, + context: __SerdeContext +): PutRepositoryCatalogDataResponse => { + return { + catalogData: + output.catalogData !== undefined && output.catalogData !== null + ? deserializeAws_json1_1RepositoryCatalogData(output.catalogData, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ReferencedImageDetail = (output: any, context: __SerdeContext): ReferencedImageDetail => { + return { + artifactMediaType: + output.artifactMediaType !== undefined && output.artifactMediaType !== null + ? output.artifactMediaType + : undefined, + imageDigest: output.imageDigest !== undefined && output.imageDigest !== null ? output.imageDigest : undefined, + imageManifestMediaType: + output.imageManifestMediaType !== undefined && output.imageManifestMediaType !== null + ? output.imageManifestMediaType + : undefined, + imagePushedAt: + output.imagePushedAt !== undefined && output.imagePushedAt !== null + ? new Date(Math.round(output.imagePushedAt * 1000)) + : undefined, + imageSizeInBytes: + output.imageSizeInBytes !== undefined && output.imageSizeInBytes !== null ? output.imageSizeInBytes : undefined, + } as any; +}; + +const deserializeAws_json1_1ReferencedImagesNotFoundException = ( + output: any, + context: __SerdeContext +): ReferencedImagesNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1Registry = (output: any, context: __SerdeContext): Registry => { + return { + aliases: + output.aliases !== undefined && output.aliases !== null + ? deserializeAws_json1_1RegistryAliasList(output.aliases, context) + : undefined, + registryArn: output.registryArn !== undefined && output.registryArn !== null ? output.registryArn : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + registryUri: output.registryUri !== undefined && output.registryUri !== null ? output.registryUri : undefined, + verified: output.verified !== undefined && output.verified !== null ? output.verified : undefined, + } as any; +}; + +const deserializeAws_json1_1RegistryAlias = (output: any, context: __SerdeContext): RegistryAlias => { + return { + defaultRegistryAlias: + output.defaultRegistryAlias !== undefined && output.defaultRegistryAlias !== null + ? output.defaultRegistryAlias + : undefined, + name: output.name !== undefined && output.name !== null ? output.name : undefined, + primaryRegistryAlias: + output.primaryRegistryAlias !== undefined && output.primaryRegistryAlias !== null + ? output.primaryRegistryAlias + : undefined, + status: output.status !== undefined && output.status !== null ? output.status : undefined, + } as any; +}; + +const deserializeAws_json1_1RegistryAliasList = (output: any, context: __SerdeContext): RegistryAlias[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1RegistryAlias(entry, context)); +}; + +const deserializeAws_json1_1RegistryCatalogData = (output: any, context: __SerdeContext): RegistryCatalogData => { + return { + displayName: output.displayName !== undefined && output.displayName !== null ? output.displayName : undefined, + } as any; +}; + +const deserializeAws_json1_1RegistryList = (output: any, context: __SerdeContext): Registry[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Registry(entry, context)); +}; + +const deserializeAws_json1_1RegistryNotFoundException = ( + output: any, + context: __SerdeContext +): RegistryNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1Repository = (output: any, context: __SerdeContext): Repository => { + return { + createdAt: + output.createdAt !== undefined && output.createdAt !== null + ? new Date(Math.round(output.createdAt * 1000)) + : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryArn: + output.repositoryArn !== undefined && output.repositoryArn !== null ? output.repositoryArn : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + repositoryUri: + output.repositoryUri !== undefined && output.repositoryUri !== null ? output.repositoryUri : undefined, + } as any; +}; + +const deserializeAws_json1_1RepositoryAlreadyExistsException = ( + output: any, + context: __SerdeContext +): RepositoryAlreadyExistsException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1RepositoryCatalogData = (output: any, context: __SerdeContext): RepositoryCatalogData => { + return { + aboutText: output.aboutText !== undefined && output.aboutText !== null ? output.aboutText : undefined, + architectures: + output.architectures !== undefined && output.architectures !== null + ? deserializeAws_json1_1ArchitectureList(output.architectures, context) + : undefined, + description: output.description !== undefined && output.description !== null ? output.description : undefined, + logoUrl: output.logoUrl !== undefined && output.logoUrl !== null ? output.logoUrl : undefined, + marketplaceCertified: + output.marketplaceCertified !== undefined && output.marketplaceCertified !== null + ? output.marketplaceCertified + : undefined, + operatingSystems: + output.operatingSystems !== undefined && output.operatingSystems !== null + ? deserializeAws_json1_1OperatingSystemList(output.operatingSystems, context) + : undefined, + usageText: output.usageText !== undefined && output.usageText !== null ? output.usageText : undefined, + } as any; +}; + +const deserializeAws_json1_1RepositoryList = (output: any, context: __SerdeContext): Repository[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Repository(entry, context)); +}; + +const deserializeAws_json1_1RepositoryNotEmptyException = ( + output: any, + context: __SerdeContext +): RepositoryNotEmptyException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1RepositoryNotFoundException = ( + output: any, + context: __SerdeContext +): RepositoryNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1RepositoryPolicyNotFoundException = ( + output: any, + context: __SerdeContext +): RepositoryPolicyNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1ServerException = (output: any, context: __SerdeContext): ServerException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1SetRepositoryPolicyResponse = ( + output: any, + context: __SerdeContext +): SetRepositoryPolicyResponse => { + return { + policyText: output.policyText !== undefined && output.policyText !== null ? output.policyText : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + } as any; +}; + +const deserializeAws_json1_1UnsupportedCommandException = ( + output: any, + context: __SerdeContext +): UnsupportedCommandException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeAws_json1_1UploadLayerPartResponse = ( + output: any, + context: __SerdeContext +): UploadLayerPartResponse => { + return { + lastByteReceived: + output.lastByteReceived !== undefined && output.lastByteReceived !== null ? output.lastByteReceived : undefined, + registryId: output.registryId !== undefined && output.registryId !== null ? output.registryId : undefined, + repositoryName: + output.repositoryName !== undefined && output.repositoryName !== null ? output.repositoryName : undefined, + uploadId: output.uploadId !== undefined && output.uploadId !== null ? output.uploadId : undefined, + } as any; +}; + +const deserializeAws_json1_1UploadNotFoundException = ( + output: any, + context: __SerdeContext +): UploadNotFoundException => { + return { + message: output.message !== undefined && output.message !== null ? output.message : undefined, + } as any; +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const buildHttpRpcRequest = async ( + context: __SerdeContext, + headers: __HeaderBag, + path: string, + resolvedHostname: string | undefined, + body: any +): Promise<__HttpRequest> => { + const { hostname, protocol = "https", port } = await context.endpoint(); + const contents: any = { + protocol, + hostname, + port, + method: "POST", + path, + headers, + }; + if (resolvedHostname !== undefined) { + contents.hostname = resolvedHostname; + } + if (body !== undefined) { + contents.body = body; + } + return new __HttpRequest(contents); +}; + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); diff --git a/clients/client-ecr-public/runtimeConfig.browser.ts b/clients/client-ecr-public/runtimeConfig.browser.ts new file mode 100644 index 000000000000..5e3675eab6a1 --- /dev/null +++ b/clients/client-ecr-public/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./ECRPUBLICClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-ecr-public/runtimeConfig.native.ts b/clients/client-ecr-public/runtimeConfig.native.ts new file mode 100644 index 000000000000..97909e5f0316 --- /dev/null +++ b/clients/client-ecr-public/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./ECRPUBLICClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-ecr-public/runtimeConfig.shared.ts b/clients/client-ecr-public/runtimeConfig.shared.ts new file mode 100644 index 000000000000..2914e8d7d679 --- /dev/null +++ b/clients/client-ecr-public/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-10-30", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "ecr-public", +}; diff --git a/clients/client-ecr-public/runtimeConfig.ts b/clients/client-ecr-public/runtimeConfig.ts new file mode 100644 index 000000000000..f8589fd728f5 --- /dev/null +++ b/clients/client-ecr-public/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./ECRPUBLICClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-ecr-public/tsconfig.es.json b/clients/client-ecr-public/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-ecr-public/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-ecr-public/tsconfig.json b/clients/client-ecr-public/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-ecr-public/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-eks/EKS.ts b/clients/client-eks/EKS.ts index 4ea2160b1d3f..ba1d1a595f71 100644 --- a/clients/client-eks/EKS.ts +++ b/clients/client-eks/EKS.ts @@ -1,4 +1,5 @@ import { EKSClient } from "./EKSClient"; +import { CreateAddonCommand, CreateAddonCommandInput, CreateAddonCommandOutput } from "./commands/CreateAddonCommand"; import { CreateClusterCommand, CreateClusterCommandInput, @@ -14,6 +15,7 @@ import { CreateNodegroupCommandInput, CreateNodegroupCommandOutput, } from "./commands/CreateNodegroupCommand"; +import { DeleteAddonCommand, DeleteAddonCommandInput, DeleteAddonCommandOutput } from "./commands/DeleteAddonCommand"; import { DeleteClusterCommand, DeleteClusterCommandInput, @@ -29,6 +31,16 @@ import { DeleteNodegroupCommandInput, DeleteNodegroupCommandOutput, } from "./commands/DeleteNodegroupCommand"; +import { + DescribeAddonCommand, + DescribeAddonCommandInput, + DescribeAddonCommandOutput, +} from "./commands/DescribeAddonCommand"; +import { + DescribeAddonVersionsCommand, + DescribeAddonVersionsCommandInput, + DescribeAddonVersionsCommandOutput, +} from "./commands/DescribeAddonVersionsCommand"; import { DescribeClusterCommand, DescribeClusterCommandInput, @@ -49,6 +61,7 @@ import { DescribeUpdateCommandInput, DescribeUpdateCommandOutput, } from "./commands/DescribeUpdateCommand"; +import { ListAddonsCommand, ListAddonsCommandInput, ListAddonsCommandOutput } from "./commands/ListAddonsCommand"; import { ListClustersCommand, ListClustersCommandInput, @@ -76,6 +89,7 @@ import { UntagResourceCommandInput, UntagResourceCommandOutput, } from "./commands/UntagResourceCommand"; +import { UpdateAddonCommand, UpdateAddonCommandInput, UpdateAddonCommandOutput } from "./commands/UpdateAddonCommand"; import { UpdateClusterConfigCommand, UpdateClusterConfigCommandInput, @@ -111,6 +125,37 @@ import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; * code modification required.

    */ export class EKS extends EKSClient { + /** + *

    Creates an Amazon EKS add-on.

    + *

    Amazon EKS add-ons help to automate the provisioning and lifecycle management of common + * operational software for Amazon EKS clusters. Amazon EKS add-ons can only be used with Amazon EKS + * clusters running version 1.18 with platform version eks.3 or later because + * add-ons rely on the Server-side Apply Kubernetes feature, which is only available in + * Kubernetes 1.18 and later.

    + */ + public createAddon(args: CreateAddonCommandInput, options?: __HttpHandlerOptions): Promise; + public createAddon(args: CreateAddonCommandInput, cb: (err: any, data?: CreateAddonCommandOutput) => void): void; + public createAddon( + args: CreateAddonCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateAddonCommandOutput) => void + ): void; + public createAddon( + args: CreateAddonCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateAddonCommandOutput) => void), + cb?: (err: any, data?: CreateAddonCommandOutput) => void + ): Promise | void { + const command = new CreateAddonCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates an Amazon EKS control plane.

    *

    The Amazon EKS control plane consists of control plane instances that run the Kubernetes @@ -242,8 +287,8 @@ export class EKS extends EKSClient { * template. For more information about using launch templates, see Launch * template support.

    *

    An Amazon EKS managed node group is an Amazon EC2 Auto Scaling group and associated Amazon EC2 instances that - * are managed by AWS for an Amazon EKS cluster. Each node group uses a version of the - * Amazon EKS-optimized Amazon Linux 2 AMI. For more information, see Managed + * are managed by AWS for an Amazon EKS cluster. Each node group uses a version of the Amazon EKS + * optimized Amazon Linux 2 AMI. For more information, see Managed * Node Groups in the Amazon EKS User Guide.

    */ public createNodegroup( @@ -275,6 +320,34 @@ export class EKS extends EKSClient { } } + /** + *

    Delete an Amazon EKS add-on.

    + *

    When you remove the add-on, it will also be deleted from the cluster. You can always + * manually start an add-on on the cluster using the Kubernetes API.

    + */ + public deleteAddon(args: DeleteAddonCommandInput, options?: __HttpHandlerOptions): Promise; + public deleteAddon(args: DeleteAddonCommandInput, cb: (err: any, data?: DeleteAddonCommandOutput) => void): void; + public deleteAddon( + args: DeleteAddonCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteAddonCommandOutput) => void + ): void; + public deleteAddon( + args: DeleteAddonCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteAddonCommandOutput) => void), + cb?: (err: any, data?: DeleteAddonCommandOutput) => void + ): Promise | void { + const command = new DeleteAddonCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Deletes the Amazon EKS cluster control plane.

    *

    If you have active services in your cluster that are associated with a load balancer, @@ -385,6 +458,70 @@ export class EKS extends EKSClient { } } + /** + *

    Describes an Amazon EKS add-on.

    + */ + public describeAddon( + args: DescribeAddonCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAddon( + args: DescribeAddonCommandInput, + cb: (err: any, data?: DescribeAddonCommandOutput) => void + ): void; + public describeAddon( + args: DescribeAddonCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeAddonCommandOutput) => void + ): void; + public describeAddon( + args: DescribeAddonCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeAddonCommandOutput) => void), + cb?: (err: any, data?: DescribeAddonCommandOutput) => void + ): Promise | void { + const command = new DescribeAddonCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Describes the Kubernetes versions that the add-on can be used with.

    + */ + public describeAddonVersions( + args: DescribeAddonVersionsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAddonVersions( + args: DescribeAddonVersionsCommandInput, + cb: (err: any, data?: DescribeAddonVersionsCommandOutput) => void + ): void; + public describeAddonVersions( + args: DescribeAddonVersionsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeAddonVersionsCommandOutput) => void + ): void; + public describeAddonVersions( + args: DescribeAddonVersionsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeAddonVersionsCommandOutput) => void), + cb?: (err: any, data?: DescribeAddonVersionsCommandOutput) => void + ): Promise | void { + const command = new DescribeAddonVersionsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns descriptive information about an Amazon EKS cluster.

    *

    The API server endpoint and certificate authority data returned by this operation are @@ -525,6 +662,32 @@ export class EKS extends EKSClient { } } + /** + *

    Lists the available add-ons.

    + */ + public listAddons(args: ListAddonsCommandInput, options?: __HttpHandlerOptions): Promise; + public listAddons(args: ListAddonsCommandInput, cb: (err: any, data?: ListAddonsCommandOutput) => void): void; + public listAddons( + args: ListAddonsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListAddonsCommandOutput) => void + ): void; + public listAddons( + args: ListAddonsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListAddonsCommandOutput) => void), + cb?: (err: any, data?: ListAddonsCommandOutput) => void + ): Promise | void { + const command = new ListAddonsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Lists the Amazon EKS clusters in your AWS account in the specified Region.

    */ @@ -743,6 +906,32 @@ export class EKS extends EKSClient { } } + /** + *

    Updates an Amazon EKS add-on.

    + */ + public updateAddon(args: UpdateAddonCommandInput, options?: __HttpHandlerOptions): Promise; + public updateAddon(args: UpdateAddonCommandInput, cb: (err: any, data?: UpdateAddonCommandOutput) => void): void; + public updateAddon( + args: UpdateAddonCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateAddonCommandOutput) => void + ): void; + public updateAddon( + args: UpdateAddonCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateAddonCommandOutput) => void), + cb?: (err: any, data?: UpdateAddonCommandOutput) => void + ): Promise | void { + const command = new UpdateAddonCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates an Amazon EKS cluster configuration. Your cluster continues to function during the * update. The response output includes an update ID that you can use to track the status @@ -891,7 +1080,8 @@ export class EKS extends EKSClient { * AMI version of a node group's current Kubernetes version by not specifying a Kubernetes * version in the request. You can update to the latest AMI version of your cluster's * current Kubernetes version by specifying your cluster's Kubernetes version in the - * request. For more information, see Amazon EKS-Optimized Linux AMI Versions in the Amazon EKS User Guide.

    + * request. For more information, see Amazon EKS + * optimized Amazon Linux 2 AMI versions in the Amazon EKS User Guide.

    *

    You cannot roll back a node group to an earlier Kubernetes version or AMI * version.

    *

    When a node in a managed node group is terminated due to a scaling action or update, diff --git a/clients/client-eks/EKSClient.ts b/clients/client-eks/EKSClient.ts index 21ea7dfd25a8..0c4eea09e26b 100644 --- a/clients/client-eks/EKSClient.ts +++ b/clients/client-eks/EKSClient.ts @@ -1,15 +1,22 @@ +import { CreateAddonCommandInput, CreateAddonCommandOutput } from "./commands/CreateAddonCommand"; import { CreateClusterCommandInput, CreateClusterCommandOutput } from "./commands/CreateClusterCommand"; import { CreateFargateProfileCommandInput, CreateFargateProfileCommandOutput, } from "./commands/CreateFargateProfileCommand"; import { CreateNodegroupCommandInput, CreateNodegroupCommandOutput } from "./commands/CreateNodegroupCommand"; +import { DeleteAddonCommandInput, DeleteAddonCommandOutput } from "./commands/DeleteAddonCommand"; import { DeleteClusterCommandInput, DeleteClusterCommandOutput } from "./commands/DeleteClusterCommand"; import { DeleteFargateProfileCommandInput, DeleteFargateProfileCommandOutput, } from "./commands/DeleteFargateProfileCommand"; import { DeleteNodegroupCommandInput, DeleteNodegroupCommandOutput } from "./commands/DeleteNodegroupCommand"; +import { DescribeAddonCommandInput, DescribeAddonCommandOutput } from "./commands/DescribeAddonCommand"; +import { + DescribeAddonVersionsCommandInput, + DescribeAddonVersionsCommandOutput, +} from "./commands/DescribeAddonVersionsCommand"; import { DescribeClusterCommandInput, DescribeClusterCommandOutput } from "./commands/DescribeClusterCommand"; import { DescribeFargateProfileCommandInput, @@ -17,6 +24,7 @@ import { } from "./commands/DescribeFargateProfileCommand"; import { DescribeNodegroupCommandInput, DescribeNodegroupCommandOutput } from "./commands/DescribeNodegroupCommand"; import { DescribeUpdateCommandInput, DescribeUpdateCommandOutput } from "./commands/DescribeUpdateCommand"; +import { ListAddonsCommandInput, ListAddonsCommandOutput } from "./commands/ListAddonsCommand"; import { ListClustersCommandInput, ListClustersCommandOutput } from "./commands/ListClustersCommand"; import { ListFargateProfilesCommandInput, @@ -30,6 +38,7 @@ import { import { ListUpdatesCommandInput, ListUpdatesCommandOutput } from "./commands/ListUpdatesCommand"; import { TagResourceCommandInput, TagResourceCommandOutput } from "./commands/TagResourceCommand"; import { UntagResourceCommandInput, UntagResourceCommandOutput } from "./commands/UntagResourceCommand"; +import { UpdateAddonCommandInput, UpdateAddonCommandOutput } from "./commands/UpdateAddonCommand"; import { UpdateClusterConfigCommandInput, UpdateClusterConfigCommandOutput, @@ -96,16 +105,21 @@ import { } from "@aws-sdk/types"; export type ServiceInputTypes = + | CreateAddonCommandInput | CreateClusterCommandInput | CreateFargateProfileCommandInput | CreateNodegroupCommandInput + | DeleteAddonCommandInput | DeleteClusterCommandInput | DeleteFargateProfileCommandInput | DeleteNodegroupCommandInput + | DescribeAddonCommandInput + | DescribeAddonVersionsCommandInput | DescribeClusterCommandInput | DescribeFargateProfileCommandInput | DescribeNodegroupCommandInput | DescribeUpdateCommandInput + | ListAddonsCommandInput | ListClustersCommandInput | ListFargateProfilesCommandInput | ListNodegroupsCommandInput @@ -113,22 +127,28 @@ export type ServiceInputTypes = | ListUpdatesCommandInput | TagResourceCommandInput | UntagResourceCommandInput + | UpdateAddonCommandInput | UpdateClusterConfigCommandInput | UpdateClusterVersionCommandInput | UpdateNodegroupConfigCommandInput | UpdateNodegroupVersionCommandInput; export type ServiceOutputTypes = + | CreateAddonCommandOutput | CreateClusterCommandOutput | CreateFargateProfileCommandOutput | CreateNodegroupCommandOutput + | DeleteAddonCommandOutput | DeleteClusterCommandOutput | DeleteFargateProfileCommandOutput | DeleteNodegroupCommandOutput + | DescribeAddonCommandOutput + | DescribeAddonVersionsCommandOutput | DescribeClusterCommandOutput | DescribeFargateProfileCommandOutput | DescribeNodegroupCommandOutput | DescribeUpdateCommandOutput + | ListAddonsCommandOutput | ListClustersCommandOutput | ListFargateProfilesCommandOutput | ListNodegroupsCommandOutput @@ -136,6 +156,7 @@ export type ServiceOutputTypes = | ListUpdatesCommandOutput | TagResourceCommandOutput | UntagResourceCommandOutput + | UpdateAddonCommandOutput | UpdateClusterConfigCommandOutput | UpdateClusterVersionCommandOutput | UpdateNodegroupConfigCommandOutput diff --git a/clients/client-eks/commands/CreateAddonCommand.ts b/clients/client-eks/commands/CreateAddonCommand.ts new file mode 100644 index 000000000000..4a547a8ba3e6 --- /dev/null +++ b/clients/client-eks/commands/CreateAddonCommand.ts @@ -0,0 +1,93 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { CreateAddonRequest, CreateAddonResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateAddonCommand, + serializeAws_restJson1CreateAddonCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateAddonCommandInput = CreateAddonRequest; +export type CreateAddonCommandOutput = CreateAddonResponse & __MetadataBearer; + +/** + *

    Creates an Amazon EKS add-on.

    + *

    Amazon EKS add-ons help to automate the provisioning and lifecycle management of common + * operational software for Amazon EKS clusters. Amazon EKS add-ons can only be used with Amazon EKS + * clusters running version 1.18 with platform version eks.3 or later because + * add-ons rely on the Server-side Apply Kubernetes feature, which is only available in + * Kubernetes 1.18 and later.

    + */ +export class CreateAddonCommand extends $Command< + CreateAddonCommandInput, + CreateAddonCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateAddonCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "CreateAddonCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateAddonRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateAddonResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateAddonCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateAddonCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateAddonCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/CreateNodegroupCommand.ts b/clients/client-eks/commands/CreateNodegroupCommand.ts index 42d79f830f37..b116f4c4e232 100644 --- a/clients/client-eks/commands/CreateNodegroupCommand.ts +++ b/clients/client-eks/commands/CreateNodegroupCommand.ts @@ -28,8 +28,8 @@ export type CreateNodegroupCommandOutput = CreateNodegroupResponse & __MetadataB * template. For more information about using launch templates, see Launch * template support.

    *

    An Amazon EKS managed node group is an Amazon EC2 Auto Scaling group and associated Amazon EC2 instances that - * are managed by AWS for an Amazon EKS cluster. Each node group uses a version of the - * Amazon EKS-optimized Amazon Linux 2 AMI. For more information, see Managed + * are managed by AWS for an Amazon EKS cluster. Each node group uses a version of the Amazon EKS + * optimized Amazon Linux 2 AMI. For more information, see Managed * Node Groups in the Amazon EKS User Guide.

    */ export class CreateNodegroupCommand extends $Command< diff --git a/clients/client-eks/commands/DeleteAddonCommand.ts b/clients/client-eks/commands/DeleteAddonCommand.ts new file mode 100644 index 000000000000..0fc98a18106b --- /dev/null +++ b/clients/client-eks/commands/DeleteAddonCommand.ts @@ -0,0 +1,90 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { DeleteAddonRequest, DeleteAddonResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteAddonCommand, + serializeAws_restJson1DeleteAddonCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteAddonCommandInput = DeleteAddonRequest; +export type DeleteAddonCommandOutput = DeleteAddonResponse & __MetadataBearer; + +/** + *

    Delete an Amazon EKS add-on.

    + *

    When you remove the add-on, it will also be deleted from the cluster. You can always + * manually start an add-on on the cluster using the Kubernetes API.

    + */ +export class DeleteAddonCommand extends $Command< + DeleteAddonCommandInput, + DeleteAddonCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteAddonCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "DeleteAddonCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteAddonRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteAddonResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteAddonCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteAddonCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteAddonCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/DescribeAddonCommand.ts b/clients/client-eks/commands/DescribeAddonCommand.ts new file mode 100644 index 000000000000..54ddb5563d52 --- /dev/null +++ b/clients/client-eks/commands/DescribeAddonCommand.ts @@ -0,0 +1,88 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { DescribeAddonRequest, DescribeAddonResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeAddonCommand, + serializeAws_restJson1DescribeAddonCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeAddonCommandInput = DescribeAddonRequest; +export type DescribeAddonCommandOutput = DescribeAddonResponse & __MetadataBearer; + +/** + *

    Describes an Amazon EKS add-on.

    + */ +export class DescribeAddonCommand extends $Command< + DescribeAddonCommandInput, + DescribeAddonCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeAddonCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "DescribeAddonCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeAddonRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeAddonResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeAddonCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeAddonCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeAddonCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/DescribeAddonVersionsCommand.ts b/clients/client-eks/commands/DescribeAddonVersionsCommand.ts new file mode 100644 index 000000000000..b034243b3117 --- /dev/null +++ b/clients/client-eks/commands/DescribeAddonVersionsCommand.ts @@ -0,0 +1,88 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { DescribeAddonVersionsRequest, DescribeAddonVersionsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeAddonVersionsCommand, + serializeAws_restJson1DescribeAddonVersionsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeAddonVersionsCommandInput = DescribeAddonVersionsRequest; +export type DescribeAddonVersionsCommandOutput = DescribeAddonVersionsResponse & __MetadataBearer; + +/** + *

    Describes the Kubernetes versions that the add-on can be used with.

    + */ +export class DescribeAddonVersionsCommand extends $Command< + DescribeAddonVersionsCommandInput, + DescribeAddonVersionsCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeAddonVersionsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "DescribeAddonVersionsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeAddonVersionsRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeAddonVersionsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeAddonVersionsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeAddonVersionsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeAddonVersionsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/ListAddonsCommand.ts b/clients/client-eks/commands/ListAddonsCommand.ts new file mode 100644 index 000000000000..c0f15ae7db74 --- /dev/null +++ b/clients/client-eks/commands/ListAddonsCommand.ts @@ -0,0 +1,88 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { ListAddonsRequest, ListAddonsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListAddonsCommand, + serializeAws_restJson1ListAddonsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListAddonsCommandInput = ListAddonsRequest; +export type ListAddonsCommandOutput = ListAddonsResponse & __MetadataBearer; + +/** + *

    Lists the available add-ons.

    + */ +export class ListAddonsCommand extends $Command< + ListAddonsCommandInput, + ListAddonsCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListAddonsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "ListAddonsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListAddonsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListAddonsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListAddonsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListAddonsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListAddonsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/UpdateAddonCommand.ts b/clients/client-eks/commands/UpdateAddonCommand.ts new file mode 100644 index 000000000000..7372ccfe777b --- /dev/null +++ b/clients/client-eks/commands/UpdateAddonCommand.ts @@ -0,0 +1,88 @@ +import { EKSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EKSClient"; +import { UpdateAddonRequest, UpdateAddonResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateAddonCommand, + serializeAws_restJson1UpdateAddonCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateAddonCommandInput = UpdateAddonRequest; +export type UpdateAddonCommandOutput = UpdateAddonResponse & __MetadataBearer; + +/** + *

    Updates an Amazon EKS add-on.

    + */ +export class UpdateAddonCommand extends $Command< + UpdateAddonCommandInput, + UpdateAddonCommandOutput, + EKSClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateAddonCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: EKSClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "EKSClient"; + const commandName = "UpdateAddonCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateAddonRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateAddonResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateAddonCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateAddonCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateAddonCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-eks/commands/UpdateNodegroupVersionCommand.ts b/clients/client-eks/commands/UpdateNodegroupVersionCommand.ts index 6500403fc73c..ee773f1bb754 100644 --- a/clients/client-eks/commands/UpdateNodegroupVersionCommand.ts +++ b/clients/client-eks/commands/UpdateNodegroupVersionCommand.ts @@ -31,7 +31,8 @@ export type UpdateNodegroupVersionCommandOutput = UpdateNodegroupVersionResponse * AMI version of a node group's current Kubernetes version by not specifying a Kubernetes * version in the request. You can update to the latest AMI version of your cluster's * current Kubernetes version by specifying your cluster's Kubernetes version in the - * request. For more information, see Amazon EKS-Optimized Linux AMI Versions in the Amazon EKS User Guide.

    + * request. For more information, see Amazon EKS + * optimized Amazon Linux 2 AMI versions in the Amazon EKS User Guide.

    *

    You cannot roll back a node group to an earlier Kubernetes version or AMI * version.

    *

    When a node in a managed node group is terminated due to a scaling action or update, diff --git a/clients/client-eks/index.ts b/clients/client-eks/index.ts index 9d5d5676ab6e..27272cbed53a 100644 --- a/clients/client-eks/index.ts +++ b/clients/client-eks/index.ts @@ -1,15 +1,22 @@ export * from "./EKSClient"; export * from "./EKS"; +export * from "./commands/CreateAddonCommand"; export * from "./commands/CreateClusterCommand"; export * from "./commands/CreateFargateProfileCommand"; export * from "./commands/CreateNodegroupCommand"; +export * from "./commands/DeleteAddonCommand"; export * from "./commands/DeleteClusterCommand"; export * from "./commands/DeleteFargateProfileCommand"; export * from "./commands/DeleteNodegroupCommand"; +export * from "./commands/DescribeAddonCommand"; +export * from "./commands/DescribeAddonVersionsCommand"; +export * from "./pagination/DescribeAddonVersionsPaginator"; export * from "./commands/DescribeClusterCommand"; export * from "./commands/DescribeFargateProfileCommand"; export * from "./commands/DescribeNodegroupCommand"; export * from "./commands/DescribeUpdateCommand"; +export * from "./commands/ListAddonsCommand"; +export * from "./pagination/ListAddonsPaginator"; export * from "./commands/ListClustersCommand"; export * from "./pagination/ListClustersPaginator"; export * from "./commands/ListFargateProfilesCommand"; @@ -21,6 +28,7 @@ export * from "./commands/ListUpdatesCommand"; export * from "./pagination/ListUpdatesPaginator"; export * from "./commands/TagResourceCommand"; export * from "./commands/UntagResourceCommand"; +export * from "./commands/UpdateAddonCommand"; export * from "./commands/UpdateClusterConfigCommand"; export * from "./commands/UpdateClusterVersionCommand"; export * from "./commands/UpdateNodegroupConfigCommand"; diff --git a/clients/client-eks/models/models_0.ts b/clients/client-eks/models/models_0.ts index 814c9a87244f..ea4d68c8e352 100644 --- a/clients/client-eks/models/models_0.ts +++ b/clients/client-eks/models/models_0.ts @@ -1,6 +1,209 @@ import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; +export enum AddonIssueCode { + ACCESS_DENIED = "AccessDenied", + CLUSTER_UNREACHABLE = "ClusterUnreachable", + CONFIGURATION_CONFLICT = "ConfigurationConflict", + INSUFFICIENT_NUMBER_OF_REPLICAS = "InsufficientNumberOfReplicas", + INTERNAL_FAILURE = "InternalFailure", +} + +/** + *

    An issue related to an add-on.

    + */ +export interface AddonIssue { + /** + *

    A code that describes the type of issue.

    + */ + code?: AddonIssueCode | string; + + /** + *

    A message that provides details about the issue and what might cause it.

    + */ + message?: string; + + /** + *

    The resource IDs of the issue.

    + */ + resourceIds?: string[]; +} + +export namespace AddonIssue { + export const filterSensitiveLog = (obj: AddonIssue): any => ({ + ...obj, + }); +} + +/** + *

    The health of the add-on.

    + */ +export interface AddonHealth { + /** + *

    An object that represents the add-on's health issues.

    + */ + issues?: AddonIssue[]; +} + +export namespace AddonHealth { + export const filterSensitiveLog = (obj: AddonHealth): any => ({ + ...obj, + }); +} + +export type AddonStatus = + | "ACTIVE" + | "CREATE_FAILED" + | "CREATING" + | "DEGRADED" + | "DELETE_FAILED" + | "DELETING" + | "UPDATING"; + +/** + *

    An Amazon EKS add-on.

    + */ +export interface Addon { + /** + *

    The name of the add-on.

    + */ + addonName?: string; + + /** + *

    The name of the cluster.

    + */ + clusterName?: string; + + /** + *

    The status of the add-on.

    + */ + status?: AddonStatus | string; + + /** + *

    The version of the add-on.

    + */ + addonVersion?: string; + + /** + *

    An object that represents the health of the add-on.

    + */ + health?: AddonHealth; + + /** + *

    The Amazon Resource Name (ARN) of the add-on.

    + */ + addonArn?: string; + + /** + *

    The date and time that the add-on was created.

    + */ + createdAt?: Date; + + /** + *

    The date and time that the add-on was last modified.

    + */ + modifiedAt?: Date; + + /** + *

    The Amazon Resource Name (ARN) of the IAM role that is bound to the Kubernetes service account used + * by the add-on.

    + */ + serviceAccountRoleArn?: string; + + /** + *

    The metadata that you apply to the cluster to assist with categorization and + * organization. Each tag consists of a key and an optional value, both of which you + * define. Cluster tags do not propagate to any other resources associated with the + * cluster.

    + */ + tags?: { [key: string]: string }; +} + +export namespace Addon { + export const filterSensitiveLog = (obj: Addon): any => ({ + ...obj, + }); +} + +/** + *

    Compatibility information.

    + */ +export interface Compatibility { + /** + *

    The supported Kubernetes version of the cluster.

    + */ + clusterVersion?: string; + + /** + *

    The supported compute platform.

    + */ + platformVersions?: string[]; + + /** + *

    The supported default version.

    + */ + defaultVersion?: boolean; +} + +export namespace Compatibility { + export const filterSensitiveLog = (obj: Compatibility): any => ({ + ...obj, + }); +} + +/** + *

    Information about an add-on version.

    + */ +export interface AddonVersionInfo { + /** + *

    The version of the add-on.

    + */ + addonVersion?: string; + + /** + *

    The architectures that the version supports.

    + */ + architecture?: string[]; + + /** + *

    An object that represents the compatibilities of a version.

    + */ + compatibilities?: Compatibility[]; +} + +export namespace AddonVersionInfo { + export const filterSensitiveLog = (obj: AddonVersionInfo): any => ({ + ...obj, + }); +} + +/** + *

    Information about an add-on.

    + */ +export interface AddonInfo { + /** + *

    The name of the add-on.

    + */ + addonName?: string; + + /** + *

    The type of the add-on.

    + */ + type?: string; + + /** + *

    An object that represents information about available add-on versions and compatible + * Kubernetes versions.

    + */ + addonVersions?: AddonVersionInfo[]; +} + +export namespace AddonInfo { + export const filterSensitiveLog = (obj: AddonInfo): any => ({ + ...obj, + }); +} + export type AMITypes = "AL2_ARM_64" | "AL2_x86_64" | "AL2_x86_64_GPU"; /** @@ -27,20 +230,239 @@ export namespace AutoScalingGroup { export interface ClientException extends __SmithyException, $MetadataBearer { name: "ClientException"; $fault: "client"; + /** + *

    The Amazon EKS cluster associated with the exception.

    + */ + clusterName?: string; + + /** + *

    The Amazon EKS managed node group associated with the exception.

    + */ + nodegroupName?: string; + + addonName?: string; + message?: string; +} + +export namespace ClientException { + export const filterSensitiveLog = (obj: ClientException): any => ({ + ...obj, + }); +} + +export type ResolveConflicts = "NONE" | "OVERWRITE"; + +export interface CreateAddonRequest { + /** + *

    The name of the cluster to create the add-on for.

    + */ + clusterName: string | undefined; + + /** + *

    The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

    + */ + addonName: string | undefined; + + /** + *

    The version of the add-on. The version must match one of the versions returned by + * DescribeAddonVersions + * .

    + */ + addonVersion?: string; + + /** + *

    The Amazon Resource Name (ARN) of an existing IAM role to bind to the add-on's service account. The role must be assigned the IAM permissions required by the add-on. If you don't specify an existing IAM role, then the add-on uses the + * permissions assigned to the node IAM role. For more information, see Amazon EKS node IAM role in the Amazon EKS User Guide.

    + * + *

    To specify an existing IAM role, you must have an IAM OpenID Connect (OIDC) provider created for + * your cluster. For more information, see Enabling + * IAM roles for service accounts on your cluster in the + * Amazon EKS User Guide.

    + *
    + */ + serviceAccountRoleArn?: string; + + /** + *

    How to resolve parameter value conflicts when migrating an existing add-on to an + * Amazon EKS add-on.

    + */ + resolveConflicts?: ResolveConflicts | string; + + /** + *

    A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

    + */ + clientRequestToken?: string; + + /** + *

    The metadata to apply to the cluster to assist with categorization and organization. + * Each tag consists of a key and an optional value, both of which you define.

    + */ + tags?: { [key: string]: string }; +} + +export namespace CreateAddonRequest { + export const filterSensitiveLog = (obj: CreateAddonRequest): any => ({ + ...obj, + }); +} + +export interface CreateAddonResponse { + /** + *

    An Amazon EKS add-on.

    + */ + addon?: Addon; +} + +export namespace CreateAddonResponse { + export const filterSensitiveLog = (obj: CreateAddonResponse): any => ({ + ...obj, + }); +} + +/** + *

    The specified parameter is invalid. Review the available parameters for the API + * request.

    + */ +export interface InvalidParameterException extends __SmithyException, $MetadataBearer { + name: "InvalidParameterException"; + $fault: "client"; + /** + *

    The Amazon EKS cluster associated with the exception.

    + */ + clusterName?: string; + /** *

    The Amazon EKS managed node group associated with the exception.

    */ nodegroupName?: string; + /** + *

    The Fargate profile associated with the exception.

    + */ + fargateProfileName?: string; + + addonName?: string; message?: string; +} + +export namespace InvalidParameterException { + export const filterSensitiveLog = (obj: InvalidParameterException): any => ({ + ...obj, + }); +} + +/** + *

    The request is invalid given the state of the cluster. Check the state of the cluster + * and the associated operations.

    + */ +export interface InvalidRequestException extends __SmithyException, $MetadataBearer { + name: "InvalidRequestException"; + $fault: "client"; /** *

    The Amazon EKS cluster associated with the exception.

    */ clusterName?: string; + + /** + *

    The Amazon EKS managed node group associated with the exception.

    + */ + nodegroupName?: string; + + addonName?: string; + message?: string; } -export namespace ClientException { - export const filterSensitiveLog = (obj: ClientException): any => ({ +export namespace InvalidRequestException { + export const filterSensitiveLog = (obj: InvalidRequestException): any => ({ + ...obj, + }); +} + +/** + *

    The specified resource is in use.

    + */ +export interface ResourceInUseException extends __SmithyException, $MetadataBearer { + name: "ResourceInUseException"; + $fault: "client"; + /** + *

    The Amazon EKS cluster associated with the exception.

    + */ + clusterName?: string; + + /** + *

    The Amazon EKS managed node group associated with the exception.

    + */ + nodegroupName?: string; + + addonName?: string; + message?: string; +} + +export namespace ResourceInUseException { + export const filterSensitiveLog = (obj: ResourceInUseException): any => ({ + ...obj, + }); +} + +/** + *

    The specified resource could not be found. You can view your available clusters with + * ListClusters. You can view your available managed node groups with + * ListNodegroups. Amazon EKS clusters and node groups are + * Region-specific.

    + */ +export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { + name: "ResourceNotFoundException"; + $fault: "client"; + /** + *

    The Amazon EKS cluster associated with the exception.

    + */ + clusterName?: string; + + /** + *

    The Amazon EKS managed node group associated with the exception.

    + */ + nodegroupName?: string; + + /** + *

    The Fargate profile associated with the exception.

    + */ + fargateProfileName?: string; + + addonName?: string; + message?: string; +} + +export namespace ResourceNotFoundException { + export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

    These errors are usually caused by a server-side issue.

    + */ +export interface ServerException extends __SmithyException, $MetadataBearer { + name: "ServerException"; + $fault: "server"; + /** + *

    The Amazon EKS cluster associated with the exception.

    + */ + clusterName?: string; + + /** + *

    The Amazon EKS managed node group associated with the exception.

    + */ + nodegroupName?: string; + + addonName?: string; + message?: string; +} + +export namespace ServerException { + export const filterSensitiveLog = (obj: ServerException): any => ({ ...obj, }); } @@ -93,22 +515,28 @@ export namespace EncryptionConfig { */ export interface KubernetesNetworkConfigRequest { /** - *

    The CIDR block to assign Kubernetes service IP addresses from. If you don't specify a block, Kubernetes assigns addresses from either the 10.100.0.0/16 or 172.20.0.0/16 CIDR blocks. We recommend that you specify a block that does not overlap with resources in other networks - * that are peered or connected to your VPC. The block must meet the following requirements:

    - *
      + *

      The CIDR block to assign Kubernetes service IP addresses from. If you don't specify a + * block, Kubernetes assigns addresses from either the 10.100.0.0/16 or 172.20.0.0/16 CIDR + * blocks. We recommend that you specify a block that does not overlap with resources in + * other networks that are peered or connected to your VPC. The block must meet the + * following requirements:

      + *
        *
      • - *

        Within one of the following private IP address blocks: 10.0.0.0/8, 172.16.0.0.0/12, or 192.168.0.0/16.

        + *

        Within one of the following private IP address blocks: 10.0.0.0/8, + * 172.16.0.0.0/12, or 192.168.0.0/16.

        *
      • *
      • - *

        Doesn't overlap with any CIDR block assigned to the VPC that you selected for VPC.

        + *

        Doesn't overlap with any CIDR block assigned to the VPC that you selected for + * VPC.

        *
      • *
      • - *

        Between /24 and /12.

        + *

        Between /24 and /12.

        *
      • *
      * - *

      You can only specify a custom CIDR block when you create a cluster and can't change this value once the cluster is created.

      - *
      + *

      You can only specify a custom CIDR block when you create a cluster and can't + * change this value once the cluster is created.

      + * */ serviceIpv4Cidr?: string; } @@ -132,17 +560,17 @@ export enum LogType { * cluster.

      */ export interface LogSetup { + /** + *

      The available cluster control plane log types.

      + */ + types?: (LogType | string)[]; + /** *

      If a log type is enabled, that log type exports its control plane logs to CloudWatch Logs. If a * log type isn't enabled, that log type doesn't export its control plane logs. Each * individual log type can be enabled or disabled independently.

      */ enabled?: boolean; - - /** - *

      The available cluster control plane log types.

      - */ - types?: (LogType | string)[]; } export namespace LogSetup { @@ -171,14 +599,46 @@ export namespace Logging { *

      An object representing the VPC configuration to use for an Amazon EKS cluster.

      */ export interface VpcConfigRequest { + /** + *

      Specify subnets for your Amazon EKS worker nodes. Amazon EKS creates cross-account elastic + * network interfaces in these subnets to allow communication between your worker nodes and + * the Kubernetes control plane.

      + */ + subnetIds?: string[]; + /** *

      Specify one or more security groups for the cross-account elastic network interfaces * that Amazon EKS creates to use to allow communication between your worker nodes and the - * Kubernetes control plane. If you don't specify a security group, the default security - * group for your VPC is used.

      + * Kubernetes control plane. If you don't specify any security groups, then familiarize + * yourself with the difference between Amazon EKS defaults for clusters deployed with + * Kubernetes:

      + *
        + *
      • + *

        1.14 Amazon EKS platform version eks.2 and earlier

        + *
      • + *
      • + *

        1.14 Amazon EKS platform version eks.3 and later

        + *
      • + *
      + *

      For more information, see Amazon EKS security group + * considerations in the + * Amazon EKS User Guide + * .

      */ securityGroupIds?: string[]; + /** + *

      Set this value to false to disable public access to your cluster's + * Kubernetes API server endpoint. If you disable public access, your cluster's Kubernetes + * API server can only receive requests from within the cluster VPC. The default value for + * this parameter is true, which enables public access for your Kubernetes API + * server. For more information, see Amazon EKS Cluster + * Endpoint Access Control in the + * Amazon EKS User Guide + * .

      + */ + endpointPublicAccess?: boolean; + /** *

      Set this value to true to enable private access for your cluster's * Kubernetes API server endpoint. If you enable private access, Kubernetes API requests @@ -195,18 +655,6 @@ export interface VpcConfigRequest { */ endpointPrivateAccess?: boolean; - /** - *

      Set this value to false to disable public access to your cluster's - * Kubernetes API server endpoint. If you disable public access, your cluster's Kubernetes - * API server can only receive requests from within the cluster VPC. The default value for - * this parameter is true, which enables public access for your Kubernetes API - * server. For more information, see Amazon EKS Cluster - * Endpoint Access Control in the - * Amazon EKS User Guide - * .

      - */ - endpointPublicAccess?: boolean; - /** *

      The CIDR blocks that are allowed access to your cluster's public Kubernetes API server * endpoint. Communication to the endpoint from addresses outside of the CIDR blocks that @@ -218,13 +666,6 @@ export interface VpcConfigRequest { * .

      */ publicAccessCidrs?: string[]; - - /** - *

      Specify subnets for your Amazon EKS worker nodes. Amazon EKS creates cross-account elastic - * network interfaces in these subnets to allow communication between your worker nodes and - * the Kubernetes control plane.

      - */ - subnetIds?: string[]; } export namespace VpcConfigRequest { @@ -235,9 +676,25 @@ export namespace VpcConfigRequest { export interface CreateClusterRequest { /** - *

      The encryption configuration for the cluster.

      + *

      The unique name to give to your cluster.

      */ - encryptionConfig?: EncryptionConfig[]; + name: string | undefined; + + /** + *

      The desired Kubernetes version for your cluster. If you don't specify a value here, + * the latest version available in Amazon EKS is used.

      + */ + version?: string; + + /** + *

      The Amazon Resource Name (ARN) of the IAM role that provides permissions for the Kubernetes control + * plane to make calls to AWS API operations on your behalf. For more information, see + * Amazon EKS + * Service IAM Role in the + * Amazon EKS User Guide + * .

      + */ + roleArn: string | undefined; /** *

      The VPC configuration used by the cluster control plane. Amazon EKS VPC resources have @@ -249,6 +706,11 @@ export interface CreateClusterRequest { */ resourcesVpcConfig: VpcConfigRequest | undefined; + /** + *

      The Kubernetes network configuration for the cluster.

      + */ + kubernetesNetworkConfig?: KubernetesNetworkConfigRequest; + /** *

      Enable or disable exporting the Kubernetes control plane logs for your cluster to * CloudWatch Logs. By default, cluster control plane logs aren't exported to CloudWatch Logs. For more @@ -269,27 +731,6 @@ export interface CreateClusterRequest { */ clientRequestToken?: string; - /** - *

      The Amazon Resource Name (ARN) of the IAM role that provides permissions for the Kubernetes control - * plane to make calls to AWS API operations on your behalf. For more information, see - * Amazon EKS - * Service IAM Role in the - * Amazon EKS User Guide - * .

      - */ - roleArn: string | undefined; - - /** - *

      The Kubernetes network configuration for the cluster.

      - */ - kubernetesNetworkConfig?: KubernetesNetworkConfigRequest; - - /** - *

      The desired Kubernetes version for your cluster. If you don't specify a value here, - * the latest version available in Amazon EKS is used.

      - */ - version?: string; - /** *

      The metadata to apply to the cluster to assist with categorization and organization. * Each tag consists of a key and an optional value, both of which you define.

      @@ -297,9 +738,9 @@ export interface CreateClusterRequest { tags?: { [key: string]: string }; /** - *

      The unique name to give to your cluster.

      + *

      The encryption configuration for the cluster.

      */ - name: string | undefined; + encryptionConfig?: EncryptionConfig[]; } export namespace CreateClusterRequest { @@ -366,8 +807,10 @@ export namespace Identity { */ export interface KubernetesNetworkConfigResponse { /** - *

      The CIDR block that Kubernetes service IP addresses are assigned from. If you didn't specify a CIDR block, then Kubernetes assigns addresses from either the 10.100.0.0/16 or 172.20.0.0/16 CIDR blocks. If this was specified, then it was specified when the cluster was created and it - * cannot be changed.

      + *

      The CIDR block that Kubernetes service IP addresses are assigned from. If you didn't + * specify a CIDR block when you created the cluster, then Kubernetes assigns addresses + * from either the 10.100.0.0/16 or 172.20.0.0/16 CIDR blocks. If this was specified, then + * it was specified when the cluster was created and it cannot be changed.

      */ serviceIpv4Cidr?: string; } @@ -383,9 +826,16 @@ export namespace KubernetesNetworkConfigResponse { */ export interface VpcConfigResponse { /** - *

      The VPC associated with your cluster.

      + *

      The subnets associated with your cluster.

      */ - vpcId?: string; + subnetIds?: string[]; + + /** + *

      The security groups associated with the cross-account elastic network interfaces that + * are used to allow communication between your worker nodes and the Kubernetes control + * plane.

      + */ + securityGroupIds?: string[]; /** *

      The cluster security group that was created by Amazon EKS for the cluster. Managed node @@ -394,16 +844,9 @@ export interface VpcConfigResponse { clusterSecurityGroupId?: string; /** - *

      The CIDR blocks that are allowed access to your cluster's public Kubernetes API server - * endpoint. Communication to the endpoint from addresses outside of the listed CIDR blocks - * is denied. The default value is 0.0.0.0/0. If you've disabled private - * endpoint access and you have worker nodes or AWS Fargate pods in the cluster, then ensure - * that the necessary CIDR blocks are listed. For more information, see Amazon EKS Cluster - * Endpoint Access Control in the - * Amazon EKS User Guide - * .

      + *

      The VPC associated with your cluster.

      */ - publicAccessCidrs?: string[]; + vpcId?: string; /** *

      This parameter indicates whether the Amazon EKS public API server endpoint is enabled. If @@ -412,18 +855,6 @@ export interface VpcConfigResponse { */ endpointPublicAccess?: boolean; - /** - *

      The subnets associated with your cluster.

      - */ - subnetIds?: string[]; - - /** - *

      The security groups associated with the cross-account elastic network interfaces that - * are used to allow communication between your worker nodes and the Kubernetes control - * plane.

      - */ - securityGroupIds?: string[]; - /** *

      This parameter indicates whether the Amazon EKS private API server endpoint is enabled. If * the Amazon EKS private API server endpoint is enabled, Kubernetes API requests that originate @@ -438,6 +869,18 @@ export interface VpcConfigResponse { * .

      */ endpointPrivateAccess?: boolean; + + /** + *

      The CIDR blocks that are allowed access to your cluster's public Kubernetes API server + * endpoint. Communication to the endpoint from addresses outside of the listed CIDR blocks + * is denied. The default value is 0.0.0.0/0. If you've disabled private + * endpoint access and you have worker nodes or AWS Fargate pods in the cluster, then ensure + * that the necessary CIDR blocks are listed. For more information, see Amazon EKS Cluster + * Endpoint Access Control in the + * Amazon EKS User Guide + * .

      + */ + publicAccessCidrs?: string[]; } export namespace VpcConfigResponse { @@ -453,17 +896,14 @@ export type ClusterStatus = "ACTIVE" | "CREATING" | "DELETING" | "FAILED" | "UPD */ export interface Cluster { /** - *

      The endpoint for your Kubernetes API server.

      + *

      The name of the cluster.

      */ - endpoint?: string; + name?: string; /** - *

      The VPC configuration used by the cluster control plane. Amazon EKS VPC resources have - * specific requirements to work properly with Kubernetes. For more information, see Cluster VPC - * Considerations and Cluster Security Group Considerations in the - * Amazon EKS User Guide.

      + *

      The Amazon Resource Name (ARN) of the cluster.

      */ - resourcesVpcConfig?: VpcConfigResponse; + arn?: string; /** *

      The Unix epoch timestamp in seconds for when the cluster was created.

      @@ -471,34 +911,38 @@ export interface Cluster { createdAt?: Date; /** - *

      The current status of the cluster.

      + *

      The Kubernetes server version for the cluster.

      */ - status?: ClusterStatus | string; + version?: string; /** - *

      Network configuration settings for your cluster.

      + *

      The endpoint for your Kubernetes API server.

      */ - kubernetesNetworkConfig?: KubernetesNetworkConfigResponse; + endpoint?: string; /** - *

      The certificate-authority-data for your cluster.

      + *

      The Amazon Resource Name (ARN) of the IAM role that provides permissions for the Kubernetes control + * plane to make calls to AWS API operations on your behalf.

      */ - certificateAuthority?: Certificate; + roleArn?: string; /** - *

      The logging configuration for your cluster.

      + *

      The VPC configuration used by the cluster control plane. Amazon EKS VPC resources have + * specific requirements to work properly with Kubernetes. For more information, see Cluster VPC + * Considerations and Cluster Security Group Considerations in the + * Amazon EKS User Guide.

      */ - logging?: Logging; + resourcesVpcConfig?: VpcConfigResponse; /** - *

      The name of the cluster.

      + *

      The Kubernetes network configuration for the cluster.

      */ - name?: string; + kubernetesNetworkConfig?: KubernetesNetworkConfigResponse; /** - *

      The Amazon Resource Name (ARN) of the cluster.

      + *

      The logging configuration for your cluster.

      */ - arn?: string; + logging?: Logging; /** *

      The identity provider information for the cluster.

      @@ -506,23 +950,20 @@ export interface Cluster { identity?: Identity; /** - *

      The Amazon Resource Name (ARN) of the IAM role that provides permissions for the Kubernetes control - * plane to make calls to AWS API operations on your behalf.

      + *

      The current status of the cluster.

      */ - roleArn?: string; + status?: ClusterStatus | string; /** - *

      The encryption configuration for the cluster.

      + *

      The certificate-authority-data for your cluster.

      */ - encryptionConfig?: EncryptionConfig[]; + certificateAuthority?: Certificate; /** - *

      The metadata that you apply to the cluster to assist with categorization and - * organization. Each tag consists of a key and an optional value, both of which you - * define. Cluster tags do not propagate to any other resources associated with the - * cluster.

      + *

      Unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

      */ - tags?: { [key: string]: string }; + clientRequestToken?: string; /** *

      The platform version of your Amazon EKS cluster. For more information, see Platform @@ -533,15 +974,17 @@ export interface Cluster { platformVersion?: string; /** - *

      Unique, case-sensitive identifier that you provide to ensure the idempotency of the - * request.

      + *

      The metadata that you apply to the cluster to assist with categorization and + * organization. Each tag consists of a key and an optional value, both of which you + * define. Cluster tags do not propagate to any other resources associated with the + * cluster.

      */ - clientRequestToken?: string; + tags?: { [key: string]: string }; /** - *

      The Kubernetes server version for the cluster.

      + *

      The encryption configuration for the cluster.

      */ - version?: string; + encryptionConfig?: EncryptionConfig[]; } export namespace Cluster { @@ -563,60 +1006,6 @@ export namespace CreateClusterResponse { }); } -/** - *

      The specified parameter is invalid. Review the available parameters for the API - * request.

      - */ -export interface InvalidParameterException extends __SmithyException, $MetadataBearer { - name: "InvalidParameterException"; - $fault: "client"; - message?: string; - /** - *

      The Fargate profile associated with the exception.

      - */ - fargateProfileName?: string; - - /** - *

      The Amazon EKS managed node group associated with the exception.

      - */ - nodegroupName?: string; - - /** - *

      The Amazon EKS cluster associated with the exception.

      - */ - clusterName?: string; -} - -export namespace InvalidParameterException { - export const filterSensitiveLog = (obj: InvalidParameterException): any => ({ - ...obj, - }); -} - -/** - *

      The specified resource is in use.

      - */ -export interface ResourceInUseException extends __SmithyException, $MetadataBearer { - name: "ResourceInUseException"; - $fault: "client"; - message?: string; - /** - *

      The Amazon EKS managed node group associated with the exception.

      - */ - nodegroupName?: string; - - /** - *

      The Amazon EKS cluster associated with the exception.

      - */ - clusterName?: string; -} - -export namespace ResourceInUseException { - export const filterSensitiveLog = (obj: ResourceInUseException): any => ({ - ...obj, - }); -} - /** *

      You have encountered a service limit on the specified resource.

      */ @@ -642,30 +1031,6 @@ export namespace ResourceLimitExceededException { }); } -/** - *

      These errors are usually caused by a server-side issue.

      - */ -export interface ServerException extends __SmithyException, $MetadataBearer { - name: "ServerException"; - $fault: "server"; - message?: string; - /** - *

      The Amazon EKS managed node group associated with the exception.

      - */ - nodegroupName?: string; - - /** - *

      The Amazon EKS cluster associated with the exception.

      - */ - clusterName?: string; -} - -export namespace ServerException { - export const filterSensitiveLog = (obj: ServerException): any => ({ - ...obj, - }); -} - /** *

      The service is unavailable. Back off and retry the operation.

      */ @@ -689,12 +1054,7 @@ export namespace ServiceUnavailableException { export interface UnsupportedAvailabilityZoneException extends __SmithyException, $MetadataBearer { name: "UnsupportedAvailabilityZoneException"; $fault: "client"; - /** - *

      The supported Availability Zones for your account. Choose subnets in these - * Availability Zones for your cluster.

      - */ - validZones?: string[]; - + message?: string; /** *

      The Amazon EKS cluster associated with the exception.

      */ @@ -705,7 +1065,11 @@ export interface UnsupportedAvailabilityZoneException extends __SmithyException, */ nodegroupName?: string; - message?: string; + /** + *

      The supported Availability Zones for your account. Choose subnets in these + * Availability Zones for your cluster.

      + */ + validZones?: string[]; } export namespace UnsupportedAvailabilityZoneException { @@ -719,15 +1083,15 @@ export namespace UnsupportedAvailabilityZoneException { */ export interface FargateProfileSelector { /** - *

      The Kubernetes labels that the selector should match. A pod must contain all of the - * labels that are specified in the selector for it to be considered a match.

      + *

      The Kubernetes namespace that the selector should match.

      */ - labels?: { [key: string]: string }; + namespace?: string; /** - *

      The Kubernetes namespace that the selector should match.

      + *

      The Kubernetes labels that the selector should match. A pod must contain all of the + * labels that are specified in the selector for it to be considered a match.

      */ - namespace?: string; + labels?: { [key: string]: string }; } export namespace FargateProfileSelector { @@ -743,11 +1107,18 @@ export interface CreateFargateProfileRequest { fargateProfileName: string | undefined; /** - *

      The selectors to match for pods to use this Fargate profile. Each selector must have an - * associated namespace. Optionally, you can also specify labels for a namespace. You may - * specify up to five selectors in a Fargate profile.

      + *

      The name of the Amazon EKS cluster to apply the Fargate profile to.

      */ - selectors?: FargateProfileSelector[]; + clusterName: string | undefined; + + /** + *

      The Amazon Resource Name (ARN) of the pod execution role to use for pods that match the selectors in + * the Fargate profile. The pod execution role allows Fargate infrastructure to register with + * your cluster as a node, and it provides read access to Amazon ECR image repositories. For + * more information, see Pod Execution Role in the + * Amazon EKS User Guide.

      + */ + podExecutionRoleArn: string | undefined; /** *

      The IDs of subnets to launch your pods into. At this time, pods running on Fargate are @@ -757,17 +1128,11 @@ export interface CreateFargateProfileRequest { subnets?: string[]; /** - *

      The metadata to apply to the Fargate profile to assist with categorization and - * organization. Each tag consists of a key and an optional value, both of which you - * define. Fargate profile tags do not propagate to any other resources associated with the - * Fargate profile, such as the pods that are scheduled with it.

      - */ - tags?: { [key: string]: string }; - - /** - *

      The name of the Amazon EKS cluster to apply the Fargate profile to.

      + *

      The selectors to match for pods to use this Fargate profile. Each selector must have an + * associated namespace. Optionally, you can also specify labels for a namespace. You may + * specify up to five selectors in a Fargate profile.

      */ - clusterName: string | undefined; + selectors?: FargateProfileSelector[]; /** *

      Unique, case-sensitive identifier that you provide to ensure the idempotency of the @@ -776,13 +1141,12 @@ export interface CreateFargateProfileRequest { clientRequestToken?: string; /** - *

      The Amazon Resource Name (ARN) of the pod execution role to use for pods that match the selectors in - * the Fargate profile. The pod execution role allows Fargate infrastructure to register with - * your cluster as a node, and it provides read access to Amazon ECR image repositories. For - * more information, see Pod Execution Role in the - * Amazon EKS User Guide.

      + *

      The metadata to apply to the Fargate profile to assist with categorization and + * organization. Each tag consists of a key and an optional value, both of which you + * define. Fargate profile tags do not propagate to any other resources associated with the + * Fargate profile, such as the pods that are scheduled with it.

      */ - podExecutionRoleArn: string | undefined; + tags?: { [key: string]: string }; } export namespace CreateFargateProfileRequest { @@ -797,26 +1161,26 @@ export type FargateProfileStatus = "ACTIVE" | "CREATE_FAILED" | "CREATING" | "DE *

      An object representing an AWS Fargate profile.

      */ export interface FargateProfile { - /** - *

      The Unix epoch timestamp in seconds for when the Fargate profile was created.

      - */ - createdAt?: Date; - /** *

      The name of the Fargate profile.

      */ fargateProfileName?: string; /** - *

      The selectors to match for pods to use this Fargate profile.

      + *

      The full Amazon Resource Name (ARN) of the Fargate profile.

      */ - selectors?: FargateProfileSelector[]; + fargateProfileArn?: string; /** *

      The name of the Amazon EKS cluster that the Fargate profile belongs to.

      */ clusterName?: string; + /** + *

      The Unix epoch timestamp in seconds for when the Fargate profile was created.

      + */ + createdAt?: Date; + /** *

      The Amazon Resource Name (ARN) of the pod execution role to use for pods that match the selectors in * the Fargate profile. For more information, see Pod @@ -825,27 +1189,27 @@ export interface FargateProfile { podExecutionRoleArn?: string; /** - *

      The metadata applied to the Fargate profile to assist with categorization and - * organization. Each tag consists of a key and an optional value, both of which you - * define. Fargate profile tags do not propagate to any other resources associated with the - * Fargate profile, such as the pods that are scheduled with it.

      + *

      The IDs of subnets to launch pods into.

      */ - tags?: { [key: string]: string }; + subnets?: string[]; /** - *

      The current status of the Fargate profile.

      + *

      The selectors to match for pods to use this Fargate profile.

      */ - status?: FargateProfileStatus | string; + selectors?: FargateProfileSelector[]; /** - *

      The full Amazon Resource Name (ARN) of the Fargate profile.

      + *

      The current status of the Fargate profile.

      */ - fargateProfileArn?: string; + status?: FargateProfileStatus | string; /** - *

      The IDs of subnets to launch pods into.

      + *

      The metadata applied to the Fargate profile to assist with categorization and + * organization. Each tag consists of a key and an optional value, both of which you + * define. Fargate profile tags do not propagate to any other resources associated with the + * Fargate profile, such as the pods that are scheduled with it.

      */ - subnets?: string[]; + tags?: { [key: string]: string }; } export namespace FargateProfile { @@ -862,36 +1226,13 @@ export interface CreateFargateProfileResponse { } export namespace CreateFargateProfileResponse { - export const filterSensitiveLog = (obj: CreateFargateProfileResponse): any => ({ - ...obj, - }); -} - -/** - *

      The request is invalid given the state of the cluster. Check the state of the cluster - * and the associated operations.

      - */ -export interface InvalidRequestException extends __SmithyException, $MetadataBearer { - name: "InvalidRequestException"; - $fault: "client"; - /** - *

      The Amazon EKS managed node group associated with the exception.

      - */ - nodegroupName?: string; - - message?: string; - /** - *

      The Amazon EKS cluster associated with the exception.

      - */ - clusterName?: string; -} - -export namespace InvalidRequestException { - export const filterSensitiveLog = (obj: InvalidRequestException): any => ({ + export const filterSensitiveLog = (obj: CreateFargateProfileResponse): any => ({ ...obj, }); } +export type CapacityTypes = "ON_DEMAND" | "SPOT"; + /** *

      An object representing a node group launch template specification. The launch template * cannot include @@ -904,14 +1245,19 @@ export namespace InvalidRequestException { * HibernationOptions * , or * TerminateInstances - * , or the node group deployment or update - * will fail. For more information about launch templates, see + * , or the node group deployment or + * update will fail. For more information about launch templates, see * CreateLaunchTemplate * in the Amazon EC2 API Reference. * For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      *

      Specify either name or id, but not both.

      */ export interface LaunchTemplateSpecification { + /** + *

      The name of the launch template.

      + */ + name?: string; + /** *

      The version of the launch template to use. If no version is specified, then the * template's default version is used.

      @@ -922,11 +1268,6 @@ export interface LaunchTemplateSpecification { *

      The ID of the launch template.

      */ id?: string; - - /** - *

      The name of the launch template.

      - */ - name?: string; } export namespace LaunchTemplateSpecification { @@ -969,18 +1310,18 @@ export namespace RemoteAccessConfig { * you must specify values for all of the properties.

      */ export interface NodegroupScalingConfig { - /** - *

      The maximum number of worker nodes that the managed node group can scale out to. - * Managed node groups can support up to 100 nodes by default.

      - */ - maxSize?: number; - /** *

      The minimum number of worker nodes that the managed node group can scale in to. This * number must be greater than zero.

      */ minSize?: number; + /** + *

      The maximum number of worker nodes that the managed node group can scale out to. + * Managed node groups can support up to 100 nodes by default.

      + */ + maxSize?: number; + /** *

      The current number of worker nodes that the managed node group should maintain.

      */ @@ -995,71 +1336,27 @@ export namespace NodegroupScalingConfig { export interface CreateNodegroupRequest { /** - *

      The metadata to apply to the node group to assist with categorization and - * organization. Each tag consists of a key and an optional value, both of which you - * define. Node group tags do not propagate to any other resources associated with the node - * group, such as the Amazon EC2 instances or subnets.

      - */ - tags?: { [key: string]: string }; - - /** - *

      The Kubernetes version to use for your managed nodes. By default, the Kubernetes - * version of the cluster is used, and this is the only accepted specified value. - * If you specify launchTemplate, and your launch template uses a custom AMI, then don't specify version, - * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + *

      The name of the cluster to create the node group in.

      */ - version?: string; + clusterName: string | undefined; /** - *

      The remote access (SSH) configuration to use with your node group. If you specify launchTemplate, - * then don't specify remoteAccess, or the node group deployment - * will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + *

      The unique name to give your node group.

      */ - remoteAccess?: RemoteAccessConfig; + nodegroupName: string | undefined; /** - *

      An object representing a node group's launch template specification. If specified, - * then do not specify instanceTypes, diskSize, or - * remoteAccess and make sure that the launch template meets the - * requirements in launchTemplateSpecification.

      + *

      The scaling configuration details for the Auto Scaling group that is created for your + * node group.

      */ - launchTemplate?: LaunchTemplateSpecification; + scalingConfig?: NodegroupScalingConfig; /** - *

      The AMI version of the Amazon EKS-optimized AMI to use with your node group. By default, - * the latest available AMI version for the node group's current Kubernetes version is - * used. For more information, see Amazon EKS-Optimized Linux AMI Versions in the Amazon EKS User Guide. - * If you specify launchTemplate, and your launch template uses a custom AMI, then don't specify releaseVersion, + *

      The root device disk size (in GiB) for your node group instances. The default disk + * size is 20 GiB. If you specify launchTemplate, then don't specify diskSize, * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      */ - releaseVersion?: string; - - /** - *

      The Amazon Resource Name (ARN) of the IAM role to associate with your node group. The Amazon EKS worker - * node kubelet daemon makes calls to AWS APIs on your behalf. Worker nodes - * receive permissions for these API calls through an IAM instance profile and associated - * policies. Before you can launch worker nodes and register them into a cluster, you must - * create an IAM role for those worker nodes to use when they are launched. For more - * information, see Amazon EKS Worker Node IAM Role in the - * - * Amazon EKS User Guide - * . If you specify launchTemplate, then don't specify - * - * IamInstanceProfile - * in your launch template, or the node group - * deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      - */ - nodeRole: string | undefined; - - /** - *

      The instance type to use for your node group. You can specify a single instance type - * for a node group. The default value for instanceTypes is - * t3.medium. If you choose a GPU instance type, be sure to specify - * AL2_x86_64_GPU with the amiType parameter. - * If you specify launchTemplate, then don't specify instanceTypes, or the node group - * deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      - */ - instanceTypes?: string[]; + diskSize?: number; /** *

      The subnets to use for the Auto Scaling group that is created for your node group. @@ -1073,24 +1370,54 @@ export interface CreateNodegroupRequest { subnets: string[] | undefined; /** - *

      The unique name to give your node group.

      + *

      Specify the instance types for a node group. If you specify a GPU instance type, be + * sure to specify AL2_x86_64_GPU with the amiType parameter. If + * you specify launchTemplate, then you can specify zero or one instance type + * in your launch template or you can specify 0-20 instance types for + * instanceTypes. If however, you specify an instance type in your launch + * template and specify any instanceTypes, the node group + * deployment will fail. If you don't specify an instance type in a launch template or for + * instanceTypes, then t3.medium is used, by default. If you + * specify Spot for capacityType, then we recommend specifying + * multiple values for instanceTypes. For more information, see Managed node group + * capacity types and Launch template support in + * the Amazon EKS User Guide.

      */ - nodegroupName: string | undefined; + instanceTypes?: string[]; /** *

      The AMI type for your node group. GPU instance types should use the * AL2_x86_64_GPU AMI type. Non-GPU instances should use the * AL2_x86_64 AMI type. Arm instances should use the - * AL2_ARM_64 AMI type. All types use the Amazon EKS-optimized Amazon Linux 2 AMI. + * AL2_ARM_64 AMI type. All types use the Amazon EKS optimized Amazon Linux 2 AMI. * If you specify launchTemplate, and your launch template uses a custom AMI, then don't specify amiType, * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      */ amiType?: AMITypes | string; /** - *

      The name of the cluster to create the node group in.

      + *

      The remote access (SSH) configuration to use with your node group. If you specify launchTemplate, + * then don't specify remoteAccess, or the node group deployment + * will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      */ - clusterName: string | undefined; + remoteAccess?: RemoteAccessConfig; + + /** + *

      The Amazon Resource Name (ARN) of the IAM role to associate with your node group. The Amazon EKS worker + * node kubelet daemon makes calls to AWS APIs on your behalf. Worker nodes + * receive permissions for these API calls through an IAM instance profile and associated + * policies. Before you can launch worker nodes and register them into a cluster, you must + * create an IAM role for those worker nodes to use when they are launched. For more + * information, see Amazon EKS Worker Node IAM Role in the + * + * Amazon EKS User Guide + * . If you specify launchTemplate, then don't specify + * + * IamInstanceProfile + * in your launch template, + * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + */ + nodeRole: string | undefined; /** *

      The Kubernetes labels to be applied to the nodes in the node group when they are @@ -1099,11 +1426,12 @@ export interface CreateNodegroupRequest { labels?: { [key: string]: string }; /** - *

      The root device disk size (in GiB) for your node group instances. The default disk - * size is 20 GiB. If you specify launchTemplate, then don't specify diskSize, - * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + *

      The metadata to apply to the node group to assist with categorization and + * organization. Each tag consists of a key and an optional value, both of which you + * define. Node group tags do not propagate to any other resources associated with the node + * group, such as the Amazon EC2 instances or subnets.

      */ - diskSize?: number; + tags?: { [key: string]: string }; /** *

      Unique, case-sensitive identifier that you provide to ensure the idempotency of the @@ -1112,10 +1440,35 @@ export interface CreateNodegroupRequest { clientRequestToken?: string; /** - *

      The scaling configuration details for the Auto Scaling group that is created for your - * node group.

      + *

      An object representing a node group's launch template specification. If specified, + * then do not specify instanceTypes, diskSize, or + * remoteAccess and make sure that the launch template meets the + * requirements in launchTemplateSpecification.

      */ - scalingConfig?: NodegroupScalingConfig; + launchTemplate?: LaunchTemplateSpecification; + + /** + *

      The capacity type for your node group.

      + */ + capacityType?: CapacityTypes | string; + + /** + *

      The Kubernetes version to use for your managed nodes. By default, the Kubernetes + * version of the cluster is used, and this is the only accepted specified value. + * If you specify launchTemplate, and your launch template uses a custom AMI, then don't specify version, + * or the node group deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + */ + version?: string; + + /** + *

      The AMI version of the Amazon EKS optimized AMI to use with your node group. By default, + * the latest available AMI version for the node group's current Kubernetes version is + * used. For more information, see Amazon EKS + * optimized Amazon Linux 2 AMI versions in the Amazon EKS User Guide. If you specify launchTemplate, + * and your launch template uses a custom AMI, then don't specify releaseVersion, or the node group + * deployment will fail. For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

      + */ + releaseVersion?: string; } export namespace CreateNodegroupRequest { @@ -1149,36 +1502,32 @@ export enum NodegroupIssueCode { *

      An object representing an issue with an Amazon EKS resource.

      */ export interface Issue { - /** - *

      The AWS resources that are afflicted by this issue.

      - */ - resourceIds?: string[]; - - /** - *

      The error message associated with the issue.

      - */ - message?: string; - /** *

      A brief description of the error.

      *
        *
      • *

        - * AutoScalingGroupNotFound: We couldn't find - * the Auto Scaling group associated with the managed node group. You may be able to - * recreate an Auto Scaling group with the same settings to recover.

        + * AccessDenied: Amazon EKS or one or more of your + * managed nodes is failing to authenticate or authorize with your Kubernetes + * cluster API server.

        *
      • *
      • *

        - * Ec2SecurityGroupNotFound: We couldn't find - * the cluster security group for the cluster. You must recreate your - * cluster.

        + * AsgInstanceLaunchFailures: Your Auto Scaling group is + * experiencing failures while attempting to launch instances.

        *
      • *
      • *

        - * Ec2SecurityGroupDeletionFailure: We could not - * delete the remote access security group for your managed node group. Remove any - * dependencies from the security group.

        + * AutoScalingGroupNotFound: We couldn't find + * the Auto Scaling group associated with the managed node group. You may be able to + * recreate an Auto Scaling group with the same settings to recover.

        + *
      • + *
      • + *

        + * ClusterUnreachable: Amazon EKS or one or more of + * your managed nodes is unable to to communicate with your Kubernetes cluster API + * server. This can happen if there are network disruptions or if API servers are + * timing out processing requests.

        *
      • *
      • *

        @@ -1195,6 +1544,18 @@ export interface Issue { *

      • *
      • *

        + * Ec2SecurityGroupDeletionFailure: We could not + * delete the remote access security group for your managed node group. Remove any + * dependencies from the security group.

        + *
      • + *
      • + *

        + * Ec2SecurityGroupNotFound: We couldn't find + * the cluster security group for the cluster. You must recreate your + * cluster.

        + *
      • + *
      • + *

        * Ec2SubnetInvalidConfiguration: One or more * Amazon EC2 subnets specified for a node group do not automatically assign public IP * addresses to instances launched into it. If you want your instances to be @@ -1217,19 +1578,6 @@ export interface Issue { *

      • *
      • *

        - * AsgInstanceLaunchFailures: Your Auto Scaling group is - * experiencing failures while attempting to launch instances.

        - *
      • - *
      • - *

        - * NodeCreationFailure: Your launched instances - * are unable to register with your Amazon EKS cluster. Common causes of this failure - * are insufficient worker node IAM - * role permissions or lack of outbound internet access for the nodes. - *

        - *
      • - *
      • - *

        * InstanceLimitExceeded: Your AWS account is * unable to launch any more instances of the specified instance type. You may be * able to request an Amazon EC2 instance limit increase to recover.

        @@ -1242,17 +1590,30 @@ export interface Issue { *
      • *
      • *

        - * AccessDenied: Amazon EKS or one or more of your - * managed nodes is unable to communicate with your cluster API server.

        + * InternalFailure: These errors are usually + * caused by an Amazon EKS server-side issue.

        *
      • *
      • *

        - * InternalFailure: These errors are usually - * caused by an Amazon EKS server-side issue.

        + * NodeCreationFailure: Your launched instances + * are unable to register with your Amazon EKS cluster. Common causes of this failure + * are insufficient worker node IAM + * role permissions or lack of outbound internet access for the nodes. + *

        *
      • *
      */ code?: NodegroupIssueCode | string; + + /** + *

      The error message associated with the issue.

      + */ + message?: string; + + /** + *

      The AWS resources that are afflicted by this issue.

      + */ + resourceIds?: string[]; } export namespace Issue { @@ -1283,73 +1644,45 @@ export namespace NodegroupHealth { */ export interface NodegroupResources { /** - *

      The remote access security group associated with the node group. This security group - * controls SSH access to the worker nodes.

      + *

      The Auto Scaling groups associated with the node group.

      */ - remoteAccessSecurityGroup?: string; + autoScalingGroups?: AutoScalingGroup[]; /** - *

      The Auto Scaling groups associated with the node group.

      + *

      The remote access security group associated with the node group. This security group + * controls SSH access to the worker nodes.

      */ - autoScalingGroups?: AutoScalingGroup[]; + remoteAccessSecurityGroup?: string; } export namespace NodegroupResources { export const filterSensitiveLog = (obj: NodegroupResources): any => ({ ...obj, - }); -} - -export type NodegroupStatus = - | "ACTIVE" - | "CREATE_FAILED" - | "CREATING" - | "DEGRADED" - | "DELETE_FAILED" - | "DELETING" - | "UPDATING"; - -/** - *

      An object representing an Amazon EKS managed node group.

      - */ -export interface Nodegroup { - /** - *

      The name associated with an Amazon EKS managed node group.

      - */ - nodegroupName?: string; - - /** - *

      If the node group was deployed using a launch template with a custom AMI, then this is - * CUSTOM. For node groups that weren't deployed using a launch template, - * this is the AMI type that was specified in the node group configuration.

      - */ - amiType?: AMITypes | string; - - /** - *

      The Kubernetes labels applied to the nodes in the node group.

      - * - *

      Only labels that are applied with the Amazon EKS API are shown here. There may be other - * Kubernetes labels applied to the nodes in this group.

      - *
      - */ - labels?: { [key: string]: string }; + }); +} - /** - *

      The subnets that were specified for the Auto Scaling group that is associated with - * your node group.

      - */ - subnets?: string[]; +export type NodegroupStatus = + | "ACTIVE" + | "CREATE_FAILED" + | "CREATING" + | "DEGRADED" + | "DELETE_FAILED" + | "DELETING" + | "UPDATING"; +/** + *

      An object representing an Amazon EKS managed node group.

      + */ +export interface Nodegroup { /** - *

      The health status of the node group. If there are issues with your node group's - * health, they are listed here.

      + *

      The name associated with an Amazon EKS managed node group.

      */ - health?: NodegroupHealth; + nodegroupName?: string; /** - *

      The current status of the managed node group.

      + *

      The Amazon Resource Name (ARN) associated with the managed node group.

      */ - status?: NodegroupStatus | string; + nodegroupArn?: string; /** *

      The name of the cluster that the managed node group resides in.

      @@ -1357,17 +1690,23 @@ export interface Nodegroup { clusterName?: string; /** - *

      The Amazon Resource Name (ARN) associated with the managed node group.

      + *

      The Kubernetes version of the managed node group.

      */ - nodegroupArn?: string; + version?: string; /** - *

      If the node group wasn't deployed with a launch template, then this is the remote - * access configuration that is associated with the node group. If the node group was - * deployed with a launch template, then this is - * null.

      + *

      If the node group was deployed using a launch template with a custom AMI, then this is + * the AMI ID that was specified in the launch template. For node groups that weren't + * deployed using a launch template, this is the version of the Amazon EKS optimized AMI that + * the node group was deployed with.

      */ - remoteAccess?: RemoteAccessConfig; + releaseVersion?: string; + + /** + *

      The Unix epoch timestamp in seconds for when the managed node group was + * created.

      + */ + createdAt?: Date; /** *

      The Unix epoch timestamp in seconds for when the managed node group was last @@ -1376,22 +1715,20 @@ export interface Nodegroup { modifiedAt?: Date; /** - *

      The scaling configuration details for the Auto Scaling group that is associated with - * your node group.

      + *

      The current status of the managed node group.

      */ - scalingConfig?: NodegroupScalingConfig; + status?: NodegroupStatus | string; /** - *

      The resources associated with the node group, such as Auto Scaling groups and security - * groups for remote access.

      + *

      The capacity type of your managed node group.

      */ - resources?: NodegroupResources; + capacityType?: CapacityTypes | string; /** - *

      If a launch template was used to create the node group, then this is the launch - * template that was used.

      + *

      The scaling configuration details for the Auto Scaling group that is associated with + * your node group.

      */ - launchTemplate?: LaunchTemplateSpecification; + scalingConfig?: NodegroupScalingConfig; /** *

      If the node group wasn't deployed with a launch template, then this is the instance @@ -1401,23 +1738,24 @@ export interface Nodegroup { instanceTypes?: string[]; /** - *

      The metadata applied to the node group to assist with categorization and organization. - * Each tag consists of a key and an optional value, both of which you define. Node group - * tags do not propagate to any other resources associated with the node group, such as the - * Amazon EC2 instances or subnets.

      + *

      The subnets that were specified for the Auto Scaling group that is associated with + * your node group.

      */ - tags?: { [key: string]: string }; + subnets?: string[]; /** - *

      The Kubernetes version of the managed node group.

      + *

      If the node group wasn't deployed with a launch template, then this is the remote + * access configuration that is associated with the node group. If the node group was + * deployed with a launch template, then this is null.

      */ - version?: string; + remoteAccess?: RemoteAccessConfig; /** - *

      The Unix epoch timestamp in seconds for when the managed node group was - * created.

      + *

      If the node group was deployed using a launch template with a custom AMI, then this is + * CUSTOM. For node groups that weren't deployed using a launch template, + * this is the AMI type that was specified in the node group configuration.

      */ - createdAt?: Date; + amiType?: AMITypes | string; /** *

      The IAM role associated with your node group. The Amazon EKS worker node @@ -1427,6 +1765,21 @@ export interface Nodegroup { */ nodeRole?: string; + /** + *

      The Kubernetes labels applied to the nodes in the node group.

      + * + *

      Only labels that are applied with the Amazon EKS API are shown here. There may be other + * Kubernetes labels applied to the nodes in this group.

      + *
      + */ + labels?: { [key: string]: string }; + + /** + *

      The resources associated with the node group, such as Auto Scaling groups and security + * groups for remote access.

      + */ + resources?: NodegroupResources; + /** *

      If the node group wasn't deployed with a launch template, then this is the disk size * in the node group configuration. If the node group was deployed with a launch template, @@ -1435,12 +1788,24 @@ export interface Nodegroup { diskSize?: number; /** - *

      If the node group was deployed using a launch template with a custom AMI, then this is - * the AMI ID that was specified in the launch template. For node groups that weren't - * deployed using a launch template, this is the version of the Amazon EKS-optimized AMI that - * the node group was deployed with.

      + *

      The health status of the node group. If there are issues with your node group's + * health, they are listed here.

      */ - releaseVersion?: string; + health?: NodegroupHealth; + + /** + *

      If a launch template was used to create the node group, then this is the launch + * template that was used.

      + */ + launchTemplate?: LaunchTemplateSpecification; + + /** + *

      The metadata applied to the node group to assist with categorization and organization. + * Each tag consists of a key and an optional value, both of which you define. Node group + * tags do not propagate to any other resources associated with the node group, such as the + * Amazon EC2 instances or subnets.

      + */ + tags?: { [key: string]: string }; } export namespace Nodegroup { @@ -1462,60 +1827,61 @@ export namespace CreateNodegroupResponse { }); } -export interface DeleteClusterRequest { +export interface DeleteAddonRequest { /** - *

      The name of the cluster to delete.

      + *

      The name of the cluster to delete the add-on from.

      */ - name: string | undefined; + clusterName: string | undefined; + + /** + *

      The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

      + */ + addonName: string | undefined; } -export namespace DeleteClusterRequest { - export const filterSensitiveLog = (obj: DeleteClusterRequest): any => ({ +export namespace DeleteAddonRequest { + export const filterSensitiveLog = (obj: DeleteAddonRequest): any => ({ ...obj, }); } -export interface DeleteClusterResponse { +export interface DeleteAddonResponse { /** - *

      The full description of the cluster to delete.

      + *

      An Amazon EKS add-on.

      */ - cluster?: Cluster; + addon?: Addon; } -export namespace DeleteClusterResponse { - export const filterSensitiveLog = (obj: DeleteClusterResponse): any => ({ +export namespace DeleteAddonResponse { + export const filterSensitiveLog = (obj: DeleteAddonResponse): any => ({ ...obj, }); } -/** - *

      The specified resource could not be found. You can view your available clusters with - * ListClusters. You can view your available managed node groups with - * ListNodegroups. Amazon EKS clusters and node groups are - * Region-specific.

      - */ -export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { - name: "ResourceNotFoundException"; - $fault: "client"; +export interface DeleteClusterRequest { /** - *

      The Amazon EKS cluster associated with the exception.

      + *

      The name of the cluster to delete.

      */ - clusterName?: string; + name: string | undefined; +} - /** - *

      The Amazon EKS managed node group associated with the exception.

      - */ - nodegroupName?: string; +export namespace DeleteClusterRequest { + export const filterSensitiveLog = (obj: DeleteClusterRequest): any => ({ + ...obj, + }); +} - message?: string; +export interface DeleteClusterResponse { /** - *

      The Fargate profile associated with the exception.

      + *

      The full description of the cluster to delete.

      */ - fargateProfileName?: string; + cluster?: Cluster; } -export namespace ResourceNotFoundException { - export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ +export namespace DeleteClusterResponse { + export const filterSensitiveLog = (obj: DeleteClusterResponse): any => ({ ...obj, }); } @@ -1582,6 +1948,101 @@ export namespace DeleteNodegroupResponse { }); } +export interface DescribeAddonRequest { + /** + *

      The name of the cluster.

      + */ + clusterName: string | undefined; + + /** + *

      The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

      + */ + addonName: string | undefined; +} + +export namespace DescribeAddonRequest { + export const filterSensitiveLog = (obj: DescribeAddonRequest): any => ({ + ...obj, + }); +} + +export interface DescribeAddonResponse { + /** + *

      An Amazon EKS add-on.

      + */ + addon?: Addon; +} + +export namespace DescribeAddonResponse { + export const filterSensitiveLog = (obj: DescribeAddonResponse): any => ({ + ...obj, + }); +} + +export interface DescribeAddonVersionsRequest { + /** + *

      The Kubernetes versions that the add-on can be used with.

      + */ + kubernetesVersion?: string; + + /** + *

      The maximum number of results to return.

      + */ + maxResults?: number; + + /** + *

      The nextToken value returned from a previous paginated + * DescribeAddonVersionsRequest where maxResults was used and + * the results exceeded the value of that parameter. Pagination continues from the end of + * the previous results that returned the nextToken value.

      + * + *

      This token should be treated as an opaque identifier that is used only to + * retrieve the next items in a list and not for other programmatic purposes.

      + *
      + */ + nextToken?: string; + + /** + *

      The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

      + */ + addonName?: string; +} + +export namespace DescribeAddonVersionsRequest { + export const filterSensitiveLog = (obj: DescribeAddonVersionsRequest): any => ({ + ...obj, + }); +} + +export interface DescribeAddonVersionsResponse { + /** + *

      The list of available versions with Kubernetes version compatibility.

      + */ + addons?: AddonInfo[]; + + /** + *

      The nextToken value returned from a previous paginated + * DescribeAddonVersionsResponse where maxResults was used + * and the results exceeded the value of that parameter. Pagination continues from the end + * of the previous results that returned the nextToken value.

      + * + *

      This token should be treated as an opaque identifier that is used only to + * retrieve the next items in a list and not for other programmatic purposes.

      + *
      + */ + nextToken?: string; +} + +export namespace DescribeAddonVersionsResponse { + export const filterSensitiveLog = (obj: DescribeAddonVersionsResponse): any => ({ + ...obj, + }); +} + export interface DescribeClusterRequest { /** *

      The name of the cluster to describe.

      @@ -1610,14 +2071,14 @@ export namespace DescribeClusterResponse { export interface DescribeFargateProfileRequest { /** - *

      The name of the Fargate profile to describe.

      + *

      The name of the Amazon EKS cluster associated with the Fargate profile.

      */ - fargateProfileName: string | undefined; + clusterName: string | undefined; /** - *

      The name of the Amazon EKS cluster associated with the Fargate profile.

      + *

      The name of the Fargate profile to describe.

      */ - clusterName: string | undefined; + fargateProfileName: string | undefined; } export namespace DescribeFargateProfileRequest { @@ -1685,6 +2146,13 @@ export interface DescribeUpdateRequest { *

      The name of the Amazon EKS node group associated with the update.

      */ nodegroupName?: string; + + /** + *

      The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

      + */ + addonName?: string; } export namespace DescribeUpdateRequest { @@ -1696,8 +2164,10 @@ export namespace DescribeUpdateRequest { export enum ErrorCode { ACCESS_DENIED = "AccessDenied", CLUSTER_UNREACHABLE = "ClusterUnreachable", + CONFIGURATION_CONFLICT = "ConfigurationConflict", ENI_LIMIT_REACHED = "EniLimitReached", INSUFFICIENT_FREE_ADDRESSES = "InsufficientFreeAddresses", + INSUFFICIENT_NUMBER_OF_REPLICAS = "InsufficientNumberOfReplicas", IP_NOT_AVAILABLE = "IpNotAvailable", NODE_CREATION_FAILURE = "NodeCreationFailure", OPERATION_NOT_PERMITTED = "OperationNotPermitted", @@ -1712,11 +2182,6 @@ export enum ErrorCode { *

      An object representing an error when an asynchronous operation fails.

      */ export interface ErrorDetail { - /** - *

      An optional field that contains the resource IDs associated with the error.

      - */ - resourceIds?: string[]; - /** *

      A brief description of the error.

      *
        @@ -1764,6 +2229,11 @@ export interface ErrorDetail { *

        A more complete description of the error.

        */ errorMessage?: string; + + /** + *

        An optional field that contains the resource IDs associated with the error.

        + */ + resourceIds?: string[]; } export namespace ErrorDetail { @@ -1773,6 +2243,7 @@ export namespace ErrorDetail { } export enum UpdateParamType { + ADDON_VERSION = "AddonVersion", CLUSTER_LOGGING = "ClusterLogging", DESIRED_SIZE = "DesiredSize", ENDPOINT_PRIVATE_ACCESS = "EndpointPrivateAccess", @@ -1784,6 +2255,8 @@ export enum UpdateParamType { PLATFORM_VERSION = "PlatformVersion", PUBLIC_ACCESS_CIDRS = "PublicAccessCidrs", RELEASE_VERSION = "ReleaseVersion", + RESOLVE_CONFLICTS = "ResolveConflicts", + SERVICE_ACCOUNT_ROLE_ARN = "ServiceAccountRoleArn", VERSION = "Version", } @@ -1792,14 +2265,14 @@ export enum UpdateParamType { */ export interface UpdateParam { /** - *

        The value of the keys submitted as part of an update request.

        + *

        The keys associated with an update request.

        */ - value?: string; + type?: UpdateParamType | string; /** - *

        The keys associated with an update request.

        + *

        The value of the keys submitted as part of an update request.

        */ - type?: UpdateParamType | string; + value?: string; } export namespace UpdateParam { @@ -1816,6 +2289,7 @@ export enum UpdateStatus { } export enum UpdateType { + ADDON_UPDATE = "AddonUpdate", CONFIG_UPDATE = "ConfigUpdate", ENDPOINT_ACCESS_UPDATE = "EndpointAccessUpdate", LOGGING_UPDATE = "LoggingUpdate", @@ -1827,19 +2301,14 @@ export enum UpdateType { */ export interface Update { /** - *

        The current status of the update.

        - */ - status?: UpdateStatus | string; - - /** - *

        The Unix epoch timestamp in seconds for when the update was created.

        + *

        A UUID that is used to track the update.

        */ - createdAt?: Date; + id?: string; /** - *

        Any errors associated with a Failed update.

        + *

        The current status of the update.

        */ - errors?: ErrorDetail[]; + status?: UpdateStatus | string; /** *

        The type of the update.

        @@ -1852,9 +2321,14 @@ export interface Update { params?: UpdateParam[]; /** - *

        A UUID that is used to track the update.

        + *

        The Unix epoch timestamp in seconds for when the update was created.

        */ - id?: string; + createdAt?: Date; + + /** + *

        Any errors associated with a Failed update.

        + */ + errors?: ErrorDetail[]; } export namespace Update { @@ -1876,6 +2350,69 @@ export namespace DescribeUpdateResponse { }); } +export interface ListAddonsRequest { + /** + *

        The name of the cluster.

        + */ + clusterName: string | undefined; + + /** + *

        The maximum number of add-on results returned by ListAddonsRequest in + * paginated output. When you use this parameter, ListAddonsRequest returns + * only maxResults results in a single page along with a + * nextToken response element. You can see the remaining results of the + * initial request by sending another ListAddonsRequest request with the + * returned nextToken value. This value can be between 1 and + * 100. If you don't use this parameter, ListAddonsRequest + * returns up to 100 results and a nextToken value, if + * applicable.

        + */ + maxResults?: number; + + /** + *

        The nextToken value returned from a previous paginated + * ListAddonsRequest where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value.

        + * + *

        This token should be treated as an opaque identifier that is used only to + * retrieve the next items in a list and not for other programmatic purposes.

        + *
        + */ + nextToken?: string; +} + +export namespace ListAddonsRequest { + export const filterSensitiveLog = (obj: ListAddonsRequest): any => ({ + ...obj, + }); +} + +export interface ListAddonsResponse { + /** + *

        A list of available add-ons.

        + */ + addons?: string[]; + + /** + *

        The nextToken value returned from a previous paginated + * ListAddonsResponse where maxResults was used and the + * results exceeded the value of that parameter. Pagination continues from the end of the + * previous results that returned the nextToken value.

        + * + *

        This token should be treated as an opaque identifier that is used only to + * retrieve the next items in a list and not for other programmatic purposes.

        + *
        + */ + nextToken?: string; +} + +export namespace ListAddonsResponse { + export const filterSensitiveLog = (obj: ListAddonsResponse): any => ({ + ...obj, + }); +} + export interface ListClustersRequest { /** *

        The maximum number of cluster results returned by ListClusters in @@ -1936,14 +2473,6 @@ export interface ListFargateProfilesRequest { */ clusterName: string | undefined; - /** - *

        The nextToken value returned from a previous paginated - * ListFargateProfiles request where maxResults was used and - * the results exceeded the value of that parameter. Pagination continues from the end of - * the previous results that returned the nextToken value.

        - */ - nextToken?: string; - /** *

        The maximum number of Fargate profile results returned by * ListFargateProfiles in paginated output. When you use this parameter, @@ -1956,6 +2485,14 @@ export interface ListFargateProfilesRequest { * results and a nextToken value if applicable.

        */ maxResults?: number; + + /** + *

        The nextToken value returned from a previous paginated + * ListFargateProfiles request where maxResults was used and + * the results exceeded the value of that parameter. Pagination continues from the end of + * the previous results that returned the nextToken value.

        + */ + nextToken?: string; } export namespace ListFargateProfilesRequest { @@ -1987,6 +2524,11 @@ export namespace ListFargateProfilesResponse { } export interface ListNodegroupsRequest { + /** + *

        The name of the Amazon EKS cluster that you would like to list node groups in.

        + */ + clusterName: string | undefined; + /** *

        The maximum number of node group results returned by ListNodegroups in * paginated output. When you use this parameter, ListNodegroups returns only @@ -2006,11 +2548,6 @@ export interface ListNodegroupsRequest { * previous results that returned the nextToken value.

        */ nextToken?: string; - - /** - *

        The name of the Amazon EKS cluster that you would like to list node groups in.

        - */ - clusterName: string | undefined; } export namespace ListNodegroupsRequest { @@ -2020,6 +2557,11 @@ export namespace ListNodegroupsRequest { } export interface ListNodegroupsResponse { + /** + *

        A list of all of the node groups associated with the specified cluster.

        + */ + nodegroups?: string[]; + /** *

        The nextToken value to include in a future ListNodegroups * request. When the results of a ListNodegroups request exceed @@ -2028,11 +2570,6 @@ export interface ListNodegroupsResponse { * return.

        */ nextToken?: string; - - /** - *

        A list of all of the node groups associated with the specified cluster.

        - */ - nodegroups?: string[]; } export namespace ListNodegroupsResponse { @@ -2106,6 +2643,16 @@ export interface ListUpdatesRequest { */ name: string | undefined; + /** + *

        The name of the Amazon EKS managed node group to list updates for.

        + */ + nodegroupName?: string; + + /** + *

        The names of the installed add-ons that have available updates.

        + */ + addonName?: string; + /** *

        The nextToken value returned from a previous paginated * ListUpdates request where maxResults was used and the @@ -2125,11 +2672,6 @@ export interface ListUpdatesRequest { * nextToken value if applicable.

        */ maxResults?: number; - - /** - *

        The name of the Amazon EKS managed node group to list updates for.

        - */ - nodegroupName?: string; } export namespace ListUpdatesRequest { @@ -2161,16 +2703,16 @@ export namespace ListUpdatesResponse { } export interface TagResourceRequest { - /** - *

        The tags to add to the resource. A tag is an array of key-value pairs.

        - */ - tags: { [key: string]: string } | undefined; - /** *

        The Amazon Resource Name (ARN) of the resource to which to add tags. Currently, the supported resources * are Amazon EKS clusters and managed node groups.

        */ resourceArn: string | undefined; + + /** + *

        The tags to add to the resource. A tag is an array of key-value pairs.

        + */ + tags: { [key: string]: string } | undefined; } export namespace TagResourceRequest { @@ -2188,16 +2730,16 @@ export namespace TagResourceResponse { } export interface UntagResourceRequest { - /** - *

        The keys of the tags to be removed.

        - */ - tagKeys: string[] | undefined; - /** *

        The Amazon Resource Name (ARN) of the resource from which to delete tags. Currently, the supported * resources are Amazon EKS clusters and managed node groups.

        */ resourceArn: string | undefined; + + /** + *

        The keys of the tags to be removed.

        + */ + tagKeys: string[] | undefined; } export namespace UntagResourceRequest { @@ -2214,7 +2756,81 @@ export namespace UntagResourceResponse { }); } +export interface UpdateAddonRequest { + /** + *

        The name of the cluster.

        + */ + clusterName: string | undefined; + + /** + *

        The name of the add-on. The name must match one of the names returned by + * ListAddons + * .

        + */ + addonName: string | undefined; + + /** + *

        The version of the add-on. The version must match one of the versions returned by + * DescribeAddonVersions + * .

        + */ + addonVersion?: string; + + /** + *

        The Amazon Resource Name (ARN) of an existing IAM role to bind to the add-on's service account. The role must be assigned the IAM permissions required by the add-on. If you don't specify an existing IAM role, then the add-on uses the + * permissions assigned to the node IAM role. For more information, see Amazon EKS node IAM role in the Amazon EKS User Guide.

        + * + *

        To specify an existing IAM role, you must have an IAM OpenID Connect (OIDC) provider created for + * your cluster. For more information, see Enabling + * IAM roles for service accounts on your cluster in the + * Amazon EKS User Guide.

        + *
        + */ + serviceAccountRoleArn?: string; + + /** + *

        How to resolve parameter value conflicts when applying the new version of the add-on + * to the cluster.

        + */ + resolveConflicts?: ResolveConflicts | string; + + /** + *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

        + */ + clientRequestToken?: string; +} + +export namespace UpdateAddonRequest { + export const filterSensitiveLog = (obj: UpdateAddonRequest): any => ({ + ...obj, + }); +} + +export interface UpdateAddonResponse { + /** + *

        An object representing an asynchronous update.

        + */ + update?: Update; +} + +export namespace UpdateAddonResponse { + export const filterSensitiveLog = (obj: UpdateAddonResponse): any => ({ + ...obj, + }); +} + export interface UpdateClusterConfigRequest { + /** + *

        The name of the Amazon EKS cluster to update.

        + */ + name: string | undefined; + + /** + *

        An object representing the VPC configuration to use for an Amazon EKS cluster.

        + */ + resourcesVpcConfig?: VpcConfigRequest; + /** *

        Enable or disable exporting the Kubernetes control plane logs for your cluster to * CloudWatch Logs. By default, cluster control plane logs aren't exported to CloudWatch Logs. For more @@ -2229,16 +2845,6 @@ export interface UpdateClusterConfigRequest { */ logging?: Logging; - /** - *

        The name of the Amazon EKS cluster to update.

        - */ - name: string | undefined; - - /** - *

        An object representing the VPC configuration to use for an Amazon EKS cluster.

        - */ - resourcesVpcConfig?: VpcConfigRequest; - /** *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the * request.

        @@ -2267,10 +2873,9 @@ export namespace UpdateClusterConfigResponse { export interface UpdateClusterVersionRequest { /** - *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the - * request.

        + *

        The name of the Amazon EKS cluster to update.

        */ - clientRequestToken?: string; + name: string | undefined; /** *

        The desired Kubernetes version following a successful update.

        @@ -2278,9 +2883,10 @@ export interface UpdateClusterVersionRequest { version: string | undefined; /** - *

        The name of the Amazon EKS cluster to update.

        + *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

        */ - name: string | undefined; + clientRequestToken?: string; } export namespace UpdateClusterVersionRequest { @@ -2325,9 +2931,9 @@ export namespace UpdateLabelsPayload { export interface UpdateNodegroupConfigRequest { /** - *

        The scaling configuration details for the Auto Scaling group after the update.

        + *

        The name of the Amazon EKS cluster that the managed node group resides in.

        */ - scalingConfig?: NodegroupScalingConfig; + clusterName: string | undefined; /** *

        The name of the managed node group to update.

        @@ -2335,21 +2941,21 @@ export interface UpdateNodegroupConfigRequest { nodegroupName: string | undefined; /** - *

        The name of the Amazon EKS cluster that the managed node group resides in.

        + *

        The Kubernetes labels to be applied to the nodes in the node group after the + * update.

        */ - clusterName: string | undefined; + labels?: UpdateLabelsPayload; /** - *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the - * request.

        + *

        The scaling configuration details for the Auto Scaling group after the update.

        */ - clientRequestToken?: string; + scalingConfig?: NodegroupScalingConfig; /** - *

        The Kubernetes labels to be applied to the nodes in the node group after the - * update.

        + *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the + * request.

        */ - labels?: UpdateLabelsPayload; + clientRequestToken?: string; } export namespace UpdateNodegroupConfigRequest { @@ -2372,6 +2978,17 @@ export namespace UpdateNodegroupConfigResponse { } export interface UpdateNodegroupVersionRequest { + /** + *

        The name of the Amazon EKS cluster that is associated with the managed node group to + * update.

        + */ + clusterName: string | undefined; + + /** + *

        The name of the managed node group to update.

        + */ + nodegroupName: string | undefined; + /** *

        The Kubernetes version to update to. If no version is specified, then the Kubernetes * version of the node group does not change. You can specify the Kubernetes version of the @@ -2383,17 +3000,9 @@ export interface UpdateNodegroupVersionRequest { version?: string; /** - *

        Force the update if the existing node group's pods are unable to be drained due to a - * pod disruption budget issue. If an update fails because pods could not be drained, you - * can force the update after it fails to terminate the old node whether or not any pods - * are running on the node.

        - */ - force?: boolean; - - /** - *

        The AMI version of the Amazon EKS-optimized AMI to use for the update. By default, the + *

        The AMI version of the Amazon EKS optimized AMI to use for the update. By default, the * latest available AMI version for the node group's Kubernetes version is used. For more - * information, see Amazon EKS-Optimized Linux AMI Versions in the + * information, see Amazon EKS optimized Amazon Linux 2 AMI versions in the * Amazon EKS User Guide. If you specify launchTemplate, and your launch template uses a custom AMI, then don't specify * releaseVersion, or the node group update will fail. * For more information about using launch templates with Amazon EKS, see Launch template support in the Amazon EKS User Guide.

        @@ -2408,21 +3017,18 @@ export interface UpdateNodegroupVersionRequest { launchTemplate?: LaunchTemplateSpecification; /** - *

        The name of the managed node group to update.

        + *

        Force the update if the existing node group's pods are unable to be drained due to a + * pod disruption budget issue. If an update fails because pods could not be drained, you + * can force the update after it fails to terminate the old node whether or not any pods + * are running on the node.

        */ - nodegroupName: string | undefined; + force?: boolean; /** *

        Unique, case-sensitive identifier that you provide to ensure the idempotency of the * request.

        */ clientRequestToken?: string; - - /** - *

        The name of the Amazon EKS cluster that is associated with the managed node group to - * update.

        - */ - clusterName: string | undefined; } export namespace UpdateNodegroupVersionRequest { diff --git a/clients/client-eks/pagination/DescribeAddonVersionsPaginator.ts b/clients/client-eks/pagination/DescribeAddonVersionsPaginator.ts new file mode 100644 index 000000000000..3e4039ef90ae --- /dev/null +++ b/clients/client-eks/pagination/DescribeAddonVersionsPaginator.ts @@ -0,0 +1,57 @@ +import { EKS } from "../EKS"; +import { EKSClient } from "../EKSClient"; +import { + DescribeAddonVersionsCommand, + DescribeAddonVersionsCommandInput, + DescribeAddonVersionsCommandOutput, +} from "../commands/DescribeAddonVersionsCommand"; +import { EKSPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: EKSClient, + input: DescribeAddonVersionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new DescribeAddonVersionsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: EKS, + input: DescribeAddonVersionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.describeAddonVersions(input, ...args); +}; +export async function* paginateDescribeAddonVersions( + config: EKSPaginationConfiguration, + input: DescribeAddonVersionsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: DescribeAddonVersionsCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof EKS) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof EKSClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected EKS | EKSClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-eks/pagination/ListAddonsPaginator.ts b/clients/client-eks/pagination/ListAddonsPaginator.ts new file mode 100644 index 000000000000..fa0f4a607f3f --- /dev/null +++ b/clients/client-eks/pagination/ListAddonsPaginator.ts @@ -0,0 +1,53 @@ +import { EKS } from "../EKS"; +import { EKSClient } from "../EKSClient"; +import { ListAddonsCommand, ListAddonsCommandInput, ListAddonsCommandOutput } from "../commands/ListAddonsCommand"; +import { EKSPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: EKSClient, + input: ListAddonsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListAddonsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: EKS, + input: ListAddonsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listAddons(input, ...args); +}; +export async function* paginateListAddons( + config: EKSPaginationConfiguration, + input: ListAddonsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListAddonsCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof EKS) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof EKSClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected EKS | EKSClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-eks/protocols/Aws_restJson1.ts b/clients/client-eks/protocols/Aws_restJson1.ts index 13ddf7d28bb2..214db0e1c68c 100644 --- a/clients/client-eks/protocols/Aws_restJson1.ts +++ b/clients/client-eks/protocols/Aws_restJson1.ts @@ -1,15 +1,22 @@ +import { CreateAddonCommandInput, CreateAddonCommandOutput } from "../commands/CreateAddonCommand"; import { CreateClusterCommandInput, CreateClusterCommandOutput } from "../commands/CreateClusterCommand"; import { CreateFargateProfileCommandInput, CreateFargateProfileCommandOutput, } from "../commands/CreateFargateProfileCommand"; import { CreateNodegroupCommandInput, CreateNodegroupCommandOutput } from "../commands/CreateNodegroupCommand"; +import { DeleteAddonCommandInput, DeleteAddonCommandOutput } from "../commands/DeleteAddonCommand"; import { DeleteClusterCommandInput, DeleteClusterCommandOutput } from "../commands/DeleteClusterCommand"; import { DeleteFargateProfileCommandInput, DeleteFargateProfileCommandOutput, } from "../commands/DeleteFargateProfileCommand"; import { DeleteNodegroupCommandInput, DeleteNodegroupCommandOutput } from "../commands/DeleteNodegroupCommand"; +import { DescribeAddonCommandInput, DescribeAddonCommandOutput } from "../commands/DescribeAddonCommand"; +import { + DescribeAddonVersionsCommandInput, + DescribeAddonVersionsCommandOutput, +} from "../commands/DescribeAddonVersionsCommand"; import { DescribeClusterCommandInput, DescribeClusterCommandOutput } from "../commands/DescribeClusterCommand"; import { DescribeFargateProfileCommandInput, @@ -17,6 +24,7 @@ import { } from "../commands/DescribeFargateProfileCommand"; import { DescribeNodegroupCommandInput, DescribeNodegroupCommandOutput } from "../commands/DescribeNodegroupCommand"; import { DescribeUpdateCommandInput, DescribeUpdateCommandOutput } from "../commands/DescribeUpdateCommand"; +import { ListAddonsCommandInput, ListAddonsCommandOutput } from "../commands/ListAddonsCommand"; import { ListClustersCommandInput, ListClustersCommandOutput } from "../commands/ListClustersCommand"; import { ListFargateProfilesCommandInput, @@ -30,6 +38,7 @@ import { import { ListUpdatesCommandInput, ListUpdatesCommandOutput } from "../commands/ListUpdatesCommand"; import { TagResourceCommandInput, TagResourceCommandOutput } from "../commands/TagResourceCommand"; import { UntagResourceCommandInput, UntagResourceCommandOutput } from "../commands/UntagResourceCommand"; +import { UpdateAddonCommandInput, UpdateAddonCommandOutput } from "../commands/UpdateAddonCommand"; import { UpdateClusterConfigCommandInput, UpdateClusterConfigCommandOutput, @@ -47,11 +56,17 @@ import { UpdateNodegroupVersionCommandOutput, } from "../commands/UpdateNodegroupVersionCommand"; import { + Addon, + AddonHealth, + AddonInfo, + AddonIssue, + AddonVersionInfo, AutoScalingGroup, BadRequestException, Certificate, ClientException, Cluster, + Compatibility, EncryptionConfig, ErrorDetail, FargateProfile, @@ -99,6 +114,44 @@ import { } from "@aws-sdk/types"; import { v4 as generateIdempotencyToken } from "uuid"; +export const serializeAws_restJson1CreateAddonCommand = async ( + input: CreateAddonCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/clusters/{clusterName}/addons"; + if (input.clusterName !== undefined) { + const labelValue: string = input.clusterName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: clusterName."); + } + resolvedPath = resolvedPath.replace("{clusterName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: clusterName."); + } + let body: any; + body = JSON.stringify({ + ...(input.addonName !== undefined && { addonName: input.addonName }), + ...(input.addonVersion !== undefined && { addonVersion: input.addonVersion }), + clientRequestToken: input.clientRequestToken ?? generateIdempotencyToken(), + ...(input.resolveConflicts !== undefined && { resolveConflicts: input.resolveConflicts }), + ...(input.serviceAccountRoleArn !== undefined && { serviceAccountRoleArn: input.serviceAccountRoleArn }), + ...(input.tags !== undefined && { tags: serializeAws_restJson1TagMap(input.tags, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1CreateClusterCommand = async ( input: CreateClusterCommandInput, context: __SerdeContext @@ -200,6 +253,7 @@ export const serializeAws_restJson1CreateNodegroupCommand = async ( let body: any; body = JSON.stringify({ ...(input.amiType !== undefined && { amiType: input.amiType }), + ...(input.capacityType !== undefined && { capacityType: input.capacityType }), clientRequestToken: input.clientRequestToken ?? generateIdempotencyToken(), ...(input.diskSize !== undefined && { diskSize: input.diskSize }), ...(input.instanceTypes !== undefined && { @@ -234,6 +288,45 @@ export const serializeAws_restJson1CreateNodegroupCommand = async ( }); }; +export const serializeAws_restJson1DeleteAddonCommand = async ( + input: DeleteAddonCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/clusters/{clusterName}/addons/{addonName}"; + if (input.clusterName !== undefined) { + const labelValue: string = input.clusterName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: clusterName."); + } + resolvedPath = resolvedPath.replace("{clusterName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: clusterName."); + } + if (input.addonName !== undefined) { + const labelValue: string = input.addonName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: addonName."); + } + resolvedPath = resolvedPath.replace("{addonName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: addonName."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1DeleteClusterCommand = async ( input: DeleteClusterCommandInput, context: __SerdeContext @@ -342,6 +435,73 @@ export const serializeAws_restJson1DeleteNodegroupCommand = async ( }); }; +export const serializeAws_restJson1DescribeAddonCommand = async ( + input: DescribeAddonCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/clusters/{clusterName}/addons/{addonName}"; + if (input.clusterName !== undefined) { + const labelValue: string = input.clusterName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: clusterName."); + } + resolvedPath = resolvedPath.replace("{clusterName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: clusterName."); + } + if (input.addonName !== undefined) { + const labelValue: string = input.addonName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: addonName."); + } + resolvedPath = resolvedPath.replace("{addonName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: addonName."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeAddonVersionsCommand = async ( + input: DescribeAddonVersionsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/addons/supported-versions"; + const query: any = { + ...(input.kubernetesVersion !== undefined && { kubernetesVersion: input.kubernetesVersion }), + ...(input.maxResults !== undefined && { maxResults: input.maxResults.toString() }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + ...(input.addonName !== undefined && { addonName: input.addonName }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + export const serializeAws_restJson1DescribeClusterCommand = async ( input: DescribeClusterCommandInput, context: __SerdeContext @@ -380,15 +540,6 @@ export const serializeAws_restJson1DescribeFargateProfileCommand = async ( "Content-Type": "", }; let resolvedPath = "/clusters/{clusterName}/fargate-profiles/{fargateProfileName}"; - if (input.fargateProfileName !== undefined) { - const labelValue: string = input.fargateProfileName; - if (labelValue.length <= 0) { - throw new Error("Empty value provided for input HTTP label: fargateProfileName."); - } - resolvedPath = resolvedPath.replace("{fargateProfileName}", __extendedEncodeURIComponent(labelValue)); - } else { - throw new Error("No value provided for input HTTP label: fargateProfileName."); - } if (input.clusterName !== undefined) { const labelValue: string = input.clusterName; if (labelValue.length <= 0) { @@ -398,6 +549,15 @@ export const serializeAws_restJson1DescribeFargateProfileCommand = async ( } else { throw new Error("No value provided for input HTTP label: clusterName."); } + if (input.fargateProfileName !== undefined) { + const labelValue: string = input.fargateProfileName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: fargateProfileName."); + } + resolvedPath = resolvedPath.replace("{fargateProfileName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: fargateProfileName."); + } let body: any; const { hostname, protocol = "https", port } = await context.endpoint(); return new __HttpRequest({ @@ -478,6 +638,42 @@ export const serializeAws_restJson1DescribeUpdateCommand = async ( } const query: any = { ...(input.nodegroupName !== undefined && { nodegroupName: input.nodegroupName }), + ...(input.addonName !== undefined && { addonName: input.addonName }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListAddonsCommand = async ( + input: ListAddonsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/clusters/{clusterName}/addons"; + if (input.clusterName !== undefined) { + const labelValue: string = input.clusterName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: clusterName."); + } + resolvedPath = resolvedPath.replace("{clusterName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: clusterName."); + } + const query: any = { + ...(input.maxResults !== undefined && { maxResults: input.maxResults.toString() }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), }; let body: any; const { hostname, protocol = "https", port } = await context.endpoint(); @@ -537,8 +733,8 @@ export const serializeAws_restJson1ListFargateProfilesCommand = async ( throw new Error("No value provided for input HTTP label: clusterName."); } const query: any = { - ...(input.nextToken !== undefined && { nextToken: input.nextToken }), ...(input.maxResults !== undefined && { maxResults: input.maxResults.toString() }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), }; let body: any; const { hostname, protocol = "https", port } = await context.endpoint(); @@ -637,9 +833,10 @@ export const serializeAws_restJson1ListUpdatesCommand = async ( throw new Error("No value provided for input HTTP label: name."); } const query: any = { + ...(input.nodegroupName !== undefined && { nodegroupName: input.nodegroupName }), + ...(input.addonName !== undefined && { addonName: input.addonName }), ...(input.nextToken !== undefined && { nextToken: input.nextToken }), ...(input.maxResults !== undefined && { maxResults: input.maxResults.toString() }), - ...(input.nodegroupName !== undefined && { nodegroupName: input.nodegroupName }), }; let body: any; const { hostname, protocol = "https", port } = await context.endpoint(); @@ -722,6 +919,51 @@ export const serializeAws_restJson1UntagResourceCommand = async ( }); }; +export const serializeAws_restJson1UpdateAddonCommand = async ( + input: UpdateAddonCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/clusters/{clusterName}/addons/{addonName}/update"; + if (input.clusterName !== undefined) { + const labelValue: string = input.clusterName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: clusterName."); + } + resolvedPath = resolvedPath.replace("{clusterName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: clusterName."); + } + if (input.addonName !== undefined) { + const labelValue: string = input.addonName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: addonName."); + } + resolvedPath = resolvedPath.replace("{addonName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: addonName."); + } + let body: any; + body = JSON.stringify({ + ...(input.addonVersion !== undefined && { addonVersion: input.addonVersion }), + clientRequestToken: input.clientRequestToken ?? generateIdempotencyToken(), + ...(input.resolveConflicts !== undefined && { resolveConflicts: input.resolveConflicts }), + ...(input.serviceAccountRoleArn !== undefined && { serviceAccountRoleArn: input.serviceAccountRoleArn }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1UpdateClusterConfigCommand = async ( input: UpdateClusterConfigCommandInput, context: __SerdeContext @@ -801,15 +1043,6 @@ export const serializeAws_restJson1UpdateNodegroupConfigCommand = async ( "Content-Type": "application/json", }; let resolvedPath = "/clusters/{clusterName}/node-groups/{nodegroupName}/update-config"; - if (input.nodegroupName !== undefined) { - const labelValue: string = input.nodegroupName; - if (labelValue.length <= 0) { - throw new Error("Empty value provided for input HTTP label: nodegroupName."); - } - resolvedPath = resolvedPath.replace("{nodegroupName}", __extendedEncodeURIComponent(labelValue)); - } else { - throw new Error("No value provided for input HTTP label: nodegroupName."); - } if (input.clusterName !== undefined) { const labelValue: string = input.clusterName; if (labelValue.length <= 0) { @@ -819,6 +1052,15 @@ export const serializeAws_restJson1UpdateNodegroupConfigCommand = async ( } else { throw new Error("No value provided for input HTTP label: clusterName."); } + if (input.nodegroupName !== undefined) { + const labelValue: string = input.nodegroupName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: nodegroupName."); + } + resolvedPath = resolvedPath.replace("{nodegroupName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: nodegroupName."); + } let body: any; body = JSON.stringify({ clientRequestToken: input.clientRequestToken ?? generateIdempotencyToken(), @@ -847,15 +1089,6 @@ export const serializeAws_restJson1UpdateNodegroupVersionCommand = async ( "Content-Type": "application/json", }; let resolvedPath = "/clusters/{clusterName}/node-groups/{nodegroupName}/update-version"; - if (input.nodegroupName !== undefined) { - const labelValue: string = input.nodegroupName; - if (labelValue.length <= 0) { - throw new Error("Empty value provided for input HTTP label: nodegroupName."); - } - resolvedPath = resolvedPath.replace("{nodegroupName}", __extendedEncodeURIComponent(labelValue)); - } else { - throw new Error("No value provided for input HTTP label: nodegroupName."); - } if (input.clusterName !== undefined) { const labelValue: string = input.clusterName; if (labelValue.length <= 0) { @@ -865,6 +1098,15 @@ export const serializeAws_restJson1UpdateNodegroupVersionCommand = async ( } else { throw new Error("No value provided for input HTTP label: clusterName."); } + if (input.nodegroupName !== undefined) { + const labelValue: string = input.nodegroupName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: nodegroupName."); + } + resolvedPath = resolvedPath.replace("{nodegroupName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: nodegroupName."); + } let body: any; body = JSON.stringify({ clientRequestToken: input.clientRequestToken ?? generateIdempotencyToken(), @@ -887,28 +1129,28 @@ export const serializeAws_restJson1UpdateNodegroupVersionCommand = async ( }); }; -export const deserializeAws_restJson1CreateClusterCommand = async ( +export const deserializeAws_restJson1CreateAddonCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode !== 200 && output.statusCode >= 300) { - return deserializeAws_restJson1CreateClusterCommandError(output, context); + return deserializeAws_restJson1CreateAddonCommandError(output, context); } - const contents: CreateClusterCommandOutput = { + const contents: CreateAddonCommandOutput = { $metadata: deserializeMetadata(output), - cluster: undefined, + addon: undefined, }; const data: any = await parseBody(output.body, context); - if (data.cluster !== undefined && data.cluster !== null) { - contents.cluster = deserializeAws_restJson1Cluster(data.cluster, context); + if (data.addon !== undefined && data.addon !== null) { + contents.addon = deserializeAws_restJson1Addon(data.addon, context); } return Promise.resolve(contents); }; -const deserializeAws_restJson1CreateClusterCommandError = async ( +const deserializeAws_restJson1CreateAddonCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -933,10 +1175,105 @@ const deserializeAws_restJson1CreateClusterCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "ResourceInUseException": - case "com.amazonaws.eks#ResourceInUseException": + case "InvalidRequestException": + case "com.amazonaws.eks#InvalidRequestException": response = { - ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceInUseException": + case "com.amazonaws.eks#ResourceInUseException": + response = { + ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateClusterCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateClusterCommandError(output, context); + } + const contents: CreateClusterCommandOutput = { + $metadata: deserializeMetadata(output), + cluster: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.cluster !== undefined && data.cluster !== null) { + contents.cluster = deserializeAws_restJson1Cluster(data.cluster, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateClusterCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "ClientException": + case "com.amazonaws.eks#ClientException": + response = { + ...(await deserializeAws_restJson1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceInUseException": + case "com.amazonaws.eks#ResourceInUseException": + response = { + ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -1188,6 +1525,93 @@ const deserializeAws_restJson1CreateNodegroupCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1DeleteAddonCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteAddonCommandError(output, context); + } + const contents: DeleteAddonCommandOutput = { + $metadata: deserializeMetadata(output), + addon: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.addon !== undefined && data.addon !== null) { + contents.addon = deserializeAws_restJson1Addon(data.addon, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteAddonCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "ClientException": + case "com.amazonaws.eks#ClientException": + response = { + ...(await deserializeAws_restJson1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.eks#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1DeleteClusterCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -1403,7 +1827,177 @@ const deserializeAws_restJson1DeleteNodegroupCommandError = async ( case "ResourceInUseException": case "com.amazonaws.eks#ResourceInUseException": response = { - ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), + ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.eks#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeAddonCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeAddonCommandError(output, context); + } + const contents: DescribeAddonCommandOutput = { + $metadata: deserializeMetadata(output), + addon: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.addon !== undefined && data.addon !== null) { + contents.addon = deserializeAws_restJson1Addon(data.addon, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeAddonCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "ClientException": + case "com.amazonaws.eks#ClientException": + response = { + ...(await deserializeAws_restJson1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.eks#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeAddonVersionsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeAddonVersionsCommandError(output, context); + } + const contents: DescribeAddonVersionsCommandOutput = { + $metadata: deserializeMetadata(output), + addons: undefined, + nextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.addons !== undefined && data.addons !== null) { + contents.addons = deserializeAws_restJson1Addons(data.addons, context); + } + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeAddonVersionsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -1424,14 +2018,6 @@ const deserializeAws_restJson1DeleteNodegroupCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "ServiceUnavailableException": - case "com.amazonaws.eks#ServiceUnavailableException": - response = { - ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -1773,6 +2359,97 @@ const deserializeAws_restJson1DescribeUpdateCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1ListAddonsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListAddonsCommandError(output, context); + } + const contents: ListAddonsCommandOutput = { + $metadata: deserializeMetadata(output), + addons: undefined, + nextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.addons !== undefined && data.addons !== null) { + contents.addons = deserializeAws_restJson1StringList(data.addons, context); + } + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListAddonsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "ClientException": + case "com.amazonaws.eks#ClientException": + response = { + ...(await deserializeAws_restJson1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.eks#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1ListClustersCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -2294,6 +2971,101 @@ const deserializeAws_restJson1UntagResourceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_restJson1UpdateAddonCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateAddonCommandError(output, context); + } + const contents: UpdateAddonCommandOutput = { + $metadata: deserializeMetadata(output), + update: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.update !== undefined && data.update !== null) { + contents.update = deserializeAws_restJson1Update(data.update, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateAddonCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "ClientException": + case "com.amazonaws.eks#ClientException": + response = { + ...(await deserializeAws_restJson1ClientExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidParameterException": + case "com.amazonaws.eks#InvalidParameterException": + response = { + ...(await deserializeAws_restJson1InvalidParameterExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InvalidRequestException": + case "com.amazonaws.eks#InvalidRequestException": + response = { + ...(await deserializeAws_restJson1InvalidRequestExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceInUseException": + case "com.amazonaws.eks#ResourceInUseException": + response = { + ...(await deserializeAws_restJson1ResourceInUseExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.eks#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServerException": + case "com.amazonaws.eks#ServerException": + response = { + ...(await deserializeAws_restJson1ServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_restJson1UpdateClusterConfigCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -2699,11 +3471,15 @@ const deserializeAws_restJson1ClientExceptionResponse = async ( name: "ClientException", $fault: "client", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -2724,12 +3500,16 @@ const deserializeAws_restJson1InvalidParameterExceptionResponse = async ( name: "InvalidParameterException", $fault: "client", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, fargateProfileName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -2753,11 +3533,15 @@ const deserializeAws_restJson1InvalidRequestExceptionResponse = async ( name: "InvalidRequestException", $fault: "client", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -2795,11 +3579,15 @@ const deserializeAws_restJson1ResourceInUseExceptionResponse = async ( name: "ResourceInUseException", $fault: "client", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -2845,12 +3633,16 @@ const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( name: "ResourceNotFoundException", $fault: "client", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, fargateProfileName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -2874,11 +3666,15 @@ const deserializeAws_restJson1ServerExceptionResponse = async ( name: "ServerException", $fault: "server", $metadata: deserializeMetadata(parsedOutput), + addonName: undefined, clusterName: undefined, message: undefined, nodegroupName: undefined, }; const data: any = parsedOutput.body; + if (data.addonName !== undefined && data.addonName !== null) { + contents.addonName = data.addonName; + } if (data.clusterName !== undefined && data.clusterName !== null) { contents.clusterName = data.clusterName; } @@ -3091,6 +3887,93 @@ const serializeAws_restJson1VpcConfigRequest = (input: VpcConfigRequest, context }; }; +const deserializeAws_restJson1Addon = (output: any, context: __SerdeContext): Addon => { + return { + addonArn: output.addonArn !== undefined && output.addonArn !== null ? output.addonArn : undefined, + addonName: output.addonName !== undefined && output.addonName !== null ? output.addonName : undefined, + addonVersion: output.addonVersion !== undefined && output.addonVersion !== null ? output.addonVersion : undefined, + clusterName: output.clusterName !== undefined && output.clusterName !== null ? output.clusterName : undefined, + createdAt: + output.createdAt !== undefined && output.createdAt !== null + ? new Date(Math.round(output.createdAt * 1000)) + : undefined, + health: + output.health !== undefined && output.health !== null + ? deserializeAws_restJson1AddonHealth(output.health, context) + : undefined, + modifiedAt: + output.modifiedAt !== undefined && output.modifiedAt !== null + ? new Date(Math.round(output.modifiedAt * 1000)) + : undefined, + serviceAccountRoleArn: + output.serviceAccountRoleArn !== undefined && output.serviceAccountRoleArn !== null + ? output.serviceAccountRoleArn + : undefined, + status: output.status !== undefined && output.status !== null ? output.status : undefined, + tags: + output.tags !== undefined && output.tags !== null + ? deserializeAws_restJson1TagMap(output.tags, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1AddonHealth = (output: any, context: __SerdeContext): AddonHealth => { + return { + issues: + output.issues !== undefined && output.issues !== null + ? deserializeAws_restJson1AddonIssueList(output.issues, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1AddonInfo = (output: any, context: __SerdeContext): AddonInfo => { + return { + addonName: output.addonName !== undefined && output.addonName !== null ? output.addonName : undefined, + addonVersions: + output.addonVersions !== undefined && output.addonVersions !== null + ? deserializeAws_restJson1AddonVersionInfoList(output.addonVersions, context) + : undefined, + type: output.type !== undefined && output.type !== null ? output.type : undefined, + } as any; +}; + +const deserializeAws_restJson1AddonIssue = (output: any, context: __SerdeContext): AddonIssue => { + return { + code: output.code !== undefined && output.code !== null ? output.code : undefined, + message: output.message !== undefined && output.message !== null ? output.message : undefined, + resourceIds: + output.resourceIds !== undefined && output.resourceIds !== null + ? deserializeAws_restJson1StringList(output.resourceIds, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1AddonIssueList = (output: any, context: __SerdeContext): AddonIssue[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1AddonIssue(entry, context)); +}; + +const deserializeAws_restJson1Addons = (output: any, context: __SerdeContext): AddonInfo[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1AddonInfo(entry, context)); +}; + +const deserializeAws_restJson1AddonVersionInfo = (output: any, context: __SerdeContext): AddonVersionInfo => { + return { + addonVersion: output.addonVersion !== undefined && output.addonVersion !== null ? output.addonVersion : undefined, + architecture: + output.architecture !== undefined && output.architecture !== null + ? deserializeAws_restJson1StringList(output.architecture, context) + : undefined, + compatibilities: + output.compatibilities !== undefined && output.compatibilities !== null + ? deserializeAws_restJson1Compatibilities(output.compatibilities, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1AddonVersionInfoList = (output: any, context: __SerdeContext): AddonVersionInfo[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1AddonVersionInfo(entry, context)); +}; + const deserializeAws_restJson1AutoScalingGroup = (output: any, context: __SerdeContext): AutoScalingGroup => { return { name: output.name !== undefined && output.name !== null ? output.name : undefined, @@ -3156,6 +4039,23 @@ const deserializeAws_restJson1Cluster = (output: any, context: __SerdeContext): } as any; }; +const deserializeAws_restJson1Compatibilities = (output: any, context: __SerdeContext): Compatibility[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1Compatibility(entry, context)); +}; + +const deserializeAws_restJson1Compatibility = (output: any, context: __SerdeContext): Compatibility => { + return { + clusterVersion: + output.clusterVersion !== undefined && output.clusterVersion !== null ? output.clusterVersion : undefined, + defaultVersion: + output.defaultVersion !== undefined && output.defaultVersion !== null ? output.defaultVersion : undefined, + platformVersions: + output.platformVersions !== undefined && output.platformVersions !== null + ? deserializeAws_restJson1StringList(output.platformVersions, context) + : undefined, + } as any; +}; + const deserializeAws_restJson1EncryptionConfig = (output: any, context: __SerdeContext): EncryptionConfig => { return { provider: @@ -3341,6 +4241,7 @@ const deserializeAws_restJson1LogTypes = (output: any, context: __SerdeContext): const deserializeAws_restJson1Nodegroup = (output: any, context: __SerdeContext): Nodegroup => { return { amiType: output.amiType !== undefined && output.amiType !== null ? output.amiType : undefined, + capacityType: output.capacityType !== undefined && output.capacityType !== null ? output.capacityType : undefined, clusterName: output.clusterName !== undefined && output.clusterName !== null ? output.clusterName : undefined, createdAt: output.createdAt !== undefined && output.createdAt !== null diff --git a/clients/client-honeycode/Honeycode.ts b/clients/client-honeycode/Honeycode.ts index 7b38410b1bf6..0d648c9bccec 100644 --- a/clients/client-honeycode/Honeycode.ts +++ b/clients/client-honeycode/Honeycode.ts @@ -1,4 +1,29 @@ import { HoneycodeClient } from "./HoneycodeClient"; +import { + BatchCreateTableRowsCommand, + BatchCreateTableRowsCommandInput, + BatchCreateTableRowsCommandOutput, +} from "./commands/BatchCreateTableRowsCommand"; +import { + BatchDeleteTableRowsCommand, + BatchDeleteTableRowsCommandInput, + BatchDeleteTableRowsCommandOutput, +} from "./commands/BatchDeleteTableRowsCommand"; +import { + BatchUpdateTableRowsCommand, + BatchUpdateTableRowsCommandInput, + BatchUpdateTableRowsCommandOutput, +} from "./commands/BatchUpdateTableRowsCommand"; +import { + BatchUpsertTableRowsCommand, + BatchUpsertTableRowsCommandInput, + BatchUpsertTableRowsCommandOutput, +} from "./commands/BatchUpsertTableRowsCommand"; +import { + DescribeTableDataImportJobCommand, + DescribeTableDataImportJobCommandInput, + DescribeTableDataImportJobCommandOutput, +} from "./commands/DescribeTableDataImportJobCommand"; import { GetScreenDataCommand, GetScreenDataCommandInput, @@ -9,6 +34,27 @@ import { InvokeScreenAutomationCommandInput, InvokeScreenAutomationCommandOutput, } from "./commands/InvokeScreenAutomationCommand"; +import { + ListTableColumnsCommand, + ListTableColumnsCommandInput, + ListTableColumnsCommandOutput, +} from "./commands/ListTableColumnsCommand"; +import { + ListTableRowsCommand, + ListTableRowsCommandInput, + ListTableRowsCommandOutput, +} from "./commands/ListTableRowsCommand"; +import { ListTablesCommand, ListTablesCommandInput, ListTablesCommandOutput } from "./commands/ListTablesCommand"; +import { + QueryTableRowsCommand, + QueryTableRowsCommandInput, + QueryTableRowsCommandOutput, +} from "./commands/QueryTableRowsCommand"; +import { + StartTableDataImportJobCommand, + StartTableDataImportJobCommandInput, + StartTableDataImportJobCommandOutput, +} from "./commands/StartTableDataImportJobCommand"; import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; /** @@ -19,6 +65,201 @@ import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; *

        */ export class Honeycode extends HoneycodeClient { + /** + *

        + * The BatchCreateTableRows API allows you to create one or more rows at the end of a table in a workbook. + * The API allows you to specify the values to set in some or all of the columns in the new rows. + *

        + *

        + * If a column is not explicitly set in a specific row, then the column level formula specified in the table + * will be applied to the new row. If there is no column level formula but the last row of the table has a + * formula, then that formula will be copied down to the new row. If there is no column level formula and + * no formula in the last row of the table, then that column will be left blank for the new rows. + *

        + */ + public batchCreateTableRows( + args: BatchCreateTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchCreateTableRows( + args: BatchCreateTableRowsCommandInput, + cb: (err: any, data?: BatchCreateTableRowsCommandOutput) => void + ): void; + public batchCreateTableRows( + args: BatchCreateTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchCreateTableRowsCommandOutput) => void + ): void; + public batchCreateTableRows( + args: BatchCreateTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchCreateTableRowsCommandOutput) => void), + cb?: (err: any, data?: BatchCreateTableRowsCommandOutput) => void + ): Promise | void { + const command = new BatchCreateTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The BatchDeleteTableRows API allows you to delete one or more rows from a table in a workbook. + * You need to specify the ids of the rows that you want to delete from the table. + *

        + */ + public batchDeleteTableRows( + args: BatchDeleteTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchDeleteTableRows( + args: BatchDeleteTableRowsCommandInput, + cb: (err: any, data?: BatchDeleteTableRowsCommandOutput) => void + ): void; + public batchDeleteTableRows( + args: BatchDeleteTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchDeleteTableRowsCommandOutput) => void + ): void; + public batchDeleteTableRows( + args: BatchDeleteTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchDeleteTableRowsCommandOutput) => void), + cb?: (err: any, data?: BatchDeleteTableRowsCommandOutput) => void + ): Promise | void { + const command = new BatchDeleteTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The BatchUpdateTableRows API allows you to update one or more rows in a table in a workbook. + *

        + *

        + * You can specify the values to set in some or all of the columns in the table for the specified + * rows. + * If a column is not explicitly specified in a particular row, then that column will not be updated + * for that row. To clear out the data in a specific cell, you need to set the value as an empty string + * (""). + *

        + */ + public batchUpdateTableRows( + args: BatchUpdateTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchUpdateTableRows( + args: BatchUpdateTableRowsCommandInput, + cb: (err: any, data?: BatchUpdateTableRowsCommandOutput) => void + ): void; + public batchUpdateTableRows( + args: BatchUpdateTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchUpdateTableRowsCommandOutput) => void + ): void; + public batchUpdateTableRows( + args: BatchUpdateTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchUpdateTableRowsCommandOutput) => void), + cb?: (err: any, data?: BatchUpdateTableRowsCommandOutput) => void + ): Promise | void { + const command = new BatchUpdateTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The BatchUpsertTableRows API allows you to upsert one or more rows in a table. The upsert + * operation takes a filter expression as input and evaluates it to find matching rows on the destination + * table. If matching rows are found, it will update the cells in the matching rows to new values specified + * in the request. If no matching rows are found, a new row is added at the end of the table and the cells in + * that row are set to the new values specified in the request. + *

        + *

        + * You can specify the values to set in some or all of the columns in the table for the + * matching or newly appended rows. If a column is not explicitly specified for a particular row, then that + * column will not be updated for that row. To clear out the data in a specific cell, you need to set the value + * as an empty string (""). + *

        + */ + public batchUpsertTableRows( + args: BatchUpsertTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public batchUpsertTableRows( + args: BatchUpsertTableRowsCommandInput, + cb: (err: any, data?: BatchUpsertTableRowsCommandOutput) => void + ): void; + public batchUpsertTableRows( + args: BatchUpsertTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: BatchUpsertTableRowsCommandOutput) => void + ): void; + public batchUpsertTableRows( + args: BatchUpsertTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: BatchUpsertTableRowsCommandOutput) => void), + cb?: (err: any, data?: BatchUpsertTableRowsCommandOutput) => void + ): Promise | void { + const command = new BatchUpsertTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The DescribeTableDataImportJob API allows you to retrieve the status and details of a table data import job. + *

        + */ + public describeTableDataImportJob( + args: DescribeTableDataImportJobCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeTableDataImportJob( + args: DescribeTableDataImportJobCommandInput, + cb: (err: any, data?: DescribeTableDataImportJobCommandOutput) => void + ): void; + public describeTableDataImportJob( + args: DescribeTableDataImportJobCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeTableDataImportJobCommandOutput) => void + ): void; + public describeTableDataImportJob( + args: DescribeTableDataImportJobCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeTableDataImportJobCommandOutput) => void), + cb?: (err: any, data?: DescribeTableDataImportJobCommandOutput) => void + ): Promise | void { + const command = new DescribeTableDataImportJobCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

        * The GetScreenData API allows retrieval of data from a screen in a Honeycode app. @@ -90,4 +331,170 @@ export class Honeycode extends HoneycodeClient { return this.send(command, optionsOrCb); } } + + /** + *

        + * The ListTableColumns API allows you to retrieve a list of all the columns in a table in a workbook. + *

        + */ + public listTableColumns( + args: ListTableColumnsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listTableColumns( + args: ListTableColumnsCommandInput, + cb: (err: any, data?: ListTableColumnsCommandOutput) => void + ): void; + public listTableColumns( + args: ListTableColumnsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListTableColumnsCommandOutput) => void + ): void; + public listTableColumns( + args: ListTableColumnsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListTableColumnsCommandOutput) => void), + cb?: (err: any, data?: ListTableColumnsCommandOutput) => void + ): Promise | void { + const command = new ListTableColumnsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The ListTableRows API allows you to retrieve a list of all the rows in a table in a workbook. + *

        + */ + public listTableRows( + args: ListTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listTableRows( + args: ListTableRowsCommandInput, + cb: (err: any, data?: ListTableRowsCommandOutput) => void + ): void; + public listTableRows( + args: ListTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListTableRowsCommandOutput) => void + ): void; + public listTableRows( + args: ListTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListTableRowsCommandOutput) => void), + cb?: (err: any, data?: ListTableRowsCommandOutput) => void + ): Promise | void { + const command = new ListTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The ListTables API allows you to retrieve a list of all the tables in a workbook. + *

        + */ + public listTables(args: ListTablesCommandInput, options?: __HttpHandlerOptions): Promise; + public listTables(args: ListTablesCommandInput, cb: (err: any, data?: ListTablesCommandOutput) => void): void; + public listTables( + args: ListTablesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListTablesCommandOutput) => void + ): void; + public listTables( + args: ListTablesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListTablesCommandOutput) => void), + cb?: (err: any, data?: ListTablesCommandOutput) => void + ): Promise | void { + const command = new ListTablesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The QueryTableRows API allows you to use a filter formula to query for specific rows in a table. + *

        + */ + public queryTableRows( + args: QueryTableRowsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public queryTableRows( + args: QueryTableRowsCommandInput, + cb: (err: any, data?: QueryTableRowsCommandOutput) => void + ): void; + public queryTableRows( + args: QueryTableRowsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: QueryTableRowsCommandOutput) => void + ): void; + public queryTableRows( + args: QueryTableRowsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: QueryTableRowsCommandOutput) => void), + cb?: (err: any, data?: QueryTableRowsCommandOutput) => void + ): Promise | void { + const command = new QueryTableRowsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        + * The StartTableDataImportJob API allows you to start an import job on a table. This API will only return + * the id of the job that was started. To find out the status of the import request, you need to call the + * DescribeTableDataImportJob API. + *

        + */ + public startTableDataImportJob( + args: StartTableDataImportJobCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public startTableDataImportJob( + args: StartTableDataImportJobCommandInput, + cb: (err: any, data?: StartTableDataImportJobCommandOutput) => void + ): void; + public startTableDataImportJob( + args: StartTableDataImportJobCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StartTableDataImportJobCommandOutput) => void + ): void; + public startTableDataImportJob( + args: StartTableDataImportJobCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StartTableDataImportJobCommandOutput) => void), + cb?: (err: any, data?: StartTableDataImportJobCommandOutput) => void + ): Promise | void { + const command = new StartTableDataImportJobCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } } diff --git a/clients/client-honeycode/HoneycodeClient.ts b/clients/client-honeycode/HoneycodeClient.ts index 0ef2dff88e49..950884a88ae4 100644 --- a/clients/client-honeycode/HoneycodeClient.ts +++ b/clients/client-honeycode/HoneycodeClient.ts @@ -1,8 +1,36 @@ +import { + BatchCreateTableRowsCommandInput, + BatchCreateTableRowsCommandOutput, +} from "./commands/BatchCreateTableRowsCommand"; +import { + BatchDeleteTableRowsCommandInput, + BatchDeleteTableRowsCommandOutput, +} from "./commands/BatchDeleteTableRowsCommand"; +import { + BatchUpdateTableRowsCommandInput, + BatchUpdateTableRowsCommandOutput, +} from "./commands/BatchUpdateTableRowsCommand"; +import { + BatchUpsertTableRowsCommandInput, + BatchUpsertTableRowsCommandOutput, +} from "./commands/BatchUpsertTableRowsCommand"; +import { + DescribeTableDataImportJobCommandInput, + DescribeTableDataImportJobCommandOutput, +} from "./commands/DescribeTableDataImportJobCommand"; import { GetScreenDataCommandInput, GetScreenDataCommandOutput } from "./commands/GetScreenDataCommand"; import { InvokeScreenAutomationCommandInput, InvokeScreenAutomationCommandOutput, } from "./commands/InvokeScreenAutomationCommand"; +import { ListTableColumnsCommandInput, ListTableColumnsCommandOutput } from "./commands/ListTableColumnsCommand"; +import { ListTableRowsCommandInput, ListTableRowsCommandOutput } from "./commands/ListTableRowsCommand"; +import { ListTablesCommandInput, ListTablesCommandOutput } from "./commands/ListTablesCommand"; +import { QueryTableRowsCommandInput, QueryTableRowsCommandOutput } from "./commands/QueryTableRowsCommand"; +import { + StartTableDataImportJobCommandInput, + StartTableDataImportJobCommandOutput, +} from "./commands/StartTableDataImportJobCommand"; import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; import { EndpointsInputConfig, @@ -52,9 +80,33 @@ import { UrlParser as __UrlParser, } from "@aws-sdk/types"; -export type ServiceInputTypes = GetScreenDataCommandInput | InvokeScreenAutomationCommandInput; +export type ServiceInputTypes = + | BatchCreateTableRowsCommandInput + | BatchDeleteTableRowsCommandInput + | BatchUpdateTableRowsCommandInput + | BatchUpsertTableRowsCommandInput + | DescribeTableDataImportJobCommandInput + | GetScreenDataCommandInput + | InvokeScreenAutomationCommandInput + | ListTableColumnsCommandInput + | ListTableRowsCommandInput + | ListTablesCommandInput + | QueryTableRowsCommandInput + | StartTableDataImportJobCommandInput; -export type ServiceOutputTypes = GetScreenDataCommandOutput | InvokeScreenAutomationCommandOutput; +export type ServiceOutputTypes = + | BatchCreateTableRowsCommandOutput + | BatchDeleteTableRowsCommandOutput + | BatchUpdateTableRowsCommandOutput + | BatchUpsertTableRowsCommandOutput + | DescribeTableDataImportJobCommandOutput + | GetScreenDataCommandOutput + | InvokeScreenAutomationCommandOutput + | ListTableColumnsCommandOutput + | ListTableRowsCommandOutput + | ListTablesCommandOutput + | QueryTableRowsCommandOutput + | StartTableDataImportJobCommandOutput; export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { /** diff --git a/clients/client-honeycode/commands/BatchCreateTableRowsCommand.ts b/clients/client-honeycode/commands/BatchCreateTableRowsCommand.ts new file mode 100644 index 000000000000..faa8cda32a54 --- /dev/null +++ b/clients/client-honeycode/commands/BatchCreateTableRowsCommand.ts @@ -0,0 +1,97 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { BatchCreateTableRowsRequest, BatchCreateTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1BatchCreateTableRowsCommand, + serializeAws_restJson1BatchCreateTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchCreateTableRowsCommandInput = BatchCreateTableRowsRequest; +export type BatchCreateTableRowsCommandOutput = BatchCreateTableRowsResult & __MetadataBearer; + +/** + *

        + * The BatchCreateTableRows API allows you to create one or more rows at the end of a table in a workbook. + * The API allows you to specify the values to set in some or all of the columns in the new rows. + *

        + *

        + * If a column is not explicitly set in a specific row, then the column level formula specified in the table + * will be applied to the new row. If there is no column level formula but the last row of the table has a + * formula, then that formula will be copied down to the new row. If there is no column level formula and + * no formula in the last row of the table, then that column will be left blank for the new rows. + *

        + */ +export class BatchCreateTableRowsCommand extends $Command< + BatchCreateTableRowsCommandInput, + BatchCreateTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchCreateTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "BatchCreateTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchCreateTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchCreateTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchCreateTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1BatchCreateTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1BatchCreateTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/BatchDeleteTableRowsCommand.ts b/clients/client-honeycode/commands/BatchDeleteTableRowsCommand.ts new file mode 100644 index 000000000000..6fc55534ac7e --- /dev/null +++ b/clients/client-honeycode/commands/BatchDeleteTableRowsCommand.ts @@ -0,0 +1,91 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { BatchDeleteTableRowsRequest, BatchDeleteTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1BatchDeleteTableRowsCommand, + serializeAws_restJson1BatchDeleteTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchDeleteTableRowsCommandInput = BatchDeleteTableRowsRequest; +export type BatchDeleteTableRowsCommandOutput = BatchDeleteTableRowsResult & __MetadataBearer; + +/** + *

        + * The BatchDeleteTableRows API allows you to delete one or more rows from a table in a workbook. + * You need to specify the ids of the rows that you want to delete from the table. + *

        + */ +export class BatchDeleteTableRowsCommand extends $Command< + BatchDeleteTableRowsCommandInput, + BatchDeleteTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchDeleteTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "BatchDeleteTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchDeleteTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchDeleteTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchDeleteTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1BatchDeleteTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1BatchDeleteTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/BatchUpdateTableRowsCommand.ts b/clients/client-honeycode/commands/BatchUpdateTableRowsCommand.ts new file mode 100644 index 000000000000..1b0995693daf --- /dev/null +++ b/clients/client-honeycode/commands/BatchUpdateTableRowsCommand.ts @@ -0,0 +1,97 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { BatchUpdateTableRowsRequest, BatchUpdateTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1BatchUpdateTableRowsCommand, + serializeAws_restJson1BatchUpdateTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchUpdateTableRowsCommandInput = BatchUpdateTableRowsRequest; +export type BatchUpdateTableRowsCommandOutput = BatchUpdateTableRowsResult & __MetadataBearer; + +/** + *

        + * The BatchUpdateTableRows API allows you to update one or more rows in a table in a workbook. + *

        + *

        + * You can specify the values to set in some or all of the columns in the table for the specified + * rows. + * If a column is not explicitly specified in a particular row, then that column will not be updated + * for that row. To clear out the data in a specific cell, you need to set the value as an empty string + * (""). + *

        + */ +export class BatchUpdateTableRowsCommand extends $Command< + BatchUpdateTableRowsCommandInput, + BatchUpdateTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchUpdateTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "BatchUpdateTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchUpdateTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchUpdateTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchUpdateTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1BatchUpdateTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1BatchUpdateTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/BatchUpsertTableRowsCommand.ts b/clients/client-honeycode/commands/BatchUpsertTableRowsCommand.ts new file mode 100644 index 000000000000..080d167b1b76 --- /dev/null +++ b/clients/client-honeycode/commands/BatchUpsertTableRowsCommand.ts @@ -0,0 +1,100 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { BatchUpsertTableRowsRequest, BatchUpsertTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1BatchUpsertTableRowsCommand, + serializeAws_restJson1BatchUpsertTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type BatchUpsertTableRowsCommandInput = BatchUpsertTableRowsRequest; +export type BatchUpsertTableRowsCommandOutput = BatchUpsertTableRowsResult & __MetadataBearer; + +/** + *

        + * The BatchUpsertTableRows API allows you to upsert one or more rows in a table. The upsert + * operation takes a filter expression as input and evaluates it to find matching rows on the destination + * table. If matching rows are found, it will update the cells in the matching rows to new values specified + * in the request. If no matching rows are found, a new row is added at the end of the table and the cells in + * that row are set to the new values specified in the request. + *

        + *

        + * You can specify the values to set in some or all of the columns in the table for the + * matching or newly appended rows. If a column is not explicitly specified for a particular row, then that + * column will not be updated for that row. To clear out the data in a specific cell, you need to set the value + * as an empty string (""). + *

        + */ +export class BatchUpsertTableRowsCommand extends $Command< + BatchUpsertTableRowsCommandInput, + BatchUpsertTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: BatchUpsertTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "BatchUpsertTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: BatchUpsertTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: BatchUpsertTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: BatchUpsertTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1BatchUpsertTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1BatchUpsertTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/DescribeTableDataImportJobCommand.ts b/clients/client-honeycode/commands/DescribeTableDataImportJobCommand.ts new file mode 100644 index 000000000000..1256b20cefc4 --- /dev/null +++ b/clients/client-honeycode/commands/DescribeTableDataImportJobCommand.ts @@ -0,0 +1,93 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { DescribeTableDataImportJobRequest, DescribeTableDataImportJobResult } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeTableDataImportJobCommand, + serializeAws_restJson1DescribeTableDataImportJobCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeTableDataImportJobCommandInput = DescribeTableDataImportJobRequest; +export type DescribeTableDataImportJobCommandOutput = DescribeTableDataImportJobResult & __MetadataBearer; + +/** + *

        + * The DescribeTableDataImportJob API allows you to retrieve the status and details of a table data import job. + *

        + */ +export class DescribeTableDataImportJobCommand extends $Command< + DescribeTableDataImportJobCommandInput, + DescribeTableDataImportJobCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeTableDataImportJobCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "DescribeTableDataImportJobCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeTableDataImportJobRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeTableDataImportJobResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeTableDataImportJobCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeTableDataImportJobCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_restJson1DescribeTableDataImportJobCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/ListTableColumnsCommand.ts b/clients/client-honeycode/commands/ListTableColumnsCommand.ts new file mode 100644 index 000000000000..f5a47591b2c7 --- /dev/null +++ b/clients/client-honeycode/commands/ListTableColumnsCommand.ts @@ -0,0 +1,90 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { ListTableColumnsRequest, ListTableColumnsResult } from "../models/models_0"; +import { + deserializeAws_restJson1ListTableColumnsCommand, + serializeAws_restJson1ListTableColumnsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListTableColumnsCommandInput = ListTableColumnsRequest; +export type ListTableColumnsCommandOutput = ListTableColumnsResult & __MetadataBearer; + +/** + *

        + * The ListTableColumns API allows you to retrieve a list of all the columns in a table in a workbook. + *

        + */ +export class ListTableColumnsCommand extends $Command< + ListTableColumnsCommandInput, + ListTableColumnsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListTableColumnsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "ListTableColumnsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListTableColumnsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListTableColumnsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListTableColumnsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListTableColumnsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListTableColumnsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/ListTableRowsCommand.ts b/clients/client-honeycode/commands/ListTableRowsCommand.ts new file mode 100644 index 000000000000..74ed39a5bc8f --- /dev/null +++ b/clients/client-honeycode/commands/ListTableRowsCommand.ts @@ -0,0 +1,90 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { ListTableRowsRequest, ListTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1ListTableRowsCommand, + serializeAws_restJson1ListTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListTableRowsCommandInput = ListTableRowsRequest; +export type ListTableRowsCommandOutput = ListTableRowsResult & __MetadataBearer; + +/** + *

        + * The ListTableRows API allows you to retrieve a list of all the rows in a table in a workbook. + *

        + */ +export class ListTableRowsCommand extends $Command< + ListTableRowsCommandInput, + ListTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "ListTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/ListTablesCommand.ts b/clients/client-honeycode/commands/ListTablesCommand.ts new file mode 100644 index 000000000000..fcae066eb886 --- /dev/null +++ b/clients/client-honeycode/commands/ListTablesCommand.ts @@ -0,0 +1,90 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { ListTablesRequest, ListTablesResult } from "../models/models_0"; +import { + deserializeAws_restJson1ListTablesCommand, + serializeAws_restJson1ListTablesCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListTablesCommandInput = ListTablesRequest; +export type ListTablesCommandOutput = ListTablesResult & __MetadataBearer; + +/** + *

        + * The ListTables API allows you to retrieve a list of all the tables in a workbook. + *

        + */ +export class ListTablesCommand extends $Command< + ListTablesCommandInput, + ListTablesCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListTablesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "ListTablesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListTablesRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListTablesResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListTablesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListTablesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListTablesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/QueryTableRowsCommand.ts b/clients/client-honeycode/commands/QueryTableRowsCommand.ts new file mode 100644 index 000000000000..41c1daf10589 --- /dev/null +++ b/clients/client-honeycode/commands/QueryTableRowsCommand.ts @@ -0,0 +1,90 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { QueryTableRowsRequest, QueryTableRowsResult } from "../models/models_0"; +import { + deserializeAws_restJson1QueryTableRowsCommand, + serializeAws_restJson1QueryTableRowsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type QueryTableRowsCommandInput = QueryTableRowsRequest; +export type QueryTableRowsCommandOutput = QueryTableRowsResult & __MetadataBearer; + +/** + *

        + * The QueryTableRows API allows you to use a filter formula to query for specific rows in a table. + *

        + */ +export class QueryTableRowsCommand extends $Command< + QueryTableRowsCommandInput, + QueryTableRowsCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: QueryTableRowsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "QueryTableRowsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: QueryTableRowsRequest.filterSensitiveLog, + outputFilterSensitiveLog: QueryTableRowsResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: QueryTableRowsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1QueryTableRowsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1QueryTableRowsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/commands/StartTableDataImportJobCommand.ts b/clients/client-honeycode/commands/StartTableDataImportJobCommand.ts new file mode 100644 index 000000000000..89c2f4a5c05c --- /dev/null +++ b/clients/client-honeycode/commands/StartTableDataImportJobCommand.ts @@ -0,0 +1,92 @@ +import { HoneycodeClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../HoneycodeClient"; +import { StartTableDataImportJobRequest, StartTableDataImportJobResult } from "../models/models_0"; +import { + deserializeAws_restJson1StartTableDataImportJobCommand, + serializeAws_restJson1StartTableDataImportJobCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StartTableDataImportJobCommandInput = StartTableDataImportJobRequest; +export type StartTableDataImportJobCommandOutput = StartTableDataImportJobResult & __MetadataBearer; + +/** + *

        + * The StartTableDataImportJob API allows you to start an import job on a table. This API will only return + * the id of the job that was started. To find out the status of the import request, you need to call the + * DescribeTableDataImportJob API. + *

        + */ +export class StartTableDataImportJobCommand extends $Command< + StartTableDataImportJobCommandInput, + StartTableDataImportJobCommandOutput, + HoneycodeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StartTableDataImportJobCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: HoneycodeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "HoneycodeClient"; + const commandName = "StartTableDataImportJobCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StartTableDataImportJobRequest.filterSensitiveLog, + outputFilterSensitiveLog: StartTableDataImportJobResult.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StartTableDataImportJobCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1StartTableDataImportJobCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1StartTableDataImportJobCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-honeycode/index.ts b/clients/client-honeycode/index.ts index f8fa033b7082..2d232be50101 100644 --- a/clients/client-honeycode/index.ts +++ b/clients/client-honeycode/index.ts @@ -1,5 +1,20 @@ export * from "./HoneycodeClient"; export * from "./Honeycode"; +export * from "./commands/BatchCreateTableRowsCommand"; +export * from "./commands/BatchDeleteTableRowsCommand"; +export * from "./commands/BatchUpdateTableRowsCommand"; +export * from "./commands/BatchUpsertTableRowsCommand"; +export * from "./commands/DescribeTableDataImportJobCommand"; export * from "./commands/GetScreenDataCommand"; export * from "./commands/InvokeScreenAutomationCommand"; +export * from "./commands/ListTableColumnsCommand"; +export * from "./pagination/ListTableColumnsPaginator"; +export * from "./commands/ListTableRowsCommand"; +export * from "./pagination/ListTableRowsPaginator"; +export * from "./commands/ListTablesCommand"; +export * from "./pagination/ListTablesPaginator"; +export * from "./commands/QueryTableRowsCommand"; +export * from "./pagination/QueryTableRowsPaginator"; +export * from "./commands/StartTableDataImportJobCommand"; +export * from "./pagination/Interfaces"; export * from "./models/index"; diff --git a/clients/client-honeycode/models/models_0.ts b/clients/client-honeycode/models/models_0.ts index 0c075107321d..99284e7d7db0 100644 --- a/clients/client-honeycode/models/models_0.ts +++ b/clients/client-honeycode/models/models_0.ts @@ -4,7 +4,7 @@ import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; /** *

        * You do not have sufficient access to perform this action. Check that the workbook is owned by you and your - * IAM policy allows access to the screen/automation in the request. + * IAM policy allows access to the resource in the request. *

        */ export interface AccessDeniedException extends __SmithyException, $MetadataBearer { @@ -49,229 +49,174 @@ export namespace AutomationExecutionTimeoutException { }); } -export enum Format { - Accounting = "ACCOUNTING", - Auto = "AUTO", - Contact = "CONTACT", - Currency = "CURRENCY", - Date = "DATE", - DateTime = "DATE_TIME", - Number = "NUMBER", - Percentage = "PERCENTAGE", - Rowlink = "ROWLINK", - Text = "TEXT", - Time = "TIME", -} - /** - *

        Metadata for column in the table.

        + *

        + * CellInput object contains the data needed to create or update cells in a table. + *

        */ -export interface ColumnMetadata { - /** - *

        The name of the column.

        - */ - name: string | undefined; - +export interface CellInput { /** - *

        The format of the column.

        + *

        + * Fact represents the data that is entered into a cell. This data can be free text or a formula. Formulas need + * to start with the equals (=) sign. + *

        */ - format: Format | string | undefined; + fact?: string; } -export namespace ColumnMetadata { - export const filterSensitiveLog = (obj: ColumnMetadata): any => ({ +export namespace CellInput { + export const filterSensitiveLog = (obj: CellInput): any => ({ ...obj, - ...(obj.name && { name: SENSITIVE_STRING }), + ...(obj.fact && { fact: SENSITIVE_STRING }), }); } /** - *

        The data in a particular data cell defined on the screen.

        + *

        + * Data needed to create a single row in a table as part of the BatchCreateTableRows request. + *

        */ -export interface DataItem { - /** - *

        The formatted value of the data. e.g. John Smith.

        - */ - formattedValue?: string; - +export interface CreateRowData { /** *

        - * The overrideFormat is optional and is specified only if a particular row of data has a different format for - * the data than the default format defined on the screen or the table. + * An external identifier that represents the single row that is being created as part of the + * BatchCreateTableRows request. This can be any string that you can use to identify the row in the request. + * The BatchCreateTableRows API puts the batch item id in the results to allow you to link data in the + * request to data in the results. *

        */ - overrideFormat?: Format | string; + batchItemId: string | undefined; /** - *

        The raw value of the data. e.g. jsmith@example.com

        + *

        + * A map representing the cells to create in the new row. The key is the column id of the + * cell and the value is the CellInput object that represents the data to set in that cell. + *

        */ - rawValue?: string; + cellsToCreate: { [key: string]: CellInput } | undefined; } -export namespace DataItem { - export const filterSensitiveLog = (obj: DataItem): any => ({ +export namespace CreateRowData { + export const filterSensitiveLog = (obj: CreateRowData): any => ({ ...obj, + ...(obj.cellsToCreate && { + cellsToCreate: Object.entries(obj.cellsToCreate).reduce( + (acc: any, [key, value]: [string, CellInput]) => ({ + ...acc, + [key]: CellInput.filterSensitiveLog(value), + }), + {} + ), + }), }); } -/** - *

        The input variables to the app to be used by the InvokeScreenAutomation action request.

        - */ -export interface VariableValue { +export interface BatchCreateTableRowsRequest { /** - *

        Raw value of the variable.

        + *

        The ID of the workbook where the new rows are being added.

        + *

        + * If a workbook with the specified ID could not be found, this API throws ResourceNotFoundException. + *

        */ - rawValue: string | undefined; -} - -export namespace VariableValue { - export const filterSensitiveLog = (obj: VariableValue): any => ({ - ...obj, - }); -} + workbookId: string | undefined; -export interface GetScreenDataRequest { /** - *

        - * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. - *

        + *

        The ID of the table where the new rows are being added.

        *

        - * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API - * will throw ValidationException. + * If a table with the specified ID could not be found, this API throws ResourceNotFoundException. *

        */ - nextToken?: string; + tableId: string | undefined; /** *

        - * Variables are optional and are needed only if the screen requires them to render correctly. Variables are - * specified as a map where the key is the name of the variable as defined on the screen. The value is an - * object which currently has only one property, rawValue, which holds the value of the variable to be passed - * to the screen. + * The list of rows to create at the end of the table. Each item in this list needs to have a batch item id + * to uniquely identify the element in the request and the cells to create for that row. + * You need to specify at least one item in this list. + *

        + *

        + * Note that if one of the column ids in any of the rows in the request does not exist in the table, then the + * request fails and no updates are made to the table. *

        */ - variables?: { [key: string]: VariableValue }; - - /** - *

        The ID of the app that contains the screem.

        - */ - appId: string | undefined; + rowsToCreate: CreateRowData[] | undefined; /** *

        - * The number of results to be returned on a single page. - * Specify a number between 1 and 100. The maximum value is 100. + * The request token for performing the batch create operation. + * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error + * like a failed network connection, you can retry the call with the same request token. The service ensures + * that if the first call using that request token is successfully performed, the second call will not perform + * the operation again. *

        *

        - * This parameter is optional. If you don't specify this parameter, the default page size is 100. + * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests + * spanning hours or days. *

        */ - maxResults?: number; - - /** - *

        The ID of the screen.

        - */ - screenId: string | undefined; - - /** - *

        The ID of the workbook that contains the screen.

        - */ - workbookId: string | undefined; -} - -export namespace GetScreenDataRequest { - export const filterSensitiveLog = (obj: GetScreenDataRequest): any => ({ - ...obj, - ...(obj.variables && { variables: SENSITIVE_STRING }), - }); -} - -/** - *

        A single row in the ResultSet.

        - */ -export interface ResultRow { - /** - *

        The ID for a particular row.

        - */ - rowId?: string; - - /** - *

        List of all the data cells in a row.

        - */ - dataItems: DataItem[] | undefined; + clientRequestToken?: string; } -export namespace ResultRow { - export const filterSensitiveLog = (obj: ResultRow): any => ({ +export namespace BatchCreateTableRowsRequest { + export const filterSensitiveLog = (obj: BatchCreateTableRowsRequest): any => ({ ...obj, - ...(obj.dataItems && { dataItems: SENSITIVE_STRING }), + ...(obj.rowsToCreate && { rowsToCreate: obj.rowsToCreate.map((item) => CreateRowData.filterSensitiveLog(item)) }), }); } /** *

        - * ResultSet contains the results of the request for a single block or list defined on the screen. + * A single item in a batch that failed to perform the intended action because of an error preventing it from + * succeeding. *

        */ -export interface ResultSet { +export interface FailedBatchItem { /** *

        - * List of rows returned by the request. Each row has a row Id and a list of data cells in that row. The data - * cells will be present in the same order as they are defined in the header. + * The id of the batch item that failed. This is the batch item id for the BatchCreateTableRows and + * BatchUpsertTableRows operations and the row id for the BatchUpdateTableRows and BatchDeleteTableRows + * operations. *

        */ - rows: ResultRow[] | undefined; + id: string | undefined; /** *

        - * List of headers for all the data cells in the block. The header identifies the name and default format of - * the data cell. Data cells appear in the same order in all rows as defined in the header. The names and - * formats are not repeated in the rows. If a particular row does not have a value for a data cell, a blank - * value is used. - *

        - *

        - * For example, a task list that displays the task name, due date and assigned person might have headers - * [ { "name": "Task Name"}, {"name": "Due Date", "format": "DATE"}, {"name": "Assigned", "format": "CONTACT"} ]. - * Every row in the result will have the task name as the first item, due date as the second item and assigned - * person as the third item. If a particular task does not have a due date, that row will still have a blank - * value in the second element and the assigned person will still be in the third element. + * The error message that indicates why the batch item failed. *

        */ - headers: ColumnMetadata[] | undefined; + errorMessage: string | undefined; } -export namespace ResultSet { - export const filterSensitiveLog = (obj: ResultSet): any => ({ +export namespace FailedBatchItem { + export const filterSensitiveLog = (obj: FailedBatchItem): any => ({ ...obj, - ...(obj.headers && { headers: obj.headers.map((item) => ColumnMetadata.filterSensitiveLog(item)) }), }); } -export interface GetScreenDataResult { +export interface BatchCreateTableRowsResult { /** - *

        - * Provides the pagination token to load the next page if there are more results matching the request. If a - * pagination token is not present in the response, it means that all data matching the query has been loaded. - *

        + *

        The updated workbook cursor after adding the new rows at the end of the table.

        */ - nextToken?: string; + workbookCursor: number | undefined; /** - *

        - * Indicates the cursor of the workbook at which the data returned by this workbook is read. Workbook cursor - * keeps increasing with every update and the increments are not sequential. - *

        + *

        The map of batch item id to the row id that was created for that item.

        */ - workbookCursor: number | undefined; + createdRows: { [key: string]: string } | undefined; /** - *

        A map of all the rows on the screen keyed by block name.

        + *

        + * The list of batch items in the request that could not be added to the table. Each element in this list + * contains one item from the request that could not be added to the table along with the reason why + * that item could not be added. + *

        */ - results: { [key: string]: ResultSet } | undefined; + failedBatchItems?: FailedBatchItem[]; } -export namespace GetScreenDataResult { - export const filterSensitiveLog = (obj: GetScreenDataResult): any => ({ +export namespace BatchCreateTableRowsResult { + export const filterSensitiveLog = (obj: BatchCreateTableRowsResult): any => ({ ...obj, }); } @@ -307,7 +252,7 @@ export namespace RequestTimeoutException { } /** - *

        A Workbook, App, Screen or Screen Automation was not found with the given ID.

        + *

        A Workbook, Table, App, Screen or Screen Automation was not found with the given ID.

        */ export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { name: "ResourceNotFoundException"; @@ -321,6 +266,23 @@ export namespace ResourceNotFoundException { }); } +/** + *

        + * The request caused service quota to be breached. + *

        + */ +export interface ServiceQuotaExceededException extends __SmithyException, $MetadataBearer { + name: "ServiceQuotaExceededException"; + $fault: "client"; + message: string | undefined; +} + +export namespace ServiceQuotaExceededException { + export const filterSensitiveLog = (obj: ServiceQuotaExceededException): any => ({ + ...obj, + }); +} + /** *

        Remote service is unreachable.

        */ @@ -368,26 +330,41 @@ export namespace ValidationException { }); } -export interface InvokeScreenAutomationRequest { +export interface BatchDeleteTableRowsRequest { /** - *

        The ID of the workbook that contains the screen automation.

        + *

        The ID of the workbook where the rows are being deleted.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        */ workbookId: string | undefined; + /** + *

        The ID of the table where the rows are being deleted.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + /** *

        - * The row ID for the automation if the automation is defined inside a block with source or list. + * The list of row ids to delete from the table. You need to specify at least one row id in this list. + *

        + *

        + * Note that if one of the row ids provided in the request does not exist in the table, then the request fails + * and no rows are deleted from the table. *

        */ - rowId?: string; + rowIds: string[] | undefined; /** *

        - * The request token for performing the automation action. + * The request token for performing the delete action. * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error * like a failed network connection, you can retry the call with the same request token. The service ensures - * that if the first call using that request token is successfully performed, the second call will return the - * response of the previous call rather than performing the action again. + * that if the first call using that request token is successfully performed, the second call will not perform + * the action again. *

        *

        * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests @@ -395,45 +372,1001 @@ export interface InvokeScreenAutomationRequest { *

        */ clientRequestToken?: string; +} + +export namespace BatchDeleteTableRowsRequest { + export const filterSensitiveLog = (obj: BatchDeleteTableRowsRequest): any => ({ + ...obj, + }); +} +export interface BatchDeleteTableRowsResult { /** - *

        The ID of the screen that contains the screen automation.

        + *

        The updated workbook cursor after deleting the rows from the table.

        */ - screenId: string | undefined; + workbookCursor: number | undefined; /** - *

        The ID of the app that contains the screen automation.

        + *

        + * The list of row ids in the request that could not be deleted from the table. Each element in this list + * contains one row id from the request that could not be deleted along with the reason why that item could not + * be deleted. + *

        */ - appId: string | undefined; + failedBatchItems?: FailedBatchItem[]; +} + +export namespace BatchDeleteTableRowsResult { + export const filterSensitiveLog = (obj: BatchDeleteTableRowsResult): any => ({ + ...obj, + }); +} +/** + *

        + * Data needed to create a single row in a table as part of the BatchCreateTableRows request. + *

        + */ +export interface UpdateRowData { /** - *

        The ID of the automation action to be performed.

        + *

        + * The id of the row that needs to be updated. + *

        */ - screenAutomationId: string | undefined; + rowId: string | undefined; /** *

        - * Variables are optional and are needed only if the screen requires them to render correctly. Variables are - * specified as a map where the key is the name of the variable as defined on the screen. The value is an - * object which currently has only one property, rawValue, which holds the value of the variable to be passed - * to the screen. + * A map representing the cells to update in the given row. The key is the column id of the + * cell and the value is the CellInput object that represents the data to set in that cell. *

        */ - variables?: { [key: string]: VariableValue }; + cellsToUpdate: { [key: string]: CellInput } | undefined; } -export namespace InvokeScreenAutomationRequest { - export const filterSensitiveLog = (obj: InvokeScreenAutomationRequest): any => ({ +export namespace UpdateRowData { + export const filterSensitiveLog = (obj: UpdateRowData): any => ({ ...obj, - ...(obj.variables && { variables: SENSITIVE_STRING }), + ...(obj.cellsToUpdate && { + cellsToUpdate: Object.entries(obj.cellsToUpdate).reduce( + (acc: any, [key, value]: [string, CellInput]) => ({ + ...acc, + [key]: CellInput.filterSensitiveLog(value), + }), + {} + ), + }), }); } -export interface InvokeScreenAutomationResult { +export interface BatchUpdateTableRowsRequest { /** - *

        The updated workbook cursor after performing the automation action.

        + *

        The ID of the workbook where the rows are being updated.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        */ - workbookCursor: number | undefined; + workbookId: string | undefined; + + /** + *

        The ID of the table where the rows are being updated.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        + * The list of rows to update in the table. Each item in this list needs to contain the row id to update + * along with the map of column id to cell values for each column in that row that needs to be updated. + * You need to specify at least one row in this list, and for each row, you need to specify at least one + * column to update. + *

        + *

        + * Note that if one of the row or column ids in the request does not exist in the table, then the request fails + * and no updates are made to the table. + *

        + */ + rowsToUpdate: UpdateRowData[] | undefined; + + /** + *

        + * The request token for performing the update action. + * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error + * like a failed network connection, you can retry the call with the same request token. The service ensures + * that if the first call using that request token is successfully performed, the second call will not perform + * the action again. + *

        + *

        + * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests + * spanning hours or days. + *

        + */ + clientRequestToken?: string; +} + +export namespace BatchUpdateTableRowsRequest { + export const filterSensitiveLog = (obj: BatchUpdateTableRowsRequest): any => ({ + ...obj, + ...(obj.rowsToUpdate && { rowsToUpdate: obj.rowsToUpdate.map((item) => UpdateRowData.filterSensitiveLog(item)) }), + }); +} + +export interface BatchUpdateTableRowsResult { + /** + *

        The updated workbook cursor after adding the new rows at the end of the table.

        + */ + workbookCursor: number | undefined; + + /** + *

        + * The list of batch items in the request that could not be updated in the table. Each element in this list + * contains one item from the request that could not be updated in the table along with the reason why + * that item could not be updated. + *

        + */ + failedBatchItems?: FailedBatchItem[]; +} + +export namespace BatchUpdateTableRowsResult { + export const filterSensitiveLog = (obj: BatchUpdateTableRowsResult): any => ({ + ...obj, + }); +} + +/** + *

        + * An object that represents a filter formula along with the id of the context row under which the filter + * function needs to evaluate. + *

        + */ +export interface Filter { + /** + *

        + * A formula representing a filter function that returns zero or more matching rows from a table. Valid + * formulas in this field return a list of rows from a table. The most common ways of writing a formula to + * return a list of rows are to use the FindRow() or Filter() functions. Any other formula that returns zero or + * more rows is also acceptable. For example, you can use a formula that points to a cell that contains a + * filter function. + *

        + */ + formula: string | undefined; + + /** + *

        + * The optional contextRowId attribute can be used to specify the row id of the context row if the filter + * formula contains unqualified references to table columns and needs a context row to evaluate them + * successfully. + *

        + */ + contextRowId?: string; +} + +export namespace Filter { + export const filterSensitiveLog = (obj: Filter): any => ({ + ...obj, + ...(obj.formula && { formula: SENSITIVE_STRING }), + }); +} + +/** + *

        + * Data needed to upsert rows in a table as part of a single item in the BatchUpsertTableRows request. + *

        + */ +export interface UpsertRowData { + /** + *

        + * An external identifier that represents a single item in the request that is being upserted as part of the + * BatchUpsertTableRows request. This can be any string that you can use to identify the item in the request. + * The BatchUpsertTableRows API puts the batch item id in the results to allow you to link data in the + * request to data in the results. + *

        + */ + batchItemId: string | undefined; + + /** + *

        + * The filter formula to use to find existing matching rows to update. The formula needs to return zero or more + * rows. If the formula returns 0 rows, then a new row will be appended in the target table. If the formula + * returns one or more rows, then the returned rows will be updated. + *

        + *

        + * Note that the filter formula needs to return rows from the target table for the upsert operation to succeed. + * If the filter formula has a syntax error or it doesn't evaluate to zero or more rows in the target table + * for any one item in the input list, then the entire BatchUpsertTableRows request fails and no updates are + * made to the table. + *

        + */ + filter: Filter | undefined; + + /** + *

        + * A map representing the cells to update for the matching rows or an appended row. The key is the column id + * of the cell and the value is the CellInput object that represents the data to set in that cell. + *

        + */ + cellsToUpdate: { [key: string]: CellInput } | undefined; +} + +export namespace UpsertRowData { + export const filterSensitiveLog = (obj: UpsertRowData): any => ({ + ...obj, + ...(obj.filter && { filter: Filter.filterSensitiveLog(obj.filter) }), + ...(obj.cellsToUpdate && { + cellsToUpdate: Object.entries(obj.cellsToUpdate).reduce( + (acc: any, [key, value]: [string, CellInput]) => ({ + ...acc, + [key]: CellInput.filterSensitiveLog(value), + }), + {} + ), + }), + }); +} + +export interface BatchUpsertTableRowsRequest { + /** + *

        The ID of the workbook where the rows are being upserted.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the table where the rows are being upserted.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        + * The list of rows to upsert in the table. Each item in this list needs to have a batch item id to uniquely + * identify the element in the request, a filter expression to find the rows to update for that element + * and the cell values to set for each column in the upserted rows. You need to specify + * at least one item in this list. + *

        + *

        + * Note that if one of the filter formulas in the request fails to evaluate because of an error or one of the + * column ids in any of the rows does not exist in the table, then the request fails + * and no updates are made to the table. + *

        + */ + rowsToUpsert: UpsertRowData[] | undefined; + + /** + *

        + * The request token for performing the update action. + * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error + * like a failed network connection, you can retry the call with the same request token. The service ensures + * that if the first call using that request token is successfully performed, the second call will not perform + * the action again. + *

        + *

        + * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests + * spanning hours or days. + *

        + */ + clientRequestToken?: string; +} + +export namespace BatchUpsertTableRowsRequest { + export const filterSensitiveLog = (obj: BatchUpsertTableRowsRequest): any => ({ + ...obj, + ...(obj.rowsToUpsert && { rowsToUpsert: obj.rowsToUpsert.map((item) => UpsertRowData.filterSensitiveLog(item)) }), + }); +} + +export enum UpsertAction { + Appended = "APPENDED", + Updated = "UPDATED", +} + +/** + *

        + * An object that represents the result of a single upsert row request. + *

        + */ +export interface UpsertRowsResult { + /** + *

        + * The list of row ids that were changed as part of an upsert row operation. If the upsert resulted in an + * update, this list could potentially contain multiple rows that matched the filter and hence got updated. + * If the upsert resulted in an append, this list would only have the single row that was appended. + *

        + */ + rowIds: string[] | undefined; + + /** + *

        + * The result of the upsert action. + *

        + */ + upsertAction: UpsertAction | string | undefined; +} + +export namespace UpsertRowsResult { + export const filterSensitiveLog = (obj: UpsertRowsResult): any => ({ + ...obj, + }); +} + +export interface BatchUpsertTableRowsResult { + /** + *

        + * A map with the batch item id as the key and the result of the upsert operation as the value. The + * result of the upsert operation specifies whether existing rows were updated or a new row was appended, along + * with the list of row ids that were affected. + *

        + */ + rows: { [key: string]: UpsertRowsResult } | undefined; + + /** + *

        The updated workbook cursor after updating or appending rows in the table.

        + */ + workbookCursor: number | undefined; + + /** + *

        + * The list of batch items in the request that could not be updated or appended in the table. Each element in + * this list contains one item from the request that could not be updated in the table along with the reason + * why that item could not be updated or appended. + *

        + */ + failedBatchItems?: FailedBatchItem[]; +} + +export namespace BatchUpsertTableRowsResult { + export const filterSensitiveLog = (obj: BatchUpsertTableRowsResult): any => ({ + ...obj, + }); +} + +export enum Format { + Accounting = "ACCOUNTING", + Auto = "AUTO", + Contact = "CONTACT", + Currency = "CURRENCY", + Date = "DATE", + DateTime = "DATE_TIME", + Number = "NUMBER", + Percentage = "PERCENTAGE", + Rowlink = "ROWLINK", + Text = "TEXT", + Time = "TIME", +} + +/** + *

        An object that represents a single cell in a table.

        + */ +export interface Cell { + /** + *

        + * The formula contained in the cell. This field is empty if a cell does not have a formula. + *

        + */ + formula?: string; + + /** + *

        The format of the cell. If this field is empty, then the format is either not specified in the + * workbook or the format is set to AUTO.

        + */ + format?: Format | string; + + /** + *

        + * The raw value of the data contained in the cell. The raw value depends on the format of the data in the + * cell. However the attribute in the API return value is always a string containing the raw value. + *

        + *

        + * Cells with format DATE, DATE_TIME or TIME have the raw value as a floating point + * number where the whole number represents the number of days since 1/1/1900 and the fractional part + * represents the fraction of the day since midnight. For example, a cell with date 11/3/2020 has the raw value + * "44138". A cell with the time 9:00 AM has the raw value "0.375" and a cell with date/time value of + * 11/3/2020 9:00 AM has the raw value "44138.375". Notice that even though the raw value is a number in all + * three cases, it is still represented as a string. + *

        + *

        + * Cells with format NUMBER, CURRENCY, PERCENTAGE and ACCOUNTING have the raw value of the data as the number + * representing the data being displayed. For example, the number 1.325 with two decimal places in the format + * will have it's raw value as "1.325" and formatted value as "1.33". A currency value for + * $10 will have the raw value as "10" and formatted value as "$10.00". A value representing 20% with two + * decimal places in the format will have its raw value as "0.2" and the formatted value as "20.00%". An + * accounting value of -$25 will have "-25" as the raw value and "$ (25.00)" as the formatted value. + *

        + *

        + * Cells with format TEXT will have the raw text as the raw value. For example, a cell with text "John Smith" + * will have "John Smith" as both the raw value and the formatted value. + *

        + *

        + * Cells with format CONTACT will have the name of the contact as a formatted value and the email address of + * the contact as the raw value. For example, a contact for John Smith will have "John Smith" as the + * formatted value and "john.smith@example.com" as the raw value. + *

        + *

        + * Cells with format ROWLINK (aka picklist) will have the first column of the linked row as the formatted value + * and the row id of the linked row as the raw value. For example, a cell containing a picklist to a table + * that displays task status might have "Completed" as the formatted value and + * "row:dfcefaee-5b37-4355-8f28-40c3e4ff5dd4/ca432b2f-b8eb-431d-9fb5-cbe0342f9f03" as the raw value. + *

        + *

        + * Cells with format AUTO or cells without any format that are auto-detected as one of the formats above will + * contain the raw and formatted values as mentioned above, based on the auto-detected formats. If there is no + * auto-detected format, the raw and formatted values will be the same as the data in the cell. + *

        + */ + rawValue?: string; + + /** + *

        + * The formatted value of the cell. This is the value that you see displayed in the cell in the UI. + *

        + *

        + * Note that the formatted value of a cell is always represented as a string irrespective of the data that is + * stored in the cell. For example, if a cell contains a date, the formatted value of the cell is the string + * representation of the formatted date being shown in the cell in the UI. See details in the rawValue field + * below for how cells of different formats will have different raw and formatted values. + *

        + */ + formattedValue?: string; +} + +export namespace Cell { + export const filterSensitiveLog = (obj: Cell): any => ({ + ...obj, + ...(obj.formula && { formula: SENSITIVE_STRING }), + }); +} + +/** + *

        Metadata for column in the table.

        + */ +export interface ColumnMetadata { + /** + *

        The name of the column.

        + */ + name: string | undefined; + + /** + *

        The format of the column.

        + */ + format: Format | string | undefined; +} + +export namespace ColumnMetadata { + export const filterSensitiveLog = (obj: ColumnMetadata): any => ({ + ...obj, + ...(obj.name && { name: SENSITIVE_STRING }), + }); +} + +/** + *

        The data in a particular data cell defined on the screen.

        + */ +export interface DataItem { + /** + *

        + * The overrideFormat is optional and is specified only if a particular row of data has a different format for + * the data than the default format defined on the screen or the table. + *

        + */ + overrideFormat?: Format | string; + + /** + *

        The raw value of the data. e.g. jsmith@example.com

        + */ + rawValue?: string; + + /** + *

        The formatted value of the data. e.g. John Smith.

        + */ + formattedValue?: string; +} + +export namespace DataItem { + export const filterSensitiveLog = (obj: DataItem): any => ({ + ...obj, + }); +} + +export enum ImportDataCharacterEncoding { + ISO_8859_1 = "ISO-8859-1", + US_ASCII = "US-ASCII", + UTF_16 = "UTF-16", + UTF_16BE = "UTF-16BE", + UTF_16LE = "UTF-16LE", + UTF_8 = "UTF-8", +} + +/** + *

        + * An object that contains the options relating to parsing delimited text as part of an import request. + *

        + */ +export interface DelimitedTextImportOptions { + /** + *

        The delimiter to use for separating columns in a single row of the input.

        + */ + delimiter: string | undefined; + + /** + *

        Indicates whether the input file has a header row at the top containing the column names.

        + */ + hasHeaderRow?: boolean; + + /** + *

        A parameter to indicate whether empty rows should be ignored or be included in the import.

        + */ + ignoreEmptyRows?: boolean; + + /** + *

        The encoding of the data in the input file.

        + */ + dataCharacterEncoding?: ImportDataCharacterEncoding | string; +} + +export namespace DelimitedTextImportOptions { + export const filterSensitiveLog = (obj: DelimitedTextImportOptions): any => ({ + ...obj, + }); +} + +export interface DescribeTableDataImportJobRequest { + /** + *

        The ID of the workbook into which data was imported.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the table into which data was imported.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        The ID of the job that was returned by the StartTableDataImportJob request.

        + *

        + * If a job with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + jobId: string | undefined; +} + +export namespace DescribeTableDataImportJobRequest { + export const filterSensitiveLog = (obj: DescribeTableDataImportJobRequest): any => ({ + ...obj, + }); +} + +/** + *

        + * An object that contains the configuration parameters for the data source of an import request. + *

        + */ +export interface ImportDataSourceConfig { + /** + *

        + * The URL from which source data will be downloaded for the import request. + *

        + */ + dataSourceUrl?: string; +} + +export namespace ImportDataSourceConfig { + export const filterSensitiveLog = (obj: ImportDataSourceConfig): any => ({ + ...obj, + }); +} + +/** + *

        An object that has details about the source of the data that was submitted for import.

        + */ +export interface ImportDataSource { + /** + *

        The configuration parameters for the data source of the import

        + */ + dataSourceConfig: ImportDataSourceConfig | undefined; +} + +export namespace ImportDataSource { + export const filterSensitiveLog = (obj: ImportDataSource): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains the properties for importing data to a specific column in a table.

        + */ +export interface SourceDataColumnProperties { + /** + *

        The index of the column in the input file.

        + */ + columnIndex?: number; +} + +export namespace SourceDataColumnProperties { + export const filterSensitiveLog = (obj: SourceDataColumnProperties): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains the options relating to the destination of the import request.

        + */ +export interface DestinationOptions { + /** + *

        A map of the column id to the import properties for each column.

        + */ + columnMap?: { [key: string]: SourceDataColumnProperties }; +} + +export namespace DestinationOptions { + export const filterSensitiveLog = (obj: DestinationOptions): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains the options specified by the sumitter of the import request.

        + */ +export interface ImportOptions { + /** + *

        Options relating to the destination of the import request.

        + */ + destinationOptions?: DestinationOptions; + + /** + *

        Options relating to parsing delimited text. Required if dataFormat is DELIMITED_TEXT.

        + */ + delimitedTextOptions?: DelimitedTextImportOptions; +} + +export namespace ImportOptions { + export const filterSensitiveLog = (obj: ImportOptions): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains the attributes of the submitter of the import job.

        + */ +export interface ImportJobSubmitter { + /** + *

        The email id of the submitter of the import job, if available.

        + */ + email?: string; + + /** + *

        The AWS user ARN of the submitter of the import job, if available.

        + */ + userArn?: string; +} + +export namespace ImportJobSubmitter { + export const filterSensitiveLog = (obj: ImportJobSubmitter): any => ({ + ...obj, + ...(obj.email && { email: SENSITIVE_STRING }), + }); +} + +/** + *

        The metadata associated with the table data import job that was submitted.

        + */ +export interface TableDataImportJobMetadata { + /** + *

        Details about the submitter of the import request.

        + */ + submitter: ImportJobSubmitter | undefined; + + /** + *

        The timestamp when the job was submitted for import.

        + */ + submitTime: Date | undefined; + + /** + *

        The options that was specified at the time of submitting the import request.

        + */ + importOptions: ImportOptions | undefined; + + /** + *

        The source of the data that was submitted for import.

        + */ + dataSource: ImportDataSource | undefined; +} + +export namespace TableDataImportJobMetadata { + export const filterSensitiveLog = (obj: TableDataImportJobMetadata): any => ({ + ...obj, + ...(obj.submitter && { submitter: ImportJobSubmitter.filterSensitiveLog(obj.submitter) }), + }); +} + +export enum TableDataImportJobStatus { + Completed = "COMPLETED", + Failed = "FAILED", + InProgress = "IN_PROGRESS", + Submitted = "SUBMITTED", +} + +export interface DescribeTableDataImportJobResult { + /** + *

        + * The current status of the import job. + *

        + */ + jobStatus: TableDataImportJobStatus | string | undefined; + + /** + *

        + * A message providing more details about the current status of the import job. + *

        + */ + message: string | undefined; + + /** + *

        + * The metadata about the job that was submitted for import. + *

        + */ + jobMetadata: TableDataImportJobMetadata | undefined; +} + +export namespace DescribeTableDataImportJobResult { + export const filterSensitiveLog = (obj: DescribeTableDataImportJobResult): any => ({ + ...obj, + ...(obj.jobMetadata && { jobMetadata: TableDataImportJobMetadata.filterSensitiveLog(obj.jobMetadata) }), + }); +} + +/** + *

        The input variables to the app to be used by the InvokeScreenAutomation action request.

        + */ +export interface VariableValue { + /** + *

        Raw value of the variable.

        + */ + rawValue: string | undefined; +} + +export namespace VariableValue { + export const filterSensitiveLog = (obj: VariableValue): any => ({ + ...obj, + }); +} + +export interface GetScreenDataRequest { + /** + *

        The ID of the workbook that contains the screen.

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the app that contains the screem.

        + */ + appId: string | undefined; + + /** + *

        The ID of the screen.

        + */ + screenId: string | undefined; + + /** + *

        + * Variables are optional and are needed only if the screen requires them to render correctly. Variables are + * specified as a map where the key is the name of the variable as defined on the screen. The value is an + * object which currently has only one property, rawValue, which holds the value of the variable to be passed + * to the screen. + *

        + */ + variables?: { [key: string]: VariableValue }; + + /** + *

        + * The number of results to be returned on a single page. + * Specify a number between 1 and 100. The maximum value is 100. + *

        + *

        + * This parameter is optional. If you don't specify this parameter, the default page size is 100. + *

        + */ + maxResults?: number; + + /** + *

        + * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. + *

        + *

        + * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API + * will throw ValidationException. + *

        + */ + nextToken?: string; +} + +export namespace GetScreenDataRequest { + export const filterSensitiveLog = (obj: GetScreenDataRequest): any => ({ + ...obj, + ...(obj.variables && { variables: SENSITIVE_STRING }), + }); +} + +/** + *

        A single row in the ResultSet.

        + */ +export interface ResultRow { + /** + *

        The ID for a particular row.

        + */ + rowId?: string; + + /** + *

        List of all the data cells in a row.

        + */ + dataItems: DataItem[] | undefined; +} + +export namespace ResultRow { + export const filterSensitiveLog = (obj: ResultRow): any => ({ + ...obj, + ...(obj.dataItems && { dataItems: SENSITIVE_STRING }), + }); +} + +/** + *

        + * ResultSet contains the results of the request for a single block or list defined on the screen. + *

        + */ +export interface ResultSet { + /** + *

        + * List of headers for all the data cells in the block. The header identifies the name and default format of + * the data cell. Data cells appear in the same order in all rows as defined in the header. The names and + * formats are not repeated in the rows. If a particular row does not have a value for a data cell, a blank + * value is used. + *

        + *

        + * For example, a task list that displays the task name, due date and assigned person might have headers + * [ { "name": "Task Name"}, {"name": "Due Date", "format": "DATE"}, {"name": "Assigned", "format": "CONTACT"} ]. + * Every row in the result will have the task name as the first item, due date as the second item and assigned + * person as the third item. If a particular task does not have a due date, that row will still have a blank + * value in the second element and the assigned person will still be in the third element. + *

        + */ + headers: ColumnMetadata[] | undefined; + + /** + *

        + * List of rows returned by the request. Each row has a row Id and a list of data cells in that row. The data + * cells will be present in the same order as they are defined in the header. + *

        + */ + rows: ResultRow[] | undefined; +} + +export namespace ResultSet { + export const filterSensitiveLog = (obj: ResultSet): any => ({ + ...obj, + ...(obj.headers && { headers: obj.headers.map((item) => ColumnMetadata.filterSensitiveLog(item)) }), + }); +} + +export interface GetScreenDataResult { + /** + *

        A map of all the rows on the screen keyed by block name.

        + */ + results: { [key: string]: ResultSet } | undefined; + + /** + *

        + * Indicates the cursor of the workbook at which the data returned by this workbook is read. Workbook cursor + * keeps increasing with every update and the increments are not sequential. + *

        + */ + workbookCursor: number | undefined; + + /** + *

        + * Provides the pagination token to load the next page if there are more results matching the request. If a + * pagination token is not present in the response, it means that all data matching the query has been loaded. + *

        + */ + nextToken?: string; +} + +export namespace GetScreenDataResult { + export const filterSensitiveLog = (obj: GetScreenDataResult): any => ({ + ...obj, + ...(obj.results && { + results: Object.entries(obj.results).reduce( + (acc: any, [key, value]: [string, ResultSet]) => ({ + ...acc, + [key]: ResultSet.filterSensitiveLog(value), + }), + {} + ), + }), + }); +} + +export enum ImportSourceDataFormat { + DelimitedText = "DELIMITED_TEXT", +} + +export interface InvokeScreenAutomationRequest { + /** + *

        The ID of the workbook that contains the screen automation.

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the app that contains the screen automation.

        + */ + appId: string | undefined; + + /** + *

        The ID of the screen that contains the screen automation.

        + */ + screenId: string | undefined; + + /** + *

        The ID of the automation action to be performed.

        + */ + screenAutomationId: string | undefined; + + /** + *

        + * Variables are specified as a map where the key is the name of the variable as defined on the screen. The value is an + * object which currently has only one property, rawValue, which holds the value of the variable to be passed + * to the screen. Any variables defined in a screen are required to be passed in the call. + *

        + */ + variables?: { [key: string]: VariableValue }; + + /** + *

        + * The row ID for the automation if the automation is defined inside a block with source or list. + *

        + */ + rowId?: string; + + /** + *

        + * The request token for performing the automation action. + * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error + * like a failed network connection, you can retry the call with the same request token. The service ensures + * that if the first call using that request token is successfully performed, the second call will return the + * response of the previous call rather than performing the action again. + *

        + *

        + * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests + * spanning hours or days. + *

        + */ + clientRequestToken?: string; +} + +export namespace InvokeScreenAutomationRequest { + export const filterSensitiveLog = (obj: InvokeScreenAutomationRequest): any => ({ + ...obj, + ...(obj.variables && { variables: SENSITIVE_STRING }), + }); +} + +export interface InvokeScreenAutomationResult { + /** + *

        The updated workbook cursor after performing the automation action.

        + */ + workbookCursor: number | undefined; } export namespace InvokeScreenAutomationResult { @@ -441,3 +1374,473 @@ export namespace InvokeScreenAutomationResult { ...obj, }); } + +export interface ListTableColumnsRequest { + /** + *

        The ID of the workbook that contains the table whose columns are being retrieved.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the table whose columns are being retrieved.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        + * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. + *

        + *

        + * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API + * will throw ValidationException. + *

        + */ + nextToken?: string; +} + +export namespace ListTableColumnsRequest { + export const filterSensitiveLog = (obj: ListTableColumnsRequest): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains attributes about a single column in a table

        + */ +export interface TableColumn { + /** + *

        The id of the column in the table.

        + */ + tableColumnId?: string; + + /** + *

        The name of the column in the table.

        + */ + tableColumnName?: string; + + /** + *

        + * The column level format that is applied in the table. An empty value in this field means that the + * column format is the default value 'AUTO'. + *

        + */ + format?: Format | string; +} + +export namespace TableColumn { + export const filterSensitiveLog = (obj: TableColumn): any => ({ + ...obj, + }); +} + +export interface ListTableColumnsResult { + /** + *

        + * The list of columns in the table. + *

        + */ + tableColumns: TableColumn[] | undefined; + + /** + *

        + * Provides the pagination token to load the next page if there are more results matching the request. If a + * pagination token is not present in the response, it means that all data matching the request has been + * loaded. + *

        + */ + nextToken?: string; + + /** + *

        + * Indicates the cursor of the workbook at which the data returned by this request is read. Workbook cursor + * keeps increasing with every update and the increments are not sequential. + *

        + */ + workbookCursor?: number; +} + +export namespace ListTableColumnsResult { + export const filterSensitiveLog = (obj: ListTableColumnsResult): any => ({ + ...obj, + }); +} + +export interface ListTableRowsRequest { + /** + *

        The ID of the workbook that contains the table whose rows are being retrieved.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the table whose rows are being retrieved.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        + * This parameter is optional. If one or more row ids are specified in this list, then only the specified + * row ids are returned in the result. If no row ids are specified here, then all the rows in the table are + * returned. + *

        + */ + rowIds?: string[]; + + /** + *

        The maximum number of rows to return in each page of the results.

        + */ + maxResults?: number; + + /** + *

        + * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. + *

        + *

        + * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API + * will throw ValidationException. + *

        + */ + nextToken?: string; +} + +export namespace ListTableRowsRequest { + export const filterSensitiveLog = (obj: ListTableRowsRequest): any => ({ + ...obj, + }); +} + +/** + *

        An object that contains attributes about a single row in a table

        + */ +export interface TableRow { + /** + *

        The id of the row in the table.

        + */ + rowId: string | undefined; + + /** + *

        A list of cells in the table row. The cells appear in the same order as the columns of the table. + *

        + */ + cells: Cell[] | undefined; +} + +export namespace TableRow { + export const filterSensitiveLog = (obj: TableRow): any => ({ + ...obj, + ...(obj.cells && { cells: SENSITIVE_STRING }), + }); +} + +export interface ListTableRowsResult { + /** + *

        + * The list of columns in the table whose row data is returned in the result. + *

        + */ + columnIds: string[] | undefined; + + /** + *

        + * The list of rows in the table. Note that this result is paginated, so this list contains a maximum of 100 + * rows. + *

        + */ + rows: TableRow[] | undefined; + + /** + *

        + * The list of row ids included in the request that were not found in the table. + *

        + */ + rowIdsNotFound?: string[]; + + /** + *

        + * Provides the pagination token to load the next page if there are more results matching the request. If a + * pagination token is not present in the response, it means that all data matching the request has been + * loaded. + *

        + */ + nextToken?: string; + + /** + *

        + * Indicates the cursor of the workbook at which the data returned by this request is read. Workbook cursor + * keeps increasing with every update and the increments are not sequential. + *

        + */ + workbookCursor: number | undefined; +} + +export namespace ListTableRowsResult { + export const filterSensitiveLog = (obj: ListTableRowsResult): any => ({ + ...obj, + }); +} + +export interface ListTablesRequest { + /** + *

        The ID of the workbook whose tables are being retrieved.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The maximum number of tables to return in each page of the results.

        + */ + maxResults?: number; + + /** + *

        + * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. + *

        + *

        + * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API + * will throw ValidationException. + *

        + */ + nextToken?: string; +} + +export namespace ListTablesRequest { + export const filterSensitiveLog = (obj: ListTablesRequest): any => ({ + ...obj, + }); +} + +/** + *

        An object representing the properties of a table in a workbook.

        + */ +export interface Table { + /** + *

        The id of the table.

        + */ + tableId?: string; + + /** + *

        The name of the table.

        + */ + tableName?: string; +} + +export namespace Table { + export const filterSensitiveLog = (obj: Table): any => ({ + ...obj, + }); +} + +export interface ListTablesResult { + /** + *

        + * The list of tables in the workbook. + *

        + */ + tables: Table[] | undefined; + + /** + *

        + * Provides the pagination token to load the next page if there are more results matching the request. If a + * pagination token is not present in the response, it means that all data matching the request has been + * loaded. + *

        + */ + nextToken?: string; + + /** + *

        + * Indicates the cursor of the workbook at which the data returned by this request is read. Workbook cursor + * keeps increasing with every update and the increments are not sequential. + *

        + */ + workbookCursor?: number; +} + +export namespace ListTablesResult { + export const filterSensitiveLog = (obj: ListTablesResult): any => ({ + ...obj, + }); +} + +export interface QueryTableRowsRequest { + /** + *

        The ID of the workbook whose table rows are being queried.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        The ID of the table whose rows are being queried.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + tableId: string | undefined; + + /** + *

        An object that represents a filter formula along with the id of the context row under which the filter + * function needs to evaluate.

        + */ + filterFormula: Filter | undefined; + + /** + *

        The maximum number of rows to return in each page of the results.

        + */ + maxResults?: number; + + /** + *

        + * This parameter is optional. If a nextToken is not specified, the API returns the first page of data. + *

        + *

        + * Pagination tokens expire after 1 hour. If you use a token that was returned more than an hour back, the API + * will throw ValidationException. + *

        + */ + nextToken?: string; +} + +export namespace QueryTableRowsRequest { + export const filterSensitiveLog = (obj: QueryTableRowsRequest): any => ({ + ...obj, + ...(obj.filterFormula && { filterFormula: Filter.filterSensitiveLog(obj.filterFormula) }), + }); +} + +export interface QueryTableRowsResult { + /** + *

        + * The list of columns in the table whose row data is returned in the result. + *

        + */ + columnIds: string[] | undefined; + + /** + *

        + * The list of rows in the table that match the query filter. + *

        + */ + rows: TableRow[] | undefined; + + /** + *

        + * Provides the pagination token to load the next page if there are more results matching the request. If a + * pagination token is not present in the response, it means that all data matching the request has been + * loaded. + *

        + */ + nextToken?: string; + + /** + *

        + * Indicates the cursor of the workbook at which the data returned by this request is read. Workbook cursor + * keeps increasing with every update and the increments are not sequential. + *

        + */ + workbookCursor: number | undefined; +} + +export namespace QueryTableRowsResult { + export const filterSensitiveLog = (obj: QueryTableRowsResult): any => ({ + ...obj, + }); +} + +export interface StartTableDataImportJobRequest { + /** + *

        The ID of the workbook where the rows are being imported.

        + *

        + * If a workbook with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + workbookId: string | undefined; + + /** + *

        + * The source of the data that is being imported. The size of source must be no larger than 100 MB. + * Source must have no more than 100,000 cells and no more than 1,000 rows. + *

        + */ + dataSource: ImportDataSource | undefined; + + /** + *

        + * The format of the data that is being imported. Currently the only option supported is "DELIMITED_TEXT". + *

        + */ + dataFormat: ImportSourceDataFormat | string | undefined; + + /** + *

        The ID of the table where the rows are being imported.

        + *

        + * If a table with the specified id could not be found, this API throws ResourceNotFoundException. + *

        + */ + destinationTableId: string | undefined; + + /** + *

        + * The options for customizing this import request. + *

        + */ + importOptions: ImportOptions | undefined; + + /** + *

        + * The request token for performing the update action. + * Request tokens help to identify duplicate requests. If a call times out or fails due to a transient error + * like a failed network connection, you can retry the call with the same request token. The service ensures + * that if the first call using that request token is successfully performed, the second call will not perform + * the action again. + *

        + *

        + * Note that request tokens are valid only for a few minutes. You cannot use request tokens to dedupe requests + * spanning hours or days. + *

        + */ + clientRequestToken: string | undefined; +} + +export namespace StartTableDataImportJobRequest { + export const filterSensitiveLog = (obj: StartTableDataImportJobRequest): any => ({ + ...obj, + }); +} + +export interface StartTableDataImportJobResult { + /** + *

        + * The id that is assigned to this import job. Future requests to find out the status of this import job + * need to send this id in the appropriate parameter in the request. + *

        + */ + jobId: string | undefined; + + /** + *

        + * The status of the import job immediately after submitting the request. + *

        + */ + jobStatus: TableDataImportJobStatus | string | undefined; +} + +export namespace StartTableDataImportJobResult { + export const filterSensitiveLog = (obj: StartTableDataImportJobResult): any => ({ + ...obj, + }); +} diff --git a/clients/client-honeycode/pagination/Interfaces.ts b/clients/client-honeycode/pagination/Interfaces.ts new file mode 100644 index 000000000000..879717299f6d --- /dev/null +++ b/clients/client-honeycode/pagination/Interfaces.ts @@ -0,0 +1,7 @@ +import { Honeycode } from "../Honeycode"; +import { HoneycodeClient } from "../HoneycodeClient"; +import { PaginationConfiguration } from "@aws-sdk/types"; + +export interface HoneycodePaginationConfiguration extends PaginationConfiguration { + client: Honeycode | HoneycodeClient; +} diff --git a/clients/client-honeycode/pagination/ListTableColumnsPaginator.ts b/clients/client-honeycode/pagination/ListTableColumnsPaginator.ts new file mode 100644 index 000000000000..2f45d10f6a23 --- /dev/null +++ b/clients/client-honeycode/pagination/ListTableColumnsPaginator.ts @@ -0,0 +1,56 @@ +import { Honeycode } from "../Honeycode"; +import { HoneycodeClient } from "../HoneycodeClient"; +import { + ListTableColumnsCommand, + ListTableColumnsCommandInput, + ListTableColumnsCommandOutput, +} from "../commands/ListTableColumnsCommand"; +import { HoneycodePaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: HoneycodeClient, + input: ListTableColumnsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListTableColumnsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Honeycode, + input: ListTableColumnsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listTableColumns(input, ...args); +}; +export async function* paginateListTableColumns( + config: HoneycodePaginationConfiguration, + input: ListTableColumnsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListTableColumnsCommandOutput; + while (hasNext) { + input.nextToken = token; + if (config.client instanceof Honeycode) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof HoneycodeClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Honeycode | HoneycodeClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-honeycode/pagination/ListTableRowsPaginator.ts b/clients/client-honeycode/pagination/ListTableRowsPaginator.ts new file mode 100644 index 000000000000..43de81b473fd --- /dev/null +++ b/clients/client-honeycode/pagination/ListTableRowsPaginator.ts @@ -0,0 +1,57 @@ +import { Honeycode } from "../Honeycode"; +import { HoneycodeClient } from "../HoneycodeClient"; +import { + ListTableRowsCommand, + ListTableRowsCommandInput, + ListTableRowsCommandOutput, +} from "../commands/ListTableRowsCommand"; +import { HoneycodePaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: HoneycodeClient, + input: ListTableRowsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListTableRowsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Honeycode, + input: ListTableRowsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listTableRows(input, ...args); +}; +export async function* paginateListTableRows( + config: HoneycodePaginationConfiguration, + input: ListTableRowsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListTableRowsCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof Honeycode) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof HoneycodeClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Honeycode | HoneycodeClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-honeycode/pagination/ListTablesPaginator.ts b/clients/client-honeycode/pagination/ListTablesPaginator.ts new file mode 100644 index 000000000000..d5795969c5d8 --- /dev/null +++ b/clients/client-honeycode/pagination/ListTablesPaginator.ts @@ -0,0 +1,53 @@ +import { Honeycode } from "../Honeycode"; +import { HoneycodeClient } from "../HoneycodeClient"; +import { ListTablesCommand, ListTablesCommandInput, ListTablesCommandOutput } from "../commands/ListTablesCommand"; +import { HoneycodePaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: HoneycodeClient, + input: ListTablesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListTablesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Honeycode, + input: ListTablesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listTables(input, ...args); +}; +export async function* paginateListTables( + config: HoneycodePaginationConfiguration, + input: ListTablesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListTablesCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof Honeycode) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof HoneycodeClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Honeycode | HoneycodeClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-honeycode/pagination/QueryTableRowsPaginator.ts b/clients/client-honeycode/pagination/QueryTableRowsPaginator.ts new file mode 100644 index 000000000000..97bb827c7d71 --- /dev/null +++ b/clients/client-honeycode/pagination/QueryTableRowsPaginator.ts @@ -0,0 +1,57 @@ +import { Honeycode } from "../Honeycode"; +import { HoneycodeClient } from "../HoneycodeClient"; +import { + QueryTableRowsCommand, + QueryTableRowsCommandInput, + QueryTableRowsCommandOutput, +} from "../commands/QueryTableRowsCommand"; +import { HoneycodePaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: HoneycodeClient, + input: QueryTableRowsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new QueryTableRowsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: Honeycode, + input: QueryTableRowsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.queryTableRows(input, ...args); +}; +export async function* paginateQueryTableRows( + config: HoneycodePaginationConfiguration, + input: QueryTableRowsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: QueryTableRowsCommandOutput; + while (hasNext) { + input.nextToken = token; + input["maxResults"] = config.pageSize; + if (config.client instanceof Honeycode) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof HoneycodeClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected Honeycode | HoneycodeClient"); + } + yield page; + token = page.nextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-honeycode/protocols/Aws_restJson1.ts b/clients/client-honeycode/protocols/Aws_restJson1.ts index 31f11975c4a1..324b1ae6fa84 100644 --- a/clients/client-honeycode/protocols/Aws_restJson1.ts +++ b/clients/client-honeycode/protocols/Aws_restJson1.ts @@ -1,21 +1,69 @@ +import { + BatchCreateTableRowsCommandInput, + BatchCreateTableRowsCommandOutput, +} from "../commands/BatchCreateTableRowsCommand"; +import { + BatchDeleteTableRowsCommandInput, + BatchDeleteTableRowsCommandOutput, +} from "../commands/BatchDeleteTableRowsCommand"; +import { + BatchUpdateTableRowsCommandInput, + BatchUpdateTableRowsCommandOutput, +} from "../commands/BatchUpdateTableRowsCommand"; +import { + BatchUpsertTableRowsCommandInput, + BatchUpsertTableRowsCommandOutput, +} from "../commands/BatchUpsertTableRowsCommand"; +import { + DescribeTableDataImportJobCommandInput, + DescribeTableDataImportJobCommandOutput, +} from "../commands/DescribeTableDataImportJobCommand"; import { GetScreenDataCommandInput, GetScreenDataCommandOutput } from "../commands/GetScreenDataCommand"; import { InvokeScreenAutomationCommandInput, InvokeScreenAutomationCommandOutput, } from "../commands/InvokeScreenAutomationCommand"; +import { ListTableColumnsCommandInput, ListTableColumnsCommandOutput } from "../commands/ListTableColumnsCommand"; +import { ListTableRowsCommandInput, ListTableRowsCommandOutput } from "../commands/ListTableRowsCommand"; +import { ListTablesCommandInput, ListTablesCommandOutput } from "../commands/ListTablesCommand"; +import { QueryTableRowsCommandInput, QueryTableRowsCommandOutput } from "../commands/QueryTableRowsCommand"; +import { + StartTableDataImportJobCommandInput, + StartTableDataImportJobCommandOutput, +} from "../commands/StartTableDataImportJobCommand"; import { AccessDeniedException, AutomationExecutionException, AutomationExecutionTimeoutException, + Cell, + CellInput, ColumnMetadata, + CreateRowData, DataItem, + DelimitedTextImportOptions, + DestinationOptions, + FailedBatchItem, + Filter, + ImportDataSource, + ImportDataSourceConfig, + ImportJobSubmitter, + ImportOptions, InternalServerException, RequestTimeoutException, ResourceNotFoundException, ResultRow, ResultSet, + ServiceQuotaExceededException, ServiceUnavailableException, + SourceDataColumnProperties, + Table, + TableColumn, + TableDataImportJobMetadata, + TableRow, ThrottlingException, + UpdateRowData, + UpsertRowData, + UpsertRowsResult, ValidationException, VariableValue, } from "../models/models_0"; @@ -31,6 +79,232 @@ import { SerdeContext as __SerdeContext, } from "@aws-sdk/types"; +export const serializeAws_restJson1BatchCreateTableRowsCommand = async ( + input: BatchCreateTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/batchcreate"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.clientRequestToken !== undefined && { clientRequestToken: input.clientRequestToken }), + ...(input.rowsToCreate !== undefined && { + rowsToCreate: serializeAws_restJson1CreateRowDataList(input.rowsToCreate, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1BatchDeleteTableRowsCommand = async ( + input: BatchDeleteTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/batchdelete"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.clientRequestToken !== undefined && { clientRequestToken: input.clientRequestToken }), + ...(input.rowIds !== undefined && { rowIds: serializeAws_restJson1RowIdList(input.rowIds, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1BatchUpdateTableRowsCommand = async ( + input: BatchUpdateTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/batchupdate"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.clientRequestToken !== undefined && { clientRequestToken: input.clientRequestToken }), + ...(input.rowsToUpdate !== undefined && { + rowsToUpdate: serializeAws_restJson1UpdateRowDataList(input.rowsToUpdate, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1BatchUpsertTableRowsCommand = async ( + input: BatchUpsertTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/batchupsert"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.clientRequestToken !== undefined && { clientRequestToken: input.clientRequestToken }), + ...(input.rowsToUpsert !== undefined && { + rowsToUpsert: serializeAws_restJson1UpsertRowDataList(input.rowsToUpsert, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeTableDataImportJobCommand = async ( + input: DescribeTableDataImportJobCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/import/{jobId}"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + if (input.jobId !== undefined) { + const labelValue: string = input.jobId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: jobId."); + } + resolvedPath = resolvedPath.replace("{jobId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: jobId."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + export const serializeAws_restJson1GetScreenDataCommand = async ( input: GetScreenDataCommandInput, context: __SerdeContext @@ -79,15 +353,6 @@ export const serializeAws_restJson1InvokeScreenAutomationCommand = async ( } else { throw new Error("No value provided for input HTTP label: workbookId."); } - if (input.screenId !== undefined) { - const labelValue: string = input.screenId; - if (labelValue.length <= 0) { - throw new Error("Empty value provided for input HTTP label: screenId."); - } - resolvedPath = resolvedPath.replace("{screenId}", __extendedEncodeURIComponent(labelValue)); - } else { - throw new Error("No value provided for input HTTP label: screenId."); - } if (input.appId !== undefined) { const labelValue: string = input.appId; if (labelValue.length <= 0) { @@ -97,6 +362,15 @@ export const serializeAws_restJson1InvokeScreenAutomationCommand = async ( } else { throw new Error("No value provided for input HTTP label: appId."); } + if (input.screenId !== undefined) { + const labelValue: string = input.screenId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: screenId."); + } + resolvedPath = resolvedPath.replace("{screenId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: screenId."); + } if (input.screenAutomationId !== undefined) { const labelValue: string = input.screenAutomationId; if (labelValue.length <= 0) { @@ -126,25 +400,1372 @@ export const serializeAws_restJson1InvokeScreenAutomationCommand = async ( }); }; -export const deserializeAws_restJson1GetScreenDataCommand = async ( +export const serializeAws_restJson1ListTableColumnsCommand = async ( + input: ListTableColumnsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/columns"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + const query: any = { + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListTableRowsCommand = async ( + input: ListTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/list"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + ...(input.rowIds !== undefined && { rowIds: serializeAws_restJson1RowIdList(input.rowIds, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListTablesCommand = async ( + input: ListTablesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/workbooks/{workbookId}/tables"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + const query: any = { + ...(input.maxResults !== undefined && { maxResults: input.maxResults.toString() }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1QueryTableRowsCommand = async ( + input: QueryTableRowsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{tableId}/rows/query"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.tableId !== undefined) { + const labelValue: string = input.tableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: tableId."); + } + resolvedPath = resolvedPath.replace("{tableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: tableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.filterFormula !== undefined && { + filterFormula: serializeAws_restJson1Filter(input.filterFormula, context), + }), + ...(input.maxResults !== undefined && { maxResults: input.maxResults }), + ...(input.nextToken !== undefined && { nextToken: input.nextToken }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1StartTableDataImportJobCommand = async ( + input: StartTableDataImportJobCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/workbooks/{workbookId}/tables/{destinationTableId}/import"; + if (input.workbookId !== undefined) { + const labelValue: string = input.workbookId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: workbookId."); + } + resolvedPath = resolvedPath.replace("{workbookId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: workbookId."); + } + if (input.destinationTableId !== undefined) { + const labelValue: string = input.destinationTableId; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: destinationTableId."); + } + resolvedPath = resolvedPath.replace("{destinationTableId}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: destinationTableId."); + } + let body: any; + body = JSON.stringify({ + ...(input.clientRequestToken !== undefined && { clientRequestToken: input.clientRequestToken }), + ...(input.dataFormat !== undefined && { dataFormat: input.dataFormat }), + ...(input.dataSource !== undefined && { + dataSource: serializeAws_restJson1ImportDataSource(input.dataSource, context), + }), + ...(input.importOptions !== undefined && { + importOptions: serializeAws_restJson1ImportOptions(input.importOptions, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1BatchCreateTableRowsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1BatchCreateTableRowsCommandError(output, context); + } + const contents: BatchCreateTableRowsCommandOutput = { + $metadata: deserializeMetadata(output), + createdRows: undefined, + failedBatchItems: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.createdRows !== undefined && data.createdRows !== null) { + contents.createdRows = deserializeAws_restJson1CreatedRowsMap(data.createdRows, context); + } + if (data.failedBatchItems !== undefined && data.failedBatchItems !== null) { + contents.failedBatchItems = deserializeAws_restJson1FailedBatchItems(data.failedBatchItems, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1BatchCreateTableRowsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.honeycode#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1BatchDeleteTableRowsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1BatchDeleteTableRowsCommandError(output, context); + } + const contents: BatchDeleteTableRowsCommandOutput = { + $metadata: deserializeMetadata(output), + failedBatchItems: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.failedBatchItems !== undefined && data.failedBatchItems !== null) { + contents.failedBatchItems = deserializeAws_restJson1FailedBatchItems(data.failedBatchItems, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1BatchDeleteTableRowsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1BatchUpdateTableRowsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1BatchUpdateTableRowsCommandError(output, context); + } + const contents: BatchUpdateTableRowsCommandOutput = { + $metadata: deserializeMetadata(output), + failedBatchItems: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.failedBatchItems !== undefined && data.failedBatchItems !== null) { + contents.failedBatchItems = deserializeAws_restJson1FailedBatchItems(data.failedBatchItems, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1BatchUpdateTableRowsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1BatchUpsertTableRowsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1BatchUpsertTableRowsCommandError(output, context); + } + const contents: BatchUpsertTableRowsCommandOutput = { + $metadata: deserializeMetadata(output), + failedBatchItems: undefined, + rows: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.failedBatchItems !== undefined && data.failedBatchItems !== null) { + contents.failedBatchItems = deserializeAws_restJson1FailedBatchItems(data.failedBatchItems, context); + } + if (data.rows !== undefined && data.rows !== null) { + contents.rows = deserializeAws_restJson1UpsertRowsResultMap(data.rows, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1BatchUpsertTableRowsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.honeycode#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeTableDataImportJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeTableDataImportJobCommandError(output, context); + } + const contents: DescribeTableDataImportJobCommandOutput = { + $metadata: deserializeMetadata(output), + jobMetadata: undefined, + jobStatus: undefined, + message: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.jobMetadata !== undefined && data.jobMetadata !== null) { + contents.jobMetadata = deserializeAws_restJson1TableDataImportJobMetadata(data.jobMetadata, context); + } + if (data.jobStatus !== undefined && data.jobStatus !== null) { + contents.jobStatus = data.jobStatus; + } + if (data.message !== undefined && data.message !== null) { + contents.message = data.message; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeTableDataImportJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetScreenDataCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetScreenDataCommandError(output, context); + } + const contents: GetScreenDataCommandOutput = { + $metadata: deserializeMetadata(output), + nextToken: undefined, + results: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + if (data.results !== undefined && data.results !== null) { + contents.results = deserializeAws_restJson1ResultSetMap(data.results, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetScreenDataCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1InvokeScreenAutomationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1InvokeScreenAutomationCommandError(output, context); + } + const contents: InvokeScreenAutomationCommandOutput = { + $metadata: deserializeMetadata(output), + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1InvokeScreenAutomationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "AutomationExecutionException": + case "com.amazonaws.honeycode#AutomationExecutionException": + response = { + ...(await deserializeAws_restJson1AutomationExecutionExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "AutomationExecutionTimeoutException": + case "com.amazonaws.honeycode#AutomationExecutionTimeoutException": + response = { + ...(await deserializeAws_restJson1AutomationExecutionTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListTableColumnsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListTableColumnsCommandError(output, context); + } + const contents: ListTableColumnsCommandOutput = { + $metadata: deserializeMetadata(output), + nextToken: undefined, + tableColumns: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + if (data.tableColumns !== undefined && data.tableColumns !== null) { + contents.tableColumns = deserializeAws_restJson1TableColumns(data.tableColumns, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListTableColumnsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListTableRowsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListTableRowsCommandError(output, context); + } + const contents: ListTableRowsCommandOutput = { + $metadata: deserializeMetadata(output), + columnIds: undefined, + nextToken: undefined, + rowIdsNotFound: undefined, + rows: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.columnIds !== undefined && data.columnIds !== null) { + contents.columnIds = deserializeAws_restJson1ResourceIds(data.columnIds, context); + } + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + if (data.rowIdsNotFound !== undefined && data.rowIdsNotFound !== null) { + contents.rowIdsNotFound = deserializeAws_restJson1RowIdList(data.rowIdsNotFound, context); + } + if (data.rows !== undefined && data.rows !== null) { + contents.rows = deserializeAws_restJson1TableRows(data.rows, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListTableRowsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListTablesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListTablesCommandError(output, context); + } + const contents: ListTablesCommandOutput = { + $metadata: deserializeMetadata(output), + nextToken: undefined, + tables: undefined, + workbookCursor: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.nextToken !== undefined && data.nextToken !== null) { + contents.nextToken = data.nextToken; + } + if (data.tables !== undefined && data.tables !== null) { + contents.tables = deserializeAws_restJson1Tables(data.tables, context); + } + if (data.workbookCursor !== undefined && data.workbookCursor !== null) { + contents.workbookCursor = data.workbookCursor; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListTablesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.honeycode#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.honeycode#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "RequestTimeoutException": + case "com.amazonaws.honeycode#RequestTimeoutException": + response = { + ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.honeycode#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailableException": + case "com.amazonaws.honeycode#ServiceUnavailableException": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.honeycode#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.honeycode#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1QueryTableRowsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode !== 200 && output.statusCode >= 300) { - return deserializeAws_restJson1GetScreenDataCommandError(output, context); + return deserializeAws_restJson1QueryTableRowsCommandError(output, context); } - const contents: GetScreenDataCommandOutput = { + const contents: QueryTableRowsCommandOutput = { $metadata: deserializeMetadata(output), + columnIds: undefined, nextToken: undefined, - results: undefined, + rows: undefined, workbookCursor: undefined, }; const data: any = await parseBody(output.body, context); + if (data.columnIds !== undefined && data.columnIds !== null) { + contents.columnIds = deserializeAws_restJson1ResourceIds(data.columnIds, context); + } if (data.nextToken !== undefined && data.nextToken !== null) { contents.nextToken = data.nextToken; } - if (data.results !== undefined && data.results !== null) { - contents.results = deserializeAws_restJson1ResultSetMap(data.results, context); + if (data.rows !== undefined && data.rows !== null) { + contents.rows = deserializeAws_restJson1TableRows(data.rows, context); } if (data.workbookCursor !== undefined && data.workbookCursor !== null) { contents.workbookCursor = data.workbookCursor; @@ -152,10 +1773,10 @@ export const deserializeAws_restJson1GetScreenDataCommand = async ( return Promise.resolve(contents); }; -const deserializeAws_restJson1GetScreenDataCommandError = async ( +const deserializeAws_restJson1QueryTableRowsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -237,28 +1858,32 @@ const deserializeAws_restJson1GetScreenDataCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_restJson1InvokeScreenAutomationCommand = async ( +export const deserializeAws_restJson1StartTableDataImportJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode !== 200 && output.statusCode >= 300) { - return deserializeAws_restJson1InvokeScreenAutomationCommandError(output, context); + return deserializeAws_restJson1StartTableDataImportJobCommandError(output, context); } - const contents: InvokeScreenAutomationCommandOutput = { + const contents: StartTableDataImportJobCommandOutput = { $metadata: deserializeMetadata(output), - workbookCursor: undefined, + jobId: undefined, + jobStatus: undefined, }; const data: any = await parseBody(output.body, context); - if (data.workbookCursor !== undefined && data.workbookCursor !== null) { - contents.workbookCursor = data.workbookCursor; + if (data.jobId !== undefined && data.jobId !== null) { + contents.jobId = data.jobId; + } + if (data.jobStatus !== undefined && data.jobStatus !== null) { + contents.jobStatus = data.jobStatus; } return Promise.resolve(contents); }; -const deserializeAws_restJson1InvokeScreenAutomationCommandError = async ( +const deserializeAws_restJson1StartTableDataImportJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -275,22 +1900,6 @@ const deserializeAws_restJson1InvokeScreenAutomationCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "AutomationExecutionException": - case "com.amazonaws.honeycode#AutomationExecutionException": - response = { - ...(await deserializeAws_restJson1AutomationExecutionExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "AutomationExecutionTimeoutException": - case "com.amazonaws.honeycode#AutomationExecutionTimeoutException": - response = { - ...(await deserializeAws_restJson1AutomationExecutionTimeoutExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "InternalServerException": case "com.amazonaws.honeycode#InternalServerException": response = { @@ -299,14 +1908,6 @@ const deserializeAws_restJson1InvokeScreenAutomationCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "RequestTimeoutException": - case "com.amazonaws.honeycode#RequestTimeoutException": - response = { - ...(await deserializeAws_restJson1RequestTimeoutExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "ResourceNotFoundException": case "com.amazonaws.honeycode#ResourceNotFoundException": response = { @@ -458,6 +2059,23 @@ const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( return contents; }; +const deserializeAws_restJson1ServiceQuotaExceededExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ServiceQuotaExceededException = { + name: "ServiceQuotaExceededException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + message: undefined, + }; + const data: any = parsedOutput.body; + if (data.message !== undefined && data.message !== null) { + contents.message = data.message; + } + return contents; +}; + const deserializeAws_restJson1ServiceUnavailableExceptionResponse = async ( parsedOutput: any, context: __SerdeContext @@ -509,6 +2127,140 @@ const deserializeAws_restJson1ValidationExceptionResponse = async ( return contents; }; +const serializeAws_restJson1CellInput = (input: CellInput, context: __SerdeContext): any => { + return { + ...(input.fact !== undefined && { fact: input.fact }), + }; +}; + +const serializeAws_restJson1CreateRowData = (input: CreateRowData, context: __SerdeContext): any => { + return { + ...(input.batchItemId !== undefined && { batchItemId: input.batchItemId }), + ...(input.cellsToCreate !== undefined && { + cellsToCreate: serializeAws_restJson1RowDataInput(input.cellsToCreate, context), + }), + }; +}; + +const serializeAws_restJson1CreateRowDataList = (input: CreateRowData[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_restJson1CreateRowData(entry, context)); +}; + +const serializeAws_restJson1DelimitedTextImportOptions = ( + input: DelimitedTextImportOptions, + context: __SerdeContext +): any => { + return { + ...(input.dataCharacterEncoding !== undefined && { dataCharacterEncoding: input.dataCharacterEncoding }), + ...(input.delimiter !== undefined && { delimiter: input.delimiter }), + ...(input.hasHeaderRow !== undefined && { hasHeaderRow: input.hasHeaderRow }), + ...(input.ignoreEmptyRows !== undefined && { ignoreEmptyRows: input.ignoreEmptyRows }), + }; +}; + +const serializeAws_restJson1DestinationOptions = (input: DestinationOptions, context: __SerdeContext): any => { + return { + ...(input.columnMap !== undefined && { + columnMap: serializeAws_restJson1ImportColumnMap(input.columnMap, context), + }), + }; +}; + +const serializeAws_restJson1Filter = (input: Filter, context: __SerdeContext): any => { + return { + ...(input.contextRowId !== undefined && { contextRowId: input.contextRowId }), + ...(input.formula !== undefined && { formula: input.formula }), + }; +}; + +const serializeAws_restJson1ImportColumnMap = ( + input: { [key: string]: SourceDataColumnProperties }, + context: __SerdeContext +): any => { + return Object.entries(input).reduce( + (acc: { [key: string]: SourceDataColumnProperties }, [key, value]: [string, any]) => ({ + ...acc, + [key]: serializeAws_restJson1SourceDataColumnProperties(value, context), + }), + {} + ); +}; + +const serializeAws_restJson1ImportDataSource = (input: ImportDataSource, context: __SerdeContext): any => { + return { + ...(input.dataSourceConfig !== undefined && { + dataSourceConfig: serializeAws_restJson1ImportDataSourceConfig(input.dataSourceConfig, context), + }), + }; +}; + +const serializeAws_restJson1ImportDataSourceConfig = (input: ImportDataSourceConfig, context: __SerdeContext): any => { + return { + ...(input.dataSourceUrl !== undefined && { dataSourceUrl: input.dataSourceUrl }), + }; +}; + +const serializeAws_restJson1ImportOptions = (input: ImportOptions, context: __SerdeContext): any => { + return { + ...(input.delimitedTextOptions !== undefined && { + delimitedTextOptions: serializeAws_restJson1DelimitedTextImportOptions(input.delimitedTextOptions, context), + }), + ...(input.destinationOptions !== undefined && { + destinationOptions: serializeAws_restJson1DestinationOptions(input.destinationOptions, context), + }), + }; +}; + +const serializeAws_restJson1RowDataInput = (input: { [key: string]: CellInput }, context: __SerdeContext): any => { + return Object.entries(input).reduce( + (acc: { [key: string]: CellInput }, [key, value]: [string, any]) => ({ + ...acc, + [key]: serializeAws_restJson1CellInput(value, context), + }), + {} + ); +}; + +const serializeAws_restJson1RowIdList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_restJson1SourceDataColumnProperties = ( + input: SourceDataColumnProperties, + context: __SerdeContext +): any => { + return { + ...(input.columnIndex !== undefined && { columnIndex: input.columnIndex }), + }; +}; + +const serializeAws_restJson1UpdateRowData = (input: UpdateRowData, context: __SerdeContext): any => { + return { + ...(input.cellsToUpdate !== undefined && { + cellsToUpdate: serializeAws_restJson1RowDataInput(input.cellsToUpdate, context), + }), + ...(input.rowId !== undefined && { rowId: input.rowId }), + }; +}; + +const serializeAws_restJson1UpdateRowDataList = (input: UpdateRowData[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_restJson1UpdateRowData(entry, context)); +}; + +const serializeAws_restJson1UpsertRowData = (input: UpsertRowData, context: __SerdeContext): any => { + return { + ...(input.batchItemId !== undefined && { batchItemId: input.batchItemId }), + ...(input.cellsToUpdate !== undefined && { + cellsToUpdate: serializeAws_restJson1RowDataInput(input.cellsToUpdate, context), + }), + ...(input.filter !== undefined && { filter: serializeAws_restJson1Filter(input.filter, context) }), + }; +}; + +const serializeAws_restJson1UpsertRowDataList = (input: UpsertRowData[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_restJson1UpsertRowData(entry, context)); +}; + const serializeAws_restJson1VariableValue = (input: VariableValue, context: __SerdeContext): any => { return { ...(input.rawValue !== undefined && { rawValue: input.rawValue }), @@ -528,6 +2280,20 @@ const serializeAws_restJson1VariableValueMap = ( ); }; +const deserializeAws_restJson1Cell = (output: any, context: __SerdeContext): Cell => { + return { + format: output.format !== undefined && output.format !== null ? output.format : undefined, + formattedValue: + output.formattedValue !== undefined && output.formattedValue !== null ? output.formattedValue : undefined, + formula: output.formula !== undefined && output.formula !== null ? output.formula : undefined, + rawValue: output.rawValue !== undefined && output.rawValue !== null ? output.rawValue : undefined, + } as any; +}; + +const deserializeAws_restJson1Cells = (output: any, context: __SerdeContext): Cell[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1Cell(entry, context)); +}; + const deserializeAws_restJson1ColumnMetadata = (output: any, context: __SerdeContext): ColumnMetadata => { return { format: output.format !== undefined && output.format !== null ? output.format : undefined, @@ -535,6 +2301,16 @@ const deserializeAws_restJson1ColumnMetadata = (output: any, context: __SerdeCon } as any; }; +const deserializeAws_restJson1CreatedRowsMap = (output: any, context: __SerdeContext): { [key: string]: string } => { + return Object.entries(output).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + const deserializeAws_restJson1DataItem = (output: any, context: __SerdeContext): DataItem => { return { formattedValue: @@ -549,6 +2325,98 @@ const deserializeAws_restJson1DataItems = (output: any, context: __SerdeContext) return (output || []).map((entry: any) => deserializeAws_restJson1DataItem(entry, context)); }; +const deserializeAws_restJson1DelimitedTextImportOptions = ( + output: any, + context: __SerdeContext +): DelimitedTextImportOptions => { + return { + dataCharacterEncoding: + output.dataCharacterEncoding !== undefined && output.dataCharacterEncoding !== null + ? output.dataCharacterEncoding + : undefined, + delimiter: output.delimiter !== undefined && output.delimiter !== null ? output.delimiter : undefined, + hasHeaderRow: output.hasHeaderRow !== undefined && output.hasHeaderRow !== null ? output.hasHeaderRow : undefined, + ignoreEmptyRows: + output.ignoreEmptyRows !== undefined && output.ignoreEmptyRows !== null ? output.ignoreEmptyRows : undefined, + } as any; +}; + +const deserializeAws_restJson1DestinationOptions = (output: any, context: __SerdeContext): DestinationOptions => { + return { + columnMap: + output.columnMap !== undefined && output.columnMap !== null + ? deserializeAws_restJson1ImportColumnMap(output.columnMap, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1FailedBatchItem = (output: any, context: __SerdeContext): FailedBatchItem => { + return { + errorMessage: output.errorMessage !== undefined && output.errorMessage !== null ? output.errorMessage : undefined, + id: output.id !== undefined && output.id !== null ? output.id : undefined, + } as any; +}; + +const deserializeAws_restJson1FailedBatchItems = (output: any, context: __SerdeContext): FailedBatchItem[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1FailedBatchItem(entry, context)); +}; + +const deserializeAws_restJson1ImportColumnMap = ( + output: any, + context: __SerdeContext +): { [key: string]: SourceDataColumnProperties } => { + return Object.entries(output).reduce( + (acc: { [key: string]: SourceDataColumnProperties }, [key, value]: [string, any]) => ({ + ...acc, + [key]: deserializeAws_restJson1SourceDataColumnProperties(value, context), + }), + {} + ); +}; + +const deserializeAws_restJson1ImportDataSource = (output: any, context: __SerdeContext): ImportDataSource => { + return { + dataSourceConfig: + output.dataSourceConfig !== undefined && output.dataSourceConfig !== null + ? deserializeAws_restJson1ImportDataSourceConfig(output.dataSourceConfig, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ImportDataSourceConfig = ( + output: any, + context: __SerdeContext +): ImportDataSourceConfig => { + return { + dataSourceUrl: + output.dataSourceUrl !== undefined && output.dataSourceUrl !== null ? output.dataSourceUrl : undefined, + } as any; +}; + +const deserializeAws_restJson1ImportJobSubmitter = (output: any, context: __SerdeContext): ImportJobSubmitter => { + return { + email: output.email !== undefined && output.email !== null ? output.email : undefined, + userArn: output.userArn !== undefined && output.userArn !== null ? output.userArn : undefined, + } as any; +}; + +const deserializeAws_restJson1ImportOptions = (output: any, context: __SerdeContext): ImportOptions => { + return { + delimitedTextOptions: + output.delimitedTextOptions !== undefined && output.delimitedTextOptions !== null + ? deserializeAws_restJson1DelimitedTextImportOptions(output.delimitedTextOptions, context) + : undefined, + destinationOptions: + output.destinationOptions !== undefined && output.destinationOptions !== null + ? deserializeAws_restJson1DestinationOptions(output.destinationOptions, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ResourceIds = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + const deserializeAws_restJson1ResultHeader = (output: any, context: __SerdeContext): ColumnMetadata[] => { return (output || []).map((entry: any) => deserializeAws_restJson1ColumnMetadata(entry, context)); }; @@ -590,6 +2458,105 @@ const deserializeAws_restJson1ResultSetMap = (output: any, context: __SerdeConte ); }; +const deserializeAws_restJson1RowIdList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1SourceDataColumnProperties = ( + output: any, + context: __SerdeContext +): SourceDataColumnProperties => { + return { + columnIndex: output.columnIndex !== undefined && output.columnIndex !== null ? output.columnIndex : undefined, + } as any; +}; + +const deserializeAws_restJson1Table = (output: any, context: __SerdeContext): Table => { + return { + tableId: output.tableId !== undefined && output.tableId !== null ? output.tableId : undefined, + tableName: output.tableName !== undefined && output.tableName !== null ? output.tableName : undefined, + } as any; +}; + +const deserializeAws_restJson1TableColumn = (output: any, context: __SerdeContext): TableColumn => { + return { + format: output.format !== undefined && output.format !== null ? output.format : undefined, + tableColumnId: + output.tableColumnId !== undefined && output.tableColumnId !== null ? output.tableColumnId : undefined, + tableColumnName: + output.tableColumnName !== undefined && output.tableColumnName !== null ? output.tableColumnName : undefined, + } as any; +}; + +const deserializeAws_restJson1TableColumns = (output: any, context: __SerdeContext): TableColumn[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1TableColumn(entry, context)); +}; + +const deserializeAws_restJson1TableDataImportJobMetadata = ( + output: any, + context: __SerdeContext +): TableDataImportJobMetadata => { + return { + dataSource: + output.dataSource !== undefined && output.dataSource !== null + ? deserializeAws_restJson1ImportDataSource(output.dataSource, context) + : undefined, + importOptions: + output.importOptions !== undefined && output.importOptions !== null + ? deserializeAws_restJson1ImportOptions(output.importOptions, context) + : undefined, + submitTime: + output.submitTime !== undefined && output.submitTime !== null + ? new Date(Math.round(output.submitTime * 1000)) + : undefined, + submitter: + output.submitter !== undefined && output.submitter !== null + ? deserializeAws_restJson1ImportJobSubmitter(output.submitter, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1TableRow = (output: any, context: __SerdeContext): TableRow => { + return { + cells: + output.cells !== undefined && output.cells !== null + ? deserializeAws_restJson1Cells(output.cells, context) + : undefined, + rowId: output.rowId !== undefined && output.rowId !== null ? output.rowId : undefined, + } as any; +}; + +const deserializeAws_restJson1TableRows = (output: any, context: __SerdeContext): TableRow[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1TableRow(entry, context)); +}; + +const deserializeAws_restJson1Tables = (output: any, context: __SerdeContext): Table[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1Table(entry, context)); +}; + +const deserializeAws_restJson1UpsertRowsResult = (output: any, context: __SerdeContext): UpsertRowsResult => { + return { + rowIds: + output.rowIds !== undefined && output.rowIds !== null + ? deserializeAws_restJson1RowIdList(output.rowIds, context) + : undefined, + upsertAction: output.upsertAction !== undefined && output.upsertAction !== null ? output.upsertAction : undefined, + } as any; +}; + +const deserializeAws_restJson1UpsertRowsResultMap = ( + output: any, + context: __SerdeContext +): { [key: string]: UpsertRowsResult } => { + return Object.entries(output).reduce( + (acc: { [key: string]: UpsertRowsResult }, [key, value]: [string, any]) => ({ + ...acc, + [key]: deserializeAws_restJson1UpsertRowsResult(value, context), + }), + {} + ); +}; + const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ httpStatusCode: output.statusCode, httpHeaders: output.headers, diff --git a/clients/client-lambda/Lambda.ts b/clients/client-lambda/Lambda.ts index 211d42c21f06..270dc4527d6a 100644 --- a/clients/client-lambda/Lambda.ts +++ b/clients/client-lambda/Lambda.ts @@ -488,8 +488,8 @@ export class Lambda extends LambdaClient { } /** - *

        Creates a Lambda function. To create a function, you need a deployment package and an execution role. The - * deployment package contains your function code. The execution role grants the function permission to use AWS + *

        Creates a Lambda function. To create a function, you need a deployment package and an execution role. The + * deployment package is a ZIP archive or image container that contains your function code. The execution role grants the function permission to use AWS * services, such as Amazon CloudWatch Logs for log streaming and AWS X-Ray for request tracing.

        * *

        When you create a function, Lambda provisions an instance of the function and its supporting resources. If @@ -510,7 +510,8 @@ export class Lambda extends LambdaClient { * to both the unpublished and published versions of the function, and include tags (TagResource) * and per-function concurrency limits (PutFunctionConcurrency).

        * - *

        To enable code signing for this function, specify the ARN of a code-signing configuration. When a user + *

        You can use code signing if your deployment package is a ZIP archive. To enable code signing for this function, + * specify the ARN of a code-signing configuration. When a user * attempts to deploy a code package with UpdateFunctionCode, Lambda checks that the code * package has a valid signature from a trusted publisher. The code-signing configuration * includes set set of signing profiles, which define the trusted publishers for this function.

        @@ -1398,7 +1399,7 @@ export class Lambda extends LambdaClient { /** *

        Returns a list of code - * signing configurations for the specified function. A request returns up to 10,000 configurations per + * signing configurations. A request returns up to 10,000 configurations per * call. You can use the MaxItems parameter to return fewer configurations per call.

        */ public listCodeSigningConfigs( diff --git a/clients/client-lambda/commands/CreateFunctionCommand.ts b/clients/client-lambda/commands/CreateFunctionCommand.ts index 26efdb72e449..13ea233597cf 100644 --- a/clients/client-lambda/commands/CreateFunctionCommand.ts +++ b/clients/client-lambda/commands/CreateFunctionCommand.ts @@ -21,8 +21,8 @@ export type CreateFunctionCommandInput = CreateFunctionRequest; export type CreateFunctionCommandOutput = FunctionConfiguration & __MetadataBearer; /** - *

        Creates a Lambda function. To create a function, you need a deployment package and an execution role. The - * deployment package contains your function code. The execution role grants the function permission to use AWS + *

        Creates a Lambda function. To create a function, you need a deployment package and an execution role. The + * deployment package is a ZIP archive or image container that contains your function code. The execution role grants the function permission to use AWS * services, such as Amazon CloudWatch Logs for log streaming and AWS X-Ray for request tracing.

        * *

        When you create a function, Lambda provisions an instance of the function and its supporting resources. If @@ -43,7 +43,8 @@ export type CreateFunctionCommandOutput = FunctionConfiguration & __MetadataBear * to both the unpublished and published versions of the function, and include tags (TagResource) * and per-function concurrency limits (PutFunctionConcurrency).

        * - *

        To enable code signing for this function, specify the ARN of a code-signing configuration. When a user + *

        You can use code signing if your deployment package is a ZIP archive. To enable code signing for this function, + * specify the ARN of a code-signing configuration. When a user * attempts to deploy a code package with UpdateFunctionCode, Lambda checks that the code * package has a valid signature from a trusted publisher. The code-signing configuration * includes set set of signing profiles, which define the trusted publishers for this function.

        diff --git a/clients/client-lambda/commands/ListCodeSigningConfigsCommand.ts b/clients/client-lambda/commands/ListCodeSigningConfigsCommand.ts index 96d2a8b0f80b..00e1999a8385 100644 --- a/clients/client-lambda/commands/ListCodeSigningConfigsCommand.ts +++ b/clients/client-lambda/commands/ListCodeSigningConfigsCommand.ts @@ -22,7 +22,7 @@ export type ListCodeSigningConfigsCommandOutput = ListCodeSigningConfigsResponse /** *

        Returns a list of code - * signing configurations for the specified function. A request returns up to 10,000 configurations per + * signing configurations. A request returns up to 10,000 configurations per * call. You can use the MaxItems parameter to return fewer configurations per call.

        */ export class ListCodeSigningConfigsCommand extends $Command< diff --git a/clients/client-lambda/models/models_0.ts b/clients/client-lambda/models/models_0.ts index 894728858398..e3b0cf88f3d0 100644 --- a/clients/client-lambda/models/models_0.ts +++ b/clients/client-lambda/models/models_0.ts @@ -500,12 +500,12 @@ export enum CodeSigningPolicy { /** *

        Code signing configuration policies specifies the validation failure action for signature mismatch or - * expiry.

        + * expiry.

        */ export interface CodeSigningPolicies { /** *

        Code signing configuration policy for deployment validation failure. If you set the policy to - * Enforce, Lambda blocks the deployment request if code-signing validation checks fail. If you set the + * Enforce, Lambda blocks the deployment request if signature validation checks fail. If you set the * policy to Warn, Lambda allows the deployment and creates a CloudWatch log.

        *

        Default value: Warn *

        @@ -1053,8 +1053,8 @@ export namespace CodeVerificationFailedException { } /** - *

        The code for the Lambda function. You can specify either an object in Amazon S3, or upload a deployment - * package directly.

        + *

        The code for the Lambda function. You can specify either an object in Amazon S3, upload a ZIP archive deployment + * package directly, or specify the URI of a container image.

        */ export interface FunctionCode { /** @@ -1077,6 +1077,11 @@ export interface FunctionCode { *

        For versioned objects, the version of the deployment package object to use.

        */ S3ObjectVersion?: string; + + /** + *

        URI of a container image in the Amazon ECR registry.

        + */ + ImageUri?: string; } export namespace FunctionCode { @@ -1141,6 +1146,39 @@ export namespace FileSystemConfig { }); } +/** + *

        Configuration values that override the container image Dockerfile. See + * Override Container settings.

        + */ +export interface ImageConfig { + /** + *

        Specifies the entry point to their application, which is typically the location of the runtime + * executable.

        + */ + EntryPoint?: string[]; + + /** + *

        Specifies parameters that you want to pass in with ENTRYPOINT.

        + */ + Command?: string[]; + + /** + *

        Specifies the working directory.

        + */ + WorkingDirectory?: string; +} + +export namespace ImageConfig { + export const filterSensitiveLog = (obj: ImageConfig): any => ({ + ...obj, + }); +} + +export enum PackageType { + Image = "Image", + Zip = "Zip", +} + export enum Runtime { dotnetcore10 = "dotnetcore1.0", dotnetcore20 = "dotnetcore2.0", @@ -1238,7 +1276,7 @@ export interface CreateFunctionRequest { /** *

        The identifier of the function's runtime.

        */ - Runtime: Runtime | string | undefined; + Runtime?: Runtime | string; /** *

        The Amazon Resource Name (ARN) of the function's execution role.

        @@ -1250,7 +1288,7 @@ export interface CreateFunctionRequest { * file name. It can also include namespaces and other qualifiers, depending on the runtime. For more information, * see Programming Model.

        */ - Handler: string | undefined; + Handler?: string; /** *

        The code for the function.

        @@ -1286,6 +1324,11 @@ export interface CreateFunctionRequest { */ VpcConfig?: VpcConfig; + /** + *

        The type of deployment package. Set to Image for container image and set Zip for ZIP archive.

        + */ + PackageType?: PackageType | string; + /** *

        A dead letter queue configuration that specifies the queue or topic where Lambda sends asynchronous events * when they fail processing. For more information, see Dead Letter Queues.

        @@ -1326,9 +1369,14 @@ export interface CreateFunctionRequest { */ FileSystemConfigs?: FileSystemConfig[]; + /** + *

        Configuration values that override the container image Dockerfile.

        + */ + ImageConfig?: ImageConfig; + /** *

        To enable code signing for this function, specify the ARN of a code-signing configuration. A code-signing configuration - * includes set set of signing profiles, which define the trusted publishers for this function.

        + * includes a set of signing profiles, which define the trusted publishers for this function.

        */ CodeSigningConfigArn?: string; } @@ -1387,6 +1435,50 @@ export namespace EnvironmentResponse { }); } +/** + *

        Error response to GetFunctionConfiguration.

        + */ +export interface ImageConfigError { + /** + *

        Error code.

        + */ + ErrorCode?: string; + + /** + *

        Error message.

        + */ + Message?: string; +} + +export namespace ImageConfigError { + export const filterSensitiveLog = (obj: ImageConfigError): any => ({ + ...obj, + ...(obj.Message && { Message: SENSITIVE_STRING }), + }); +} + +/** + *

        Response to GetFunctionConfiguration request.

        + */ +export interface ImageConfigResponse { + /** + *

        Configuration values that override the container image Dockerfile.

        + */ + ImageConfig?: ImageConfig; + + /** + *

        Error response to GetFunctionConfiguration.

        + */ + Error?: ImageConfigError; +} + +export namespace ImageConfigResponse { + export const filterSensitiveLog = (obj: ImageConfigResponse): any => ({ + ...obj, + ...(obj.Error && { Error: ImageConfigError.filterSensitiveLog(obj.Error) }), + }); +} + export enum LastUpdateStatus { Failed = "Failed", InProgress = "InProgress", @@ -1395,6 +1487,8 @@ export enum LastUpdateStatus { export enum LastUpdateStatusReasonCode { EniLimitExceeded = "EniLimitExceeded", + ImageAccessDenied = "ImageAccessDenied", + ImageDeleted = "ImageDeleted", InsufficientRolePermissions = "InsufficientRolePermissions", InternalError = "InternalError", InvalidConfiguration = "InvalidConfiguration", @@ -1446,6 +1540,8 @@ export enum StateReasonCode { Creating = "Creating", EniLimitExceeded = "EniLimitExceeded", Idle = "Idle", + ImageAccessDenied = "ImageAccessDenied", + ImageDeleted = "ImageDeleted", InsufficientRolePermissions = "InsufficientRolePermissions", InternalError = "InternalError", InvalidConfiguration = "InvalidConfiguration", @@ -1641,6 +1737,16 @@ export interface FunctionConfiguration { */ FileSystemConfigs?: FileSystemConfig[]; + /** + *

        The type of deployment package. Set to Image for container image and set Zip for ZIP archive.

        + */ + PackageType?: PackageType | string; + + /** + *

        The function's image configuration values.

        + */ + ImageConfigResponse?: ImageConfigResponse; + /** *

        The ARN of the signing profile version.

        */ @@ -1656,6 +1762,9 @@ export namespace FunctionConfiguration { export const filterSensitiveLog = (obj: FunctionConfiguration): any => ({ ...obj, ...(obj.Environment && { Environment: EnvironmentResponse.filterSensitiveLog(obj.Environment) }), + ...(obj.ImageConfigResponse && { + ImageConfigResponse: ImageConfigResponse.filterSensitiveLog(obj.ImageConfigResponse), + }), }); } @@ -2109,6 +2218,16 @@ export interface FunctionCodeLocation { *

        A presigned URL that you can use to download the deployment package.

        */ Location?: string; + + /** + *

        URI of a container image in the Amazon ECR registry.

        + */ + ImageUri?: string; + + /** + *

        The resolved URI for the image.

        + */ + ResolvedImageUri?: string; } export namespace FunctionCodeLocation { @@ -4764,6 +4883,11 @@ export interface UpdateFunctionCodeRequest { */ S3ObjectVersion?: string; + /** + *

        URI of a container image in the Amazon ECR registry.

        + */ + ImageUri?: string; + /** *

        Set to true to publish a new version of the function after updating the code. This has the same effect as * calling PublishVersion separately.

        @@ -4895,6 +5019,11 @@ export interface UpdateFunctionConfigurationRequest { *

        Connection settings for an Amazon EFS file system.

        */ FileSystemConfigs?: FileSystemConfig[]; + + /** + *

        Configuration values that override the container image Dockerfile.

        + */ + ImageConfig?: ImageConfig; } export namespace UpdateFunctionConfigurationRequest { diff --git a/clients/client-lambda/protocols/Aws_restJson1.ts b/clients/client-lambda/protocols/Aws_restJson1.ts index 1104e4588d7a..73b50cf7c994 100644 --- a/clients/client-lambda/protocols/Aws_restJson1.ts +++ b/clients/client-lambda/protocols/Aws_restJson1.ts @@ -189,6 +189,9 @@ import { FunctionCodeLocation, FunctionConfiguration, FunctionEventInvokeConfig, + ImageConfig, + ImageConfigError, + ImageConfigResponse, InvalidCodeSignatureException, InvalidParameterValueException, InvalidRequestContentException, @@ -476,9 +479,13 @@ export const serializeAws_restJson1CreateFunctionCommand = async ( }), ...(input.FunctionName !== undefined && { FunctionName: input.FunctionName }), ...(input.Handler !== undefined && { Handler: input.Handler }), + ...(input.ImageConfig !== undefined && { + ImageConfig: serializeAws_restJson1ImageConfig(input.ImageConfig, context), + }), ...(input.KMSKeyArn !== undefined && { KMSKeyArn: input.KMSKeyArn }), ...(input.Layers !== undefined && { Layers: serializeAws_restJson1LayerList(input.Layers, context) }), ...(input.MemorySize !== undefined && { MemorySize: input.MemorySize }), + ...(input.PackageType !== undefined && { PackageType: input.PackageType }), ...(input.Publish !== undefined && { Publish: input.Publish }), ...(input.Role !== undefined && { Role: input.Role }), ...(input.Runtime !== undefined && { Runtime: input.Runtime }), @@ -2228,6 +2235,7 @@ export const serializeAws_restJson1UpdateFunctionCodeCommand = async ( let body: any; body = JSON.stringify({ ...(input.DryRun !== undefined && { DryRun: input.DryRun }), + ...(input.ImageUri !== undefined && { ImageUri: input.ImageUri }), ...(input.Publish !== undefined && { Publish: input.Publish }), ...(input.RevisionId !== undefined && { RevisionId: input.RevisionId }), ...(input.S3Bucket !== undefined && { S3Bucket: input.S3Bucket }), @@ -2277,6 +2285,9 @@ export const serializeAws_restJson1UpdateFunctionConfigurationCommand = async ( FileSystemConfigs: serializeAws_restJson1FileSystemConfigList(input.FileSystemConfigs, context), }), ...(input.Handler !== undefined && { Handler: input.Handler }), + ...(input.ImageConfig !== undefined && { + ImageConfig: serializeAws_restJson1ImageConfig(input.ImageConfig, context), + }), ...(input.KMSKeyArn !== undefined && { KMSKeyArn: input.KMSKeyArn }), ...(input.Layers !== undefined && { Layers: serializeAws_restJson1LayerList(input.Layers, context) }), ...(input.MemorySize !== undefined && { MemorySize: input.MemorySize }), @@ -2902,6 +2913,7 @@ export const deserializeAws_restJson1CreateFunctionCommand = async ( FunctionArn: undefined, FunctionName: undefined, Handler: undefined, + ImageConfigResponse: undefined, KMSKeyArn: undefined, LastModified: undefined, LastUpdateStatus: undefined, @@ -2910,6 +2922,7 @@ export const deserializeAws_restJson1CreateFunctionCommand = async ( Layers: undefined, MasterArn: undefined, MemorySize: undefined, + PackageType: undefined, RevisionId: undefined, Role: undefined, Runtime: undefined, @@ -2951,6 +2964,9 @@ export const deserializeAws_restJson1CreateFunctionCommand = async ( if (data.Handler !== undefined && data.Handler !== null) { contents.Handler = data.Handler; } + if (data.ImageConfigResponse !== undefined && data.ImageConfigResponse !== null) { + contents.ImageConfigResponse = deserializeAws_restJson1ImageConfigResponse(data.ImageConfigResponse, context); + } if (data.KMSKeyArn !== undefined && data.KMSKeyArn !== null) { contents.KMSKeyArn = data.KMSKeyArn; } @@ -2975,6 +2991,9 @@ export const deserializeAws_restJson1CreateFunctionCommand = async ( if (data.MemorySize !== undefined && data.MemorySize !== null) { contents.MemorySize = data.MemorySize; } + if (data.PackageType !== undefined && data.PackageType !== null) { + contents.PackageType = data.PackageType; + } if (data.RevisionId !== undefined && data.RevisionId !== null) { contents.RevisionId = data.RevisionId; } @@ -4563,6 +4582,7 @@ export const deserializeAws_restJson1GetFunctionConfigurationCommand = async ( FunctionArn: undefined, FunctionName: undefined, Handler: undefined, + ImageConfigResponse: undefined, KMSKeyArn: undefined, LastModified: undefined, LastUpdateStatus: undefined, @@ -4571,6 +4591,7 @@ export const deserializeAws_restJson1GetFunctionConfigurationCommand = async ( Layers: undefined, MasterArn: undefined, MemorySize: undefined, + PackageType: undefined, RevisionId: undefined, Role: undefined, Runtime: undefined, @@ -4612,6 +4633,9 @@ export const deserializeAws_restJson1GetFunctionConfigurationCommand = async ( if (data.Handler !== undefined && data.Handler !== null) { contents.Handler = data.Handler; } + if (data.ImageConfigResponse !== undefined && data.ImageConfigResponse !== null) { + contents.ImageConfigResponse = deserializeAws_restJson1ImageConfigResponse(data.ImageConfigResponse, context); + } if (data.KMSKeyArn !== undefined && data.KMSKeyArn !== null) { contents.KMSKeyArn = data.KMSKeyArn; } @@ -4636,6 +4660,9 @@ export const deserializeAws_restJson1GetFunctionConfigurationCommand = async ( if (data.MemorySize !== undefined && data.MemorySize !== null) { contents.MemorySize = data.MemorySize; } + if (data.PackageType !== undefined && data.PackageType !== null) { + contents.PackageType = data.PackageType; + } if (data.RevisionId !== undefined && data.RevisionId !== null) { contents.RevisionId = data.RevisionId; } @@ -6685,6 +6712,7 @@ export const deserializeAws_restJson1PublishVersionCommand = async ( FunctionArn: undefined, FunctionName: undefined, Handler: undefined, + ImageConfigResponse: undefined, KMSKeyArn: undefined, LastModified: undefined, LastUpdateStatus: undefined, @@ -6693,6 +6721,7 @@ export const deserializeAws_restJson1PublishVersionCommand = async ( Layers: undefined, MasterArn: undefined, MemorySize: undefined, + PackageType: undefined, RevisionId: undefined, Role: undefined, Runtime: undefined, @@ -6734,6 +6763,9 @@ export const deserializeAws_restJson1PublishVersionCommand = async ( if (data.Handler !== undefined && data.Handler !== null) { contents.Handler = data.Handler; } + if (data.ImageConfigResponse !== undefined && data.ImageConfigResponse !== null) { + contents.ImageConfigResponse = deserializeAws_restJson1ImageConfigResponse(data.ImageConfigResponse, context); + } if (data.KMSKeyArn !== undefined && data.KMSKeyArn !== null) { contents.KMSKeyArn = data.KMSKeyArn; } @@ -6758,6 +6790,9 @@ export const deserializeAws_restJson1PublishVersionCommand = async ( if (data.MemorySize !== undefined && data.MemorySize !== null) { contents.MemorySize = data.MemorySize; } + if (data.PackageType !== undefined && data.PackageType !== null) { + contents.PackageType = data.PackageType; + } if (data.RevisionId !== undefined && data.RevisionId !== null) { contents.RevisionId = data.RevisionId; } @@ -7985,6 +8020,7 @@ export const deserializeAws_restJson1UpdateFunctionCodeCommand = async ( FunctionArn: undefined, FunctionName: undefined, Handler: undefined, + ImageConfigResponse: undefined, KMSKeyArn: undefined, LastModified: undefined, LastUpdateStatus: undefined, @@ -7993,6 +8029,7 @@ export const deserializeAws_restJson1UpdateFunctionCodeCommand = async ( Layers: undefined, MasterArn: undefined, MemorySize: undefined, + PackageType: undefined, RevisionId: undefined, Role: undefined, Runtime: undefined, @@ -8034,6 +8071,9 @@ export const deserializeAws_restJson1UpdateFunctionCodeCommand = async ( if (data.Handler !== undefined && data.Handler !== null) { contents.Handler = data.Handler; } + if (data.ImageConfigResponse !== undefined && data.ImageConfigResponse !== null) { + contents.ImageConfigResponse = deserializeAws_restJson1ImageConfigResponse(data.ImageConfigResponse, context); + } if (data.KMSKeyArn !== undefined && data.KMSKeyArn !== null) { contents.KMSKeyArn = data.KMSKeyArn; } @@ -8058,6 +8098,9 @@ export const deserializeAws_restJson1UpdateFunctionCodeCommand = async ( if (data.MemorySize !== undefined && data.MemorySize !== null) { contents.MemorySize = data.MemorySize; } + if (data.PackageType !== undefined && data.PackageType !== null) { + contents.PackageType = data.PackageType; + } if (data.RevisionId !== undefined && data.RevisionId !== null) { contents.RevisionId = data.RevisionId; } @@ -8224,6 +8267,7 @@ export const deserializeAws_restJson1UpdateFunctionConfigurationCommand = async FunctionArn: undefined, FunctionName: undefined, Handler: undefined, + ImageConfigResponse: undefined, KMSKeyArn: undefined, LastModified: undefined, LastUpdateStatus: undefined, @@ -8232,6 +8276,7 @@ export const deserializeAws_restJson1UpdateFunctionConfigurationCommand = async Layers: undefined, MasterArn: undefined, MemorySize: undefined, + PackageType: undefined, RevisionId: undefined, Role: undefined, Runtime: undefined, @@ -8273,6 +8318,9 @@ export const deserializeAws_restJson1UpdateFunctionConfigurationCommand = async if (data.Handler !== undefined && data.Handler !== null) { contents.Handler = data.Handler; } + if (data.ImageConfigResponse !== undefined && data.ImageConfigResponse !== null) { + contents.ImageConfigResponse = deserializeAws_restJson1ImageConfigResponse(data.ImageConfigResponse, context); + } if (data.KMSKeyArn !== undefined && data.KMSKeyArn !== null) { contents.KMSKeyArn = data.KMSKeyArn; } @@ -8297,6 +8345,9 @@ export const deserializeAws_restJson1UpdateFunctionConfigurationCommand = async if (data.MemorySize !== undefined && data.MemorySize !== null) { contents.MemorySize = data.MemorySize; } + if (data.PackageType !== undefined && data.PackageType !== null) { + contents.PackageType = data.PackageType; + } if (data.RevisionId !== undefined && data.RevisionId !== null) { contents.RevisionId = data.RevisionId; } @@ -9349,6 +9400,7 @@ const serializeAws_restJson1FileSystemConfigList = (input: FileSystemConfig[], c const serializeAws_restJson1FunctionCode = (input: FunctionCode, context: __SerdeContext): any => { return { + ...(input.ImageUri !== undefined && { ImageUri: input.ImageUri }), ...(input.S3Bucket !== undefined && { S3Bucket: input.S3Bucket }), ...(input.S3Key !== undefined && { S3Key: input.S3Key }), ...(input.S3ObjectVersion !== undefined && { S3ObjectVersion: input.S3ObjectVersion }), @@ -9356,6 +9408,14 @@ const serializeAws_restJson1FunctionCode = (input: FunctionCode, context: __Serd }; }; +const serializeAws_restJson1ImageConfig = (input: ImageConfig, context: __SerdeContext): any => { + return { + ...(input.Command !== undefined && { Command: serializeAws_restJson1StringList(input.Command, context) }), + ...(input.EntryPoint !== undefined && { EntryPoint: serializeAws_restJson1StringList(input.EntryPoint, context) }), + ...(input.WorkingDirectory !== undefined && { WorkingDirectory: input.WorkingDirectory }), + }; +}; + const serializeAws_restJson1LayerList = (input: string[], context: __SerdeContext): any => { return input.map((entry) => entry); }; @@ -9413,6 +9473,10 @@ const serializeAws_restJson1SourceAccessConfigurations = ( return input.map((entry) => serializeAws_restJson1SourceAccessConfiguration(entry, context)); }; +const serializeAws_restJson1StringList = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + const serializeAws_restJson1SubnetIds = (input: string[], context: __SerdeContext): any => { return input.map((entry) => entry); }; @@ -9721,9 +9785,12 @@ const deserializeAws_restJson1FunctionArnList = (output: any, context: __SerdeCo const deserializeAws_restJson1FunctionCodeLocation = (output: any, context: __SerdeContext): FunctionCodeLocation => { return { + ImageUri: output.ImageUri !== undefined && output.ImageUri !== null ? output.ImageUri : undefined, Location: output.Location !== undefined && output.Location !== null ? output.Location : undefined, RepositoryType: output.RepositoryType !== undefined && output.RepositoryType !== null ? output.RepositoryType : undefined, + ResolvedImageUri: + output.ResolvedImageUri !== undefined && output.ResolvedImageUri !== null ? output.ResolvedImageUri : undefined, } as any; }; @@ -9747,6 +9814,10 @@ const deserializeAws_restJson1FunctionConfiguration = (output: any, context: __S FunctionArn: output.FunctionArn !== undefined && output.FunctionArn !== null ? output.FunctionArn : undefined, FunctionName: output.FunctionName !== undefined && output.FunctionName !== null ? output.FunctionName : undefined, Handler: output.Handler !== undefined && output.Handler !== null ? output.Handler : undefined, + ImageConfigResponse: + output.ImageConfigResponse !== undefined && output.ImageConfigResponse !== null + ? deserializeAws_restJson1ImageConfigResponse(output.ImageConfigResponse, context) + : undefined, KMSKeyArn: output.KMSKeyArn !== undefined && output.KMSKeyArn !== null ? output.KMSKeyArn : undefined, LastModified: output.LastModified !== undefined && output.LastModified !== null ? output.LastModified : undefined, LastUpdateStatus: @@ -9765,6 +9836,7 @@ const deserializeAws_restJson1FunctionConfiguration = (output: any, context: __S : undefined, MasterArn: output.MasterArn !== undefined && output.MasterArn !== null ? output.MasterArn : undefined, MemorySize: output.MemorySize !== undefined && output.MemorySize !== null ? output.MemorySize : undefined, + PackageType: output.PackageType !== undefined && output.PackageType !== null ? output.PackageType : undefined, RevisionId: output.RevisionId !== undefined && output.RevisionId !== null ? output.RevisionId : undefined, Role: output.Role !== undefined && output.Role !== null ? output.Role : undefined, Runtime: output.Runtime !== undefined && output.Runtime !== null ? output.Runtime : undefined, @@ -9827,6 +9899,41 @@ const deserializeAws_restJson1FunctionList = (output: any, context: __SerdeConte return (output || []).map((entry: any) => deserializeAws_restJson1FunctionConfiguration(entry, context)); }; +const deserializeAws_restJson1ImageConfig = (output: any, context: __SerdeContext): ImageConfig => { + return { + Command: + output.Command !== undefined && output.Command !== null + ? deserializeAws_restJson1StringList(output.Command, context) + : undefined, + EntryPoint: + output.EntryPoint !== undefined && output.EntryPoint !== null + ? deserializeAws_restJson1StringList(output.EntryPoint, context) + : undefined, + WorkingDirectory: + output.WorkingDirectory !== undefined && output.WorkingDirectory !== null ? output.WorkingDirectory : undefined, + } as any; +}; + +const deserializeAws_restJson1ImageConfigError = (output: any, context: __SerdeContext): ImageConfigError => { + return { + ErrorCode: output.ErrorCode !== undefined && output.ErrorCode !== null ? output.ErrorCode : undefined, + Message: output.Message !== undefined && output.Message !== null ? output.Message : undefined, + } as any; +}; + +const deserializeAws_restJson1ImageConfigResponse = (output: any, context: __SerdeContext): ImageConfigResponse => { + return { + Error: + output.Error !== undefined && output.Error !== null + ? deserializeAws_restJson1ImageConfigError(output.Error, context) + : undefined, + ImageConfig: + output.ImageConfig !== undefined && output.ImageConfig !== null + ? deserializeAws_restJson1ImageConfig(output.ImageConfig, context) + : undefined, + } as any; +}; + const deserializeAws_restJson1Layer = (output: any, context: __SerdeContext): Layer => { return { Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, @@ -9972,6 +10079,10 @@ const deserializeAws_restJson1SourceAccessConfigurations = ( return (output || []).map((entry: any) => deserializeAws_restJson1SourceAccessConfiguration(entry, context)); }; +const deserializeAws_restJson1StringList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + const deserializeAws_restJson1SubnetIds = (output: any, context: __SerdeContext): string[] => { return (output || []).map((entry: any) => entry); }; diff --git a/clients/client-lookoutvision/.gitignore b/clients/client-lookoutvision/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-lookoutvision/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-lookoutvision/.npmignore b/clients/client-lookoutvision/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-lookoutvision/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-lookoutvision/LICENSE b/clients/client-lookoutvision/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-lookoutvision/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-lookoutvision/LookoutVision.ts b/clients/client-lookoutvision/LookoutVision.ts new file mode 100644 index 000000000000..9712cd0777c5 --- /dev/null +++ b/clients/client-lookoutvision/LookoutVision.ts @@ -0,0 +1,612 @@ +import { LookoutVisionClient } from "./LookoutVisionClient"; +import { + CreateDatasetCommand, + CreateDatasetCommandInput, + CreateDatasetCommandOutput, +} from "./commands/CreateDatasetCommand"; +import { CreateModelCommand, CreateModelCommandInput, CreateModelCommandOutput } from "./commands/CreateModelCommand"; +import { + CreateProjectCommand, + CreateProjectCommandInput, + CreateProjectCommandOutput, +} from "./commands/CreateProjectCommand"; +import { + DeleteDatasetCommand, + DeleteDatasetCommandInput, + DeleteDatasetCommandOutput, +} from "./commands/DeleteDatasetCommand"; +import { DeleteModelCommand, DeleteModelCommandInput, DeleteModelCommandOutput } from "./commands/DeleteModelCommand"; +import { + DeleteProjectCommand, + DeleteProjectCommandInput, + DeleteProjectCommandOutput, +} from "./commands/DeleteProjectCommand"; +import { + DescribeDatasetCommand, + DescribeDatasetCommandInput, + DescribeDatasetCommandOutput, +} from "./commands/DescribeDatasetCommand"; +import { + DescribeModelCommand, + DescribeModelCommandInput, + DescribeModelCommandOutput, +} from "./commands/DescribeModelCommand"; +import { + DescribeProjectCommand, + DescribeProjectCommandInput, + DescribeProjectCommandOutput, +} from "./commands/DescribeProjectCommand"; +import { + DetectAnomaliesCommand, + DetectAnomaliesCommandInput, + DetectAnomaliesCommandOutput, +} from "./commands/DetectAnomaliesCommand"; +import { + ListDatasetEntriesCommand, + ListDatasetEntriesCommandInput, + ListDatasetEntriesCommandOutput, +} from "./commands/ListDatasetEntriesCommand"; +import { ListModelsCommand, ListModelsCommandInput, ListModelsCommandOutput } from "./commands/ListModelsCommand"; +import { + ListProjectsCommand, + ListProjectsCommandInput, + ListProjectsCommandOutput, +} from "./commands/ListProjectsCommand"; +import { StartModelCommand, StartModelCommandInput, StartModelCommandOutput } from "./commands/StartModelCommand"; +import { StopModelCommand, StopModelCommandInput, StopModelCommandOutput } from "./commands/StopModelCommand"; +import { + UpdateDatasetEntriesCommand, + UpdateDatasetEntriesCommandInput, + UpdateDatasetEntriesCommandOutput, +} from "./commands/UpdateDatasetEntriesCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

        This is the Amazon Lookout for Vision API Reference. It provides descriptions of actions, + * data types, common parameters, and common errors.

        + *

        Amazon Lookout for Vision enables you to find visual defects in industrial products, + * accurately and at scale. It uses computer vision to identify missing components in an industrial product, + * damage to vehicles or structures, irregularities in production lines, and even minuscule defects in + * silicon wafers — or any other physical item where quality is important such as a missing capacitor + * on printed circuit boards.

        + */ +export class LookoutVision extends LookoutVisionClient { + /** + *

        Creates a new dataset in an Amazon Lookout for Vision project. CreateDataset can create a + * training or a test dataset from a valid dataset source (DatasetSource).

        + *

        If you want a single dataset project, specify train for the value of + * DatasetType.

        + *

        To have a project with separate training and test datasets, call CreateDataset twice. + * On the first call, specify train for the value of + * DatasetType. On the second call, specify test for the value of + * DatasetType. + * + * of dataset with

        + */ + public createDataset( + args: CreateDatasetCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createDataset( + args: CreateDatasetCommandInput, + cb: (err: any, data?: CreateDatasetCommandOutput) => void + ): void; + public createDataset( + args: CreateDatasetCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateDatasetCommandOutput) => void + ): void; + public createDataset( + args: CreateDatasetCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateDatasetCommandOutput) => void), + cb?: (err: any, data?: CreateDatasetCommandOutput) => void + ): Promise | void { + const command = new CreateDatasetCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Creates a new version of a model within an an Amazon Lookout for Vision project. + * CreateModel is an asynchronous operation in which Amazon Lookout for Vision trains, tests, + * and evaluates a new version of a model.

        + *

        To get the current status, check the Status field returned + * in the response from DescribeModel.

        + *

        If the project has a single dataset, Amazon Lookout for Vision internally splits the dataset + * to create a training and a test dataset. + * If the project has a training and a test dataset, Lookout for Vision uses the respective datasets to train and test + * the model.

        + *

        After training completes, the evaluation metrics are stored at the location specified in + * OutputConfig.

        + */ + public createModel(args: CreateModelCommandInput, options?: __HttpHandlerOptions): Promise; + public createModel(args: CreateModelCommandInput, cb: (err: any, data?: CreateModelCommandOutput) => void): void; + public createModel( + args: CreateModelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateModelCommandOutput) => void + ): void; + public createModel( + args: CreateModelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateModelCommandOutput) => void), + cb?: (err: any, data?: CreateModelCommandOutput) => void + ): Promise | void { + const command = new CreateModelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Creates an empty Amazon Lookout for Vision project. After you create the project, add a dataset by calling + * CreateDataset.

        + */ + public createProject( + args: CreateProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createProject( + args: CreateProjectCommandInput, + cb: (err: any, data?: CreateProjectCommandOutput) => void + ): void; + public createProject( + args: CreateProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateProjectCommandOutput) => void + ): void; + public createProject( + args: CreateProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateProjectCommandOutput) => void), + cb?: (err: any, data?: CreateProjectCommandOutput) => void + ): Promise | void { + const command = new CreateProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Deletes an existing Amazon Lookout for Vision dataset.

        + *

        If your the project has a single + * dataset, you must create a new dataset before you can create a model.

        + *

        If you project has a training dataset and a test dataset consider the following.

        + *
          + *
        • + *

          If you delete the test dataset, your project reverts to a single dataset project. If you then + * train the model, Amazon Lookout for Vision internally splits the remaining dataset into a training and test dataset.

          + *
        • + *
        • + *

          If you delete the training dataset, you must create a training dataset before you can create a model.

          + *
        • + *
        + *

        It might take a while to delete the dataset. To check the current status, check the Status field + * in the response from a call to DescribeDataset.

        + */ + public deleteDataset( + args: DeleteDatasetCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteDataset( + args: DeleteDatasetCommandInput, + cb: (err: any, data?: DeleteDatasetCommandOutput) => void + ): void; + public deleteDataset( + args: DeleteDatasetCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteDatasetCommandOutput) => void + ): void; + public deleteDataset( + args: DeleteDatasetCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteDatasetCommandOutput) => void), + cb?: (err: any, data?: DeleteDatasetCommandOutput) => void + ): Promise | void { + const command = new DeleteDatasetCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Deletes an Amazon Lookout for Vision model. You can't delete a running model. To stop a running model, + * use the StopModel operation.

        + */ + public deleteModel(args: DeleteModelCommandInput, options?: __HttpHandlerOptions): Promise; + public deleteModel(args: DeleteModelCommandInput, cb: (err: any, data?: DeleteModelCommandOutput) => void): void; + public deleteModel( + args: DeleteModelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteModelCommandOutput) => void + ): void; + public deleteModel( + args: DeleteModelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteModelCommandOutput) => void), + cb?: (err: any, data?: DeleteModelCommandOutput) => void + ): Promise | void { + const command = new DeleteModelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Deletes an Amazon Lookout for Vision project.

        + *

        To delete a project, you must first delete each version of the model associated with + * the project. To delete a model use the DeleteModel operation.

        + *

        The training and test datasets are deleted automatically for you. + * The images referenced by the training and test datasets aren't deleted.

        + */ + public deleteProject( + args: DeleteProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteProject( + args: DeleteProjectCommandInput, + cb: (err: any, data?: DeleteProjectCommandOutput) => void + ): void; + public deleteProject( + args: DeleteProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteProjectCommandOutput) => void + ): void; + public deleteProject( + args: DeleteProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteProjectCommandOutput) => void), + cb?: (err: any, data?: DeleteProjectCommandOutput) => void + ): Promise | void { + const command = new DeleteProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Describe an Amazon Lookout for Vision dataset.

        + */ + public describeDataset( + args: DescribeDatasetCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeDataset( + args: DescribeDatasetCommandInput, + cb: (err: any, data?: DescribeDatasetCommandOutput) => void + ): void; + public describeDataset( + args: DescribeDatasetCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeDatasetCommandOutput) => void + ): void; + public describeDataset( + args: DescribeDatasetCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeDatasetCommandOutput) => void), + cb?: (err: any, data?: DescribeDatasetCommandOutput) => void + ): Promise | void { + const command = new DescribeDatasetCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Describes a version of an Amazon Lookout for Vision model.

        + */ + public describeModel( + args: DescribeModelCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeModel( + args: DescribeModelCommandInput, + cb: (err: any, data?: DescribeModelCommandOutput) => void + ): void; + public describeModel( + args: DescribeModelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeModelCommandOutput) => void + ): void; + public describeModel( + args: DescribeModelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeModelCommandOutput) => void), + cb?: (err: any, data?: DescribeModelCommandOutput) => void + ): Promise | void { + const command = new DescribeModelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Describes an Amazon Lookout for Vision project.

        + */ + public describeProject( + args: DescribeProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeProject( + args: DescribeProjectCommandInput, + cb: (err: any, data?: DescribeProjectCommandOutput) => void + ): void; + public describeProject( + args: DescribeProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeProjectCommandOutput) => void + ): void; + public describeProject( + args: DescribeProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeProjectCommandOutput) => void), + cb?: (err: any, data?: DescribeProjectCommandOutput) => void + ): Promise | void { + const command = new DescribeProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Detects anomalies in an image that you supply.

        + *

        The response from DetectAnomalies includes a boolean prediction + * that the image contains one or more anomalies and a confidence value for the prediction.

        + * + *

        Before calling DetectAnomalies, you must first start your model with the StartModel operation. + * You are charged for the amount of time, in minutes, that a model runs and for the number of anomaly detection units that your + * model uses. If you are not using a model, use the StopModel operation to stop your model.

        + *
        + */ + public detectAnomalies( + args: DetectAnomaliesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public detectAnomalies( + args: DetectAnomaliesCommandInput, + cb: (err: any, data?: DetectAnomaliesCommandOutput) => void + ): void; + public detectAnomalies( + args: DetectAnomaliesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DetectAnomaliesCommandOutput) => void + ): void; + public detectAnomalies( + args: DetectAnomaliesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DetectAnomaliesCommandOutput) => void), + cb?: (err: any, data?: DetectAnomaliesCommandOutput) => void + ): Promise | void { + const command = new DetectAnomaliesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Lists the JSON Lines within a dataset. An Amazon Lookout for Vision JSON Line contains the anomaly + * information for a single image, including the image location and the assigned label.

        + */ + public listDatasetEntries( + args: ListDatasetEntriesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listDatasetEntries( + args: ListDatasetEntriesCommandInput, + cb: (err: any, data?: ListDatasetEntriesCommandOutput) => void + ): void; + public listDatasetEntries( + args: ListDatasetEntriesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListDatasetEntriesCommandOutput) => void + ): void; + public listDatasetEntries( + args: ListDatasetEntriesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListDatasetEntriesCommandOutput) => void), + cb?: (err: any, data?: ListDatasetEntriesCommandOutput) => void + ): Promise | void { + const command = new ListDatasetEntriesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Lists the versions of a model in an Amazon Lookout for Vision project.

        + */ + public listModels(args: ListModelsCommandInput, options?: __HttpHandlerOptions): Promise; + public listModels(args: ListModelsCommandInput, cb: (err: any, data?: ListModelsCommandOutput) => void): void; + public listModels( + args: ListModelsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListModelsCommandOutput) => void + ): void; + public listModels( + args: ListModelsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListModelsCommandOutput) => void), + cb?: (err: any, data?: ListModelsCommandOutput) => void + ): Promise | void { + const command = new ListModelsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Lists the Amazon Lookout for Vision projects in your AWS account.

        + */ + public listProjects( + args: ListProjectsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listProjects(args: ListProjectsCommandInput, cb: (err: any, data?: ListProjectsCommandOutput) => void): void; + public listProjects( + args: ListProjectsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListProjectsCommandOutput) => void + ): void; + public listProjects( + args: ListProjectsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListProjectsCommandOutput) => void), + cb?: (err: any, data?: ListProjectsCommandOutput) => void + ): Promise | void { + const command = new ListProjectsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Starts the running of the version of an Amazon Lookout for Vision model. Starting a model takes a while + * to complete. To check the current state of the model, use DescribeModel.

        + *

        Once the model is running, you can detect custom labels in new images by calling + * DetectAnomalies.

        + * + *

        You are charged for the amount of time that the model is running. To stop a running + * model, call StopModel.

        + *
        + */ + public startModel(args: StartModelCommandInput, options?: __HttpHandlerOptions): Promise; + public startModel(args: StartModelCommandInput, cb: (err: any, data?: StartModelCommandOutput) => void): void; + public startModel( + args: StartModelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StartModelCommandOutput) => void + ): void; + public startModel( + args: StartModelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StartModelCommandOutput) => void), + cb?: (err: any, data?: StartModelCommandOutput) => void + ): Promise | void { + const command = new StartModelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Stops a running model. The operation might take a while to complete. To + * check the current status, call DescribeModel.

        + */ + public stopModel(args: StopModelCommandInput, options?: __HttpHandlerOptions): Promise; + public stopModel(args: StopModelCommandInput, cb: (err: any, data?: StopModelCommandOutput) => void): void; + public stopModel( + args: StopModelCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StopModelCommandOutput) => void + ): void; + public stopModel( + args: StopModelCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StopModelCommandOutput) => void), + cb?: (err: any, data?: StopModelCommandOutput) => void + ): Promise | void { + const command = new StopModelCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

        Adds one or more JSON Line entries to a dataset. A JSON Line includes information about an image + * used for training or testing an Amazon Lookout for Vision model. The following is an example JSON Line.

        + * + * + *

        Updating a dataset might take a while to complete. To check the current status, call DescribeDataset and + * check the Status field in the response.

        + */ + public updateDatasetEntries( + args: UpdateDatasetEntriesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateDatasetEntries( + args: UpdateDatasetEntriesCommandInput, + cb: (err: any, data?: UpdateDatasetEntriesCommandOutput) => void + ): void; + public updateDatasetEntries( + args: UpdateDatasetEntriesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateDatasetEntriesCommandOutput) => void + ): void; + public updateDatasetEntries( + args: UpdateDatasetEntriesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateDatasetEntriesCommandOutput) => void), + cb?: (err: any, data?: UpdateDatasetEntriesCommandOutput) => void + ): Promise | void { + const command = new UpdateDatasetEntriesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-lookoutvision/LookoutVisionClient.ts b/clients/client-lookoutvision/LookoutVisionClient.ts new file mode 100644 index 000000000000..bbcacd77addd --- /dev/null +++ b/clients/client-lookoutvision/LookoutVisionClient.ts @@ -0,0 +1,258 @@ +import { CreateDatasetCommandInput, CreateDatasetCommandOutput } from "./commands/CreateDatasetCommand"; +import { CreateModelCommandInput, CreateModelCommandOutput } from "./commands/CreateModelCommand"; +import { CreateProjectCommandInput, CreateProjectCommandOutput } from "./commands/CreateProjectCommand"; +import { DeleteDatasetCommandInput, DeleteDatasetCommandOutput } from "./commands/DeleteDatasetCommand"; +import { DeleteModelCommandInput, DeleteModelCommandOutput } from "./commands/DeleteModelCommand"; +import { DeleteProjectCommandInput, DeleteProjectCommandOutput } from "./commands/DeleteProjectCommand"; +import { DescribeDatasetCommandInput, DescribeDatasetCommandOutput } from "./commands/DescribeDatasetCommand"; +import { DescribeModelCommandInput, DescribeModelCommandOutput } from "./commands/DescribeModelCommand"; +import { DescribeProjectCommandInput, DescribeProjectCommandOutput } from "./commands/DescribeProjectCommand"; +import { DetectAnomaliesCommandInput, DetectAnomaliesCommandOutput } from "./commands/DetectAnomaliesCommand"; +import { ListDatasetEntriesCommandInput, ListDatasetEntriesCommandOutput } from "./commands/ListDatasetEntriesCommand"; +import { ListModelsCommandInput, ListModelsCommandOutput } from "./commands/ListModelsCommand"; +import { ListProjectsCommandInput, ListProjectsCommandOutput } from "./commands/ListProjectsCommand"; +import { StartModelCommandInput, StartModelCommandOutput } from "./commands/StartModelCommand"; +import { StopModelCommandInput, StopModelCommandOutput } from "./commands/StopModelCommand"; +import { + UpdateDatasetEntriesCommandInput, + UpdateDatasetEntriesCommandOutput, +} from "./commands/UpdateDatasetEntriesCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = + | CreateDatasetCommandInput + | CreateModelCommandInput + | CreateProjectCommandInput + | DeleteDatasetCommandInput + | DeleteModelCommandInput + | DeleteProjectCommandInput + | DescribeDatasetCommandInput + | DescribeModelCommandInput + | DescribeProjectCommandInput + | DetectAnomaliesCommandInput + | ListDatasetEntriesCommandInput + | ListModelsCommandInput + | ListProjectsCommandInput + | StartModelCommandInput + | StopModelCommandInput + | UpdateDatasetEntriesCommandInput; + +export type ServiceOutputTypes = + | CreateDatasetCommandOutput + | CreateModelCommandOutput + | CreateProjectCommandOutput + | DeleteDatasetCommandOutput + | DeleteModelCommandOutput + | DeleteProjectCommandOutput + | DescribeDatasetCommandOutput + | DescribeModelCommandOutput + | DescribeProjectCommandOutput + | DetectAnomaliesCommandOutput + | ListDatasetEntriesCommandOutput + | ListModelsCommandOutput + | ListProjectsCommandOutput + | StartModelCommandOutput + | StopModelCommandOutput + | UpdateDatasetEntriesCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type LookoutVisionClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type LookoutVisionClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

        This is the Amazon Lookout for Vision API Reference. It provides descriptions of actions, + * data types, common parameters, and common errors.

        + *

        Amazon Lookout for Vision enables you to find visual defects in industrial products, + * accurately and at scale. It uses computer vision to identify missing components in an industrial product, + * damage to vehicles or structures, irregularities in production lines, and even minuscule defects in + * silicon wafers — or any other physical item where quality is important such as a missing capacitor + * on printed circuit boards.

        + */ +export class LookoutVisionClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + LookoutVisionClientResolvedConfig +> { + readonly config: LookoutVisionClientResolvedConfig; + + constructor(configuration: LookoutVisionClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-lookoutvision/README.md b/clients/client-lookoutvision/README.md new file mode 100644 index 000000000000..6dc81bd5c3e1 --- /dev/null +++ b/clients/client-lookoutvision/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-lookoutvision + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-lookoutvision/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-lookoutvision) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-lookoutvision.svg)](https://www.npmjs.com/package/@aws-sdk/client-lookoutvision) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-lookoutvision/commands/CreateDatasetCommand.ts b/clients/client-lookoutvision/commands/CreateDatasetCommand.ts new file mode 100644 index 000000000000..77e1a0c5742c --- /dev/null +++ b/clients/client-lookoutvision/commands/CreateDatasetCommand.ts @@ -0,0 +1,97 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { CreateDatasetRequest, CreateDatasetResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateDatasetCommand, + serializeAws_restJson1CreateDatasetCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateDatasetCommandInput = CreateDatasetRequest; +export type CreateDatasetCommandOutput = CreateDatasetResponse & __MetadataBearer; + +/** + *

        Creates a new dataset in an Amazon Lookout for Vision project. CreateDataset can create a + * training or a test dataset from a valid dataset source (DatasetSource).

        + *

        If you want a single dataset project, specify train for the value of + * DatasetType.

        + *

        To have a project with separate training and test datasets, call CreateDataset twice. + * On the first call, specify train for the value of + * DatasetType. On the second call, specify test for the value of + * DatasetType. + * + * of dataset with

        + */ +export class CreateDatasetCommand extends $Command< + CreateDatasetCommandInput, + CreateDatasetCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateDatasetCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "CreateDatasetCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateDatasetRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateDatasetResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateDatasetCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateDatasetCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateDatasetCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/CreateModelCommand.ts b/clients/client-lookoutvision/commands/CreateModelCommand.ts new file mode 100644 index 000000000000..f256ca1b26d1 --- /dev/null +++ b/clients/client-lookoutvision/commands/CreateModelCommand.ts @@ -0,0 +1,98 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { CreateModelRequest, CreateModelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateModelCommand, + serializeAws_restJson1CreateModelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateModelCommandInput = CreateModelRequest; +export type CreateModelCommandOutput = CreateModelResponse & __MetadataBearer; + +/** + *

        Creates a new version of a model within an an Amazon Lookout for Vision project. + * CreateModel is an asynchronous operation in which Amazon Lookout for Vision trains, tests, + * and evaluates a new version of a model.

        + *

        To get the current status, check the Status field returned + * in the response from DescribeModel.

        + *

        If the project has a single dataset, Amazon Lookout for Vision internally splits the dataset + * to create a training and a test dataset. + * If the project has a training and a test dataset, Lookout for Vision uses the respective datasets to train and test + * the model.

        + *

        After training completes, the evaluation metrics are stored at the location specified in + * OutputConfig.

        + */ +export class CreateModelCommand extends $Command< + CreateModelCommandInput, + CreateModelCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateModelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "CreateModelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateModelRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateModelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateModelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateModelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateModelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/CreateProjectCommand.ts b/clients/client-lookoutvision/commands/CreateProjectCommand.ts new file mode 100644 index 000000000000..e83a3bb6344a --- /dev/null +++ b/clients/client-lookoutvision/commands/CreateProjectCommand.ts @@ -0,0 +1,89 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { CreateProjectRequest, CreateProjectResponse } from "../models/models_0"; +import { + deserializeAws_restJson1CreateProjectCommand, + serializeAws_restJson1CreateProjectCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateProjectCommandInput = CreateProjectRequest; +export type CreateProjectCommandOutput = CreateProjectResponse & __MetadataBearer; + +/** + *

        Creates an empty Amazon Lookout for Vision project. After you create the project, add a dataset by calling + * CreateDataset.

        + */ +export class CreateProjectCommand extends $Command< + CreateProjectCommandInput, + CreateProjectCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "CreateProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateProjectRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateProjectResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1CreateProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1CreateProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DeleteDatasetCommand.ts b/clients/client-lookoutvision/commands/DeleteDatasetCommand.ts new file mode 100644 index 000000000000..b8193fec635c --- /dev/null +++ b/clients/client-lookoutvision/commands/DeleteDatasetCommand.ts @@ -0,0 +1,102 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DeleteDatasetRequest, DeleteDatasetResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteDatasetCommand, + serializeAws_restJson1DeleteDatasetCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteDatasetCommandInput = DeleteDatasetRequest; +export type DeleteDatasetCommandOutput = DeleteDatasetResponse & __MetadataBearer; + +/** + *

        Deletes an existing Amazon Lookout for Vision dataset.

        + *

        If your the project has a single + * dataset, you must create a new dataset before you can create a model.

        + *

        If you project has a training dataset and a test dataset consider the following.

        + *
          + *
        • + *

          If you delete the test dataset, your project reverts to a single dataset project. If you then + * train the model, Amazon Lookout for Vision internally splits the remaining dataset into a training and test dataset.

          + *
        • + *
        • + *

          If you delete the training dataset, you must create a training dataset before you can create a model.

          + *
        • + *
        + *

        It might take a while to delete the dataset. To check the current status, check the Status field + * in the response from a call to DescribeDataset.

        + */ +export class DeleteDatasetCommand extends $Command< + DeleteDatasetCommandInput, + DeleteDatasetCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteDatasetCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DeleteDatasetCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteDatasetRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteDatasetResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteDatasetCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteDatasetCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteDatasetCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DeleteModelCommand.ts b/clients/client-lookoutvision/commands/DeleteModelCommand.ts new file mode 100644 index 000000000000..1e4e5cb2c66c --- /dev/null +++ b/clients/client-lookoutvision/commands/DeleteModelCommand.ts @@ -0,0 +1,89 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DeleteModelRequest, DeleteModelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteModelCommand, + serializeAws_restJson1DeleteModelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteModelCommandInput = DeleteModelRequest; +export type DeleteModelCommandOutput = DeleteModelResponse & __MetadataBearer; + +/** + *

        Deletes an Amazon Lookout for Vision model. You can't delete a running model. To stop a running model, + * use the StopModel operation.

        + */ +export class DeleteModelCommand extends $Command< + DeleteModelCommandInput, + DeleteModelCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteModelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DeleteModelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteModelRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteModelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteModelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteModelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteModelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DeleteProjectCommand.ts b/clients/client-lookoutvision/commands/DeleteProjectCommand.ts new file mode 100644 index 000000000000..ffafae1a497c --- /dev/null +++ b/clients/client-lookoutvision/commands/DeleteProjectCommand.ts @@ -0,0 +1,92 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DeleteProjectRequest, DeleteProjectResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteProjectCommand, + serializeAws_restJson1DeleteProjectCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteProjectCommandInput = DeleteProjectRequest; +export type DeleteProjectCommandOutput = DeleteProjectResponse & __MetadataBearer; + +/** + *

        Deletes an Amazon Lookout for Vision project.

        + *

        To delete a project, you must first delete each version of the model associated with + * the project. To delete a model use the DeleteModel operation.

        + *

        The training and test datasets are deleted automatically for you. + * The images referenced by the training and test datasets aren't deleted.

        + */ +export class DeleteProjectCommand extends $Command< + DeleteProjectCommandInput, + DeleteProjectCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DeleteProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteProjectRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteProjectResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DescribeDatasetCommand.ts b/clients/client-lookoutvision/commands/DescribeDatasetCommand.ts new file mode 100644 index 000000000000..dd044d81d748 --- /dev/null +++ b/clients/client-lookoutvision/commands/DescribeDatasetCommand.ts @@ -0,0 +1,88 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DescribeDatasetRequest, DescribeDatasetResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeDatasetCommand, + serializeAws_restJson1DescribeDatasetCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeDatasetCommandInput = DescribeDatasetRequest; +export type DescribeDatasetCommandOutput = DescribeDatasetResponse & __MetadataBearer; + +/** + *

        Describe an Amazon Lookout for Vision dataset.

        + */ +export class DescribeDatasetCommand extends $Command< + DescribeDatasetCommandInput, + DescribeDatasetCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeDatasetCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DescribeDatasetCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeDatasetRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeDatasetResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeDatasetCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeDatasetCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeDatasetCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DescribeModelCommand.ts b/clients/client-lookoutvision/commands/DescribeModelCommand.ts new file mode 100644 index 000000000000..c834f9cfc2bf --- /dev/null +++ b/clients/client-lookoutvision/commands/DescribeModelCommand.ts @@ -0,0 +1,88 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DescribeModelRequest, DescribeModelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeModelCommand, + serializeAws_restJson1DescribeModelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeModelCommandInput = DescribeModelRequest; +export type DescribeModelCommandOutput = DescribeModelResponse & __MetadataBearer; + +/** + *

        Describes a version of an Amazon Lookout for Vision model.

        + */ +export class DescribeModelCommand extends $Command< + DescribeModelCommandInput, + DescribeModelCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeModelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DescribeModelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeModelRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeModelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeModelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeModelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeModelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DescribeProjectCommand.ts b/clients/client-lookoutvision/commands/DescribeProjectCommand.ts new file mode 100644 index 000000000000..964444954acc --- /dev/null +++ b/clients/client-lookoutvision/commands/DescribeProjectCommand.ts @@ -0,0 +1,88 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DescribeProjectRequest, DescribeProjectResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DescribeProjectCommand, + serializeAws_restJson1DescribeProjectCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeProjectCommandInput = DescribeProjectRequest; +export type DescribeProjectCommandOutput = DescribeProjectResponse & __MetadataBearer; + +/** + *

        Describes an Amazon Lookout for Vision project.

        + */ +export class DescribeProjectCommand extends $Command< + DescribeProjectCommandInput, + DescribeProjectCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DescribeProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeProjectRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeProjectResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DescribeProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DescribeProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/DetectAnomaliesCommand.ts b/clients/client-lookoutvision/commands/DetectAnomaliesCommand.ts new file mode 100644 index 000000000000..28dbe6d6b42c --- /dev/null +++ b/clients/client-lookoutvision/commands/DetectAnomaliesCommand.ts @@ -0,0 +1,97 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { DetectAnomaliesRequest, DetectAnomaliesResponse } from "../models/models_0"; +import { + deserializeAws_restJson1DetectAnomaliesCommand, + serializeAws_restJson1DetectAnomaliesCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DetectAnomaliesCommandInput = Omit & { + Body: DetectAnomaliesRequest["Body"] | string | Uint8Array | Buffer; +}; +export type DetectAnomaliesCommandOutput = DetectAnomaliesResponse & __MetadataBearer; + +/** + *

        Detects anomalies in an image that you supply.

        + *

        The response from DetectAnomalies includes a boolean prediction + * that the image contains one or more anomalies and a confidence value for the prediction.

        + * + *

        Before calling DetectAnomalies, you must first start your model with the StartModel operation. + * You are charged for the amount of time, in minutes, that a model runs and for the number of anomaly detection units that your + * model uses. If you are not using a model, use the StopModel operation to stop your model.

        + *
        + */ +export class DetectAnomaliesCommand extends $Command< + DetectAnomaliesCommandInput, + DetectAnomaliesCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DetectAnomaliesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "DetectAnomaliesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DetectAnomaliesRequest.filterSensitiveLog, + outputFilterSensitiveLog: DetectAnomaliesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DetectAnomaliesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DetectAnomaliesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DetectAnomaliesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/ListDatasetEntriesCommand.ts b/clients/client-lookoutvision/commands/ListDatasetEntriesCommand.ts new file mode 100644 index 000000000000..8bb8649afce7 --- /dev/null +++ b/clients/client-lookoutvision/commands/ListDatasetEntriesCommand.ts @@ -0,0 +1,89 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { ListDatasetEntriesRequest, ListDatasetEntriesResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListDatasetEntriesCommand, + serializeAws_restJson1ListDatasetEntriesCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListDatasetEntriesCommandInput = ListDatasetEntriesRequest; +export type ListDatasetEntriesCommandOutput = ListDatasetEntriesResponse & __MetadataBearer; + +/** + *

        Lists the JSON Lines within a dataset. An Amazon Lookout for Vision JSON Line contains the anomaly + * information for a single image, including the image location and the assigned label.

        + */ +export class ListDatasetEntriesCommand extends $Command< + ListDatasetEntriesCommandInput, + ListDatasetEntriesCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListDatasetEntriesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "ListDatasetEntriesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListDatasetEntriesRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListDatasetEntriesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListDatasetEntriesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListDatasetEntriesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListDatasetEntriesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/ListModelsCommand.ts b/clients/client-lookoutvision/commands/ListModelsCommand.ts new file mode 100644 index 000000000000..cfba3bee4113 --- /dev/null +++ b/clients/client-lookoutvision/commands/ListModelsCommand.ts @@ -0,0 +1,88 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { ListModelsRequest, ListModelsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListModelsCommand, + serializeAws_restJson1ListModelsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListModelsCommandInput = ListModelsRequest; +export type ListModelsCommandOutput = ListModelsResponse & __MetadataBearer; + +/** + *

        Lists the versions of a model in an Amazon Lookout for Vision project.

        + */ +export class ListModelsCommand extends $Command< + ListModelsCommandInput, + ListModelsCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListModelsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "ListModelsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListModelsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListModelsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListModelsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListModelsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListModelsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/ListProjectsCommand.ts b/clients/client-lookoutvision/commands/ListProjectsCommand.ts new file mode 100644 index 000000000000..aac0bd8bdbd3 --- /dev/null +++ b/clients/client-lookoutvision/commands/ListProjectsCommand.ts @@ -0,0 +1,88 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { ListProjectsRequest, ListProjectsResponse } from "../models/models_0"; +import { + deserializeAws_restJson1ListProjectsCommand, + serializeAws_restJson1ListProjectsCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListProjectsCommandInput = ListProjectsRequest; +export type ListProjectsCommandOutput = ListProjectsResponse & __MetadataBearer; + +/** + *

        Lists the Amazon Lookout for Vision projects in your AWS account.

        + */ +export class ListProjectsCommand extends $Command< + ListProjectsCommandInput, + ListProjectsCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListProjectsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "ListProjectsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListProjectsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListProjectsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListProjectsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1ListProjectsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1ListProjectsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/StartModelCommand.ts b/clients/client-lookoutvision/commands/StartModelCommand.ts new file mode 100644 index 000000000000..cbd8a58a4a23 --- /dev/null +++ b/clients/client-lookoutvision/commands/StartModelCommand.ts @@ -0,0 +1,95 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { StartModelRequest, StartModelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1StartModelCommand, + serializeAws_restJson1StartModelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StartModelCommandInput = StartModelRequest; +export type StartModelCommandOutput = StartModelResponse & __MetadataBearer; + +/** + *

        Starts the running of the version of an Amazon Lookout for Vision model. Starting a model takes a while + * to complete. To check the current state of the model, use DescribeModel.

        + *

        Once the model is running, you can detect custom labels in new images by calling + * DetectAnomalies.

        + * + *

        You are charged for the amount of time that the model is running. To stop a running + * model, call StopModel.

        + *
        + */ +export class StartModelCommand extends $Command< + StartModelCommandInput, + StartModelCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StartModelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "StartModelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StartModelRequest.filterSensitiveLog, + outputFilterSensitiveLog: StartModelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StartModelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1StartModelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1StartModelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/StopModelCommand.ts b/clients/client-lookoutvision/commands/StopModelCommand.ts new file mode 100644 index 000000000000..b8fe2255c6e1 --- /dev/null +++ b/clients/client-lookoutvision/commands/StopModelCommand.ts @@ -0,0 +1,89 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { StopModelRequest, StopModelResponse } from "../models/models_0"; +import { + deserializeAws_restJson1StopModelCommand, + serializeAws_restJson1StopModelCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StopModelCommandInput = StopModelRequest; +export type StopModelCommandOutput = StopModelResponse & __MetadataBearer; + +/** + *

        Stops a running model. The operation might take a while to complete. To + * check the current status, call DescribeModel.

        + */ +export class StopModelCommand extends $Command< + StopModelCommandInput, + StopModelCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StopModelCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "StopModelCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StopModelRequest.filterSensitiveLog, + outputFilterSensitiveLog: StopModelResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StopModelCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1StopModelCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1StopModelCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/commands/UpdateDatasetEntriesCommand.ts b/clients/client-lookoutvision/commands/UpdateDatasetEntriesCommand.ts new file mode 100644 index 000000000000..49f8cdc56889 --- /dev/null +++ b/clients/client-lookoutvision/commands/UpdateDatasetEntriesCommand.ts @@ -0,0 +1,93 @@ +import { LookoutVisionClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../LookoutVisionClient"; +import { UpdateDatasetEntriesRequest, UpdateDatasetEntriesResponse } from "../models/models_0"; +import { + deserializeAws_restJson1UpdateDatasetEntriesCommand, + serializeAws_restJson1UpdateDatasetEntriesCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateDatasetEntriesCommandInput = UpdateDatasetEntriesRequest; +export type UpdateDatasetEntriesCommandOutput = UpdateDatasetEntriesResponse & __MetadataBearer; + +/** + *

        Adds one or more JSON Line entries to a dataset. A JSON Line includes information about an image + * used for training or testing an Amazon Lookout for Vision model. The following is an example JSON Line.

        + * + * + *

        Updating a dataset might take a while to complete. To check the current status, call DescribeDataset and + * check the Status field in the response.

        + */ +export class UpdateDatasetEntriesCommand extends $Command< + UpdateDatasetEntriesCommandInput, + UpdateDatasetEntriesCommandOutput, + LookoutVisionClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateDatasetEntriesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: LookoutVisionClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "LookoutVisionClient"; + const commandName = "UpdateDatasetEntriesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateDatasetEntriesRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateDatasetEntriesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateDatasetEntriesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1UpdateDatasetEntriesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1UpdateDatasetEntriesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-lookoutvision/endpoints.ts b/clients/client-lookoutvision/endpoints.ts new file mode 100644 index 000000000000..725a833ac4dc --- /dev/null +++ b/clients/client-lookoutvision/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "lookoutvision.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "lookoutvision.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "lookoutvision.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "lookoutvision.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "lookoutvision.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-lookoutvision/index.ts b/clients/client-lookoutvision/index.ts new file mode 100644 index 000000000000..9f674be29071 --- /dev/null +++ b/clients/client-lookoutvision/index.ts @@ -0,0 +1,23 @@ +export * from "./LookoutVisionClient"; +export * from "./LookoutVision"; +export * from "./commands/CreateDatasetCommand"; +export * from "./commands/CreateModelCommand"; +export * from "./commands/CreateProjectCommand"; +export * from "./commands/DeleteDatasetCommand"; +export * from "./commands/DeleteModelCommand"; +export * from "./commands/DeleteProjectCommand"; +export * from "./commands/DescribeDatasetCommand"; +export * from "./commands/DescribeModelCommand"; +export * from "./commands/DescribeProjectCommand"; +export * from "./commands/DetectAnomaliesCommand"; +export * from "./commands/ListDatasetEntriesCommand"; +export * from "./pagination/ListDatasetEntriesPaginator"; +export * from "./commands/ListModelsCommand"; +export * from "./pagination/ListModelsPaginator"; +export * from "./commands/ListProjectsCommand"; +export * from "./pagination/ListProjectsPaginator"; +export * from "./commands/StartModelCommand"; +export * from "./commands/StopModelCommand"; +export * from "./commands/UpdateDatasetEntriesCommand"; +export * from "./pagination/Interfaces"; +export * from "./models/index"; diff --git a/clients/client-lookoutvision/models/index.ts b/clients/client-lookoutvision/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-lookoutvision/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-lookoutvision/models/models_0.ts b/clients/client-lookoutvision/models/models_0.ts new file mode 100644 index 000000000000..881e2a32b261 --- /dev/null +++ b/clients/client-lookoutvision/models/models_0.ts @@ -0,0 +1,1397 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; +import { Readable } from "stream"; + +/** + *

        You are not authorized to perform the action.

        + */ +export interface AccessDeniedException extends __SmithyException, $MetadataBearer { + name: "AccessDeniedException"; + $fault: "client"; + Message: string | undefined; +} + +export namespace AccessDeniedException { + export const filterSensitiveLog = (obj: AccessDeniedException): any => ({ + ...obj, + }); +} + +export enum ResourceType { + DATASET = "DATASET", + MODEL = "MODEL", + PROJECT = "PROJECT", + TRIAL = "TRIAL", +} + +/** + *

        The update or deletion of a resource caused an inconsistent state.

        + */ +export interface ConflictException extends __SmithyException, $MetadataBearer { + name: "ConflictException"; + $fault: "client"; + Message: string | undefined; + /** + *

        The ID of the resource.

        + */ + ResourceId: string | undefined; + + /** + *

        The type of the resource.

        + */ + ResourceType: ResourceType | string | undefined; +} + +export namespace ConflictException { + export const filterSensitiveLog = (obj: ConflictException): any => ({ + ...obj, + }); +} + +/** + *

        Amazon S3 Location information for an input manifest file.

        + */ +export interface InputS3Object { + /** + *

        The Amazon S3 bucket that contains the manifest.

        + */ + Bucket: string | undefined; + + /** + *

        The name and location of the manifest file withiin the bucket.

        + */ + Key: string | undefined; + + /** + *

        The version ID of the bucket.

        + */ + VersionId?: string; +} + +export namespace InputS3Object { + export const filterSensitiveLog = (obj: InputS3Object): any => ({ + ...obj, + }); +} + +/** + *

        Location information about a manifest file. You can use a manifest file to + * create a dataset.

        + */ +export interface DatasetGroundTruthManifest { + /** + *

        The S3 bucket location for the manifest file.

        + */ + S3Object?: InputS3Object; +} + +export namespace DatasetGroundTruthManifest { + export const filterSensitiveLog = (obj: DatasetGroundTruthManifest): any => ({ + ...obj, + }); +} + +/** + *

        Information about the location of a manifest file that Amazon Lookout for Vision uses to to create a dataset.

        + */ +export interface DatasetSource { + /** + *

        Location information for the manifest file.

        + */ + GroundTruthManifest?: DatasetGroundTruthManifest; +} + +export namespace DatasetSource { + export const filterSensitiveLog = (obj: DatasetSource): any => ({ + ...obj, + }); +} + +export interface CreateDatasetRequest { + /** + *

        The name of the project in which you want to create a dataset.

        + */ + ProjectName: string | undefined; + + /** + *

        The type of the dataset. Specify train for a training dataset. + * Specify test for a test dataset.

        + */ + DatasetType: string | undefined; + + /** + *

        The location of the manifest file that Amazon Lookout for Vision uses to create the dataset.

        + *

        If you don't specify DatasetSource, an empty dataset is created and the operation + * synchronously returns. Later, you can add JSON Lines by calling UpdateDatasetEntries. + *

        + *

        If you specify a value for DataSource, the manifest at the S3 location + * is validated and used to create the dataset. The call to CreateDataset is asynchronous + * and might take a while to complete. To find out the current status, Check the value of Status + * returned in a call to DescribeDataset.

        + */ + DatasetSource?: DatasetSource; + + /** + *

        ClientToken is an idempotency token that ensures a call to CreateDataset + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from CreateDataset. + * In this case, safely retry your call + * to CreateDataset by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to CreateDataset. An idempotency + * token is active for 8 hours. + *

        + */ + ClientToken?: string; +} + +export namespace CreateDatasetRequest { + export const filterSensitiveLog = (obj: CreateDatasetRequest): any => ({ + ...obj, + }); +} + +export enum DatasetStatus { + CREATE_COMPLETE = "CREATE_COMPLETE", + CREATE_FAILED = "CREATE_FAILED", + CREATE_IN_PROGRESS = "CREATE_IN_PROGRESS", + DELETE_COMPLETE = "DELETE_COMPLETE", + DELETE_FAILED = "DELETE_FAILED", + DELETE_IN_PROGRESS = "DELETE_IN_PROGRESS", + UPDATE_COMPLETE = "UPDATE_COMPLETE", + UPDATE_FAILED_ROLLBACK_COMPLETE = "UPDATE_FAILED_ROLLBACK_COMPLETE", + UPDATE_FAILED_ROLLBACK_IN_PROGRESS = "UPDATE_FAILED_ROLLBACK_IN_PROGRESS", + UPDATE_IN_PROGRESS = "UPDATE_IN_PROGRESS", +} + +/** + *

        Sumary information for an Amazon Lookout for Vision dataset.

        + */ +export interface DatasetMetadata { + /** + *

        The type of the dataset.

        + */ + DatasetType?: string; + + /** + *

        The Unix timestamp for the date and time that the dataset was created.

        + */ + CreationTimestamp?: Date; + + /** + *

        The status for the dataset.

        + */ + Status?: DatasetStatus | string; + + /** + *

        The status message for the dataset.

        + */ + StatusMessage?: string; +} + +export namespace DatasetMetadata { + export const filterSensitiveLog = (obj: DatasetMetadata): any => ({ + ...obj, + }); +} + +export interface CreateDatasetResponse { + /** + *

        Information about the dataset.

        + */ + DatasetMetadata?: DatasetMetadata; +} + +export namespace CreateDatasetResponse { + export const filterSensitiveLog = (obj: CreateDatasetResponse): any => ({ + ...obj, + }); +} + +/** + *

        Amazon Lookout for Vision experienced a service issue. Try your call again.

        + */ +export interface InternalServerException extends __SmithyException, $MetadataBearer { + name: "InternalServerException"; + $fault: "server"; + Message: string | undefined; + /** + *

        The period of time, in seconds, before the operation can be retried.

        + */ + RetryAfterSeconds?: number; +} + +export namespace InternalServerException { + export const filterSensitiveLog = (obj: InternalServerException): any => ({ + ...obj, + }); +} + +/** + *

        The resource could not be found.

        + */ +export interface ResourceNotFoundException extends __SmithyException, $MetadataBearer { + name: "ResourceNotFoundException"; + $fault: "client"; + Message: string | undefined; + /** + *

        The ID of the resource.

        + */ + ResourceId: string | undefined; + + /** + *

        The type of the resource.

        + */ + ResourceType: ResourceType | string | undefined; +} + +export namespace ResourceNotFoundException { + export const filterSensitiveLog = (obj: ResourceNotFoundException): any => ({ + ...obj, + }); +} + +/** + *

        A service quota was exceeded the allowed limit. For more information, see + * Limits in Amazon Lookout for Vision in the Amazon Lookout for Vision Developer Guide.

        + */ +export interface ServiceQuotaExceededException extends __SmithyException, $MetadataBearer { + name: "ServiceQuotaExceededException"; + $fault: "client"; + Message: string | undefined; + /** + *

        The ID of the resource.

        + */ + ResourceId?: string; + + /** + *

        The type of the resource.

        + */ + ResourceType?: ResourceType | string; + + /** + *

        The quota code.

        + */ + QuotaCode: string | undefined; + + /** + *

        The service code.

        + */ + ServiceCode: string | undefined; +} + +export namespace ServiceQuotaExceededException { + export const filterSensitiveLog = (obj: ServiceQuotaExceededException): any => ({ + ...obj, + }); +} + +/** + *

        Amazon Lookout for Vision is temporarily unable to process the request. Try your call again.

        + */ +export interface ThrottlingException extends __SmithyException, $MetadataBearer { + name: "ThrottlingException"; + $fault: "client"; + Message: string | undefined; + /** + *

        The quota code.

        + */ + QuotaCode?: string; + + /** + *

        The service code.

        + */ + ServiceCode?: string; + + /** + *

        The period of time, in seconds, before the operation can be retried.

        + */ + RetryAfterSeconds?: number; +} + +export namespace ThrottlingException { + export const filterSensitiveLog = (obj: ThrottlingException): any => ({ + ...obj, + }); +} + +/** + *

        An input validation error occured. For example, invalid characters in a project name, + * or if a pagination token is invalid.

        + */ +export interface ValidationException extends __SmithyException, $MetadataBearer { + name: "ValidationException"; + $fault: "client"; + Message: string | undefined; +} + +export namespace ValidationException { + export const filterSensitiveLog = (obj: ValidationException): any => ({ + ...obj, + }); +} + +/** + *

        The S3 location where Amazon Lookout for Vision saves training output.

        + */ +export interface OutputS3Object { + /** + *

        The bucket that contains the training output.

        + */ + Bucket: string | undefined; + + /** + *

        The location of the training output in the bucket.

        + */ + Key: string | undefined; +} + +export namespace OutputS3Object { + export const filterSensitiveLog = (obj: OutputS3Object): any => ({ + ...obj, + }); +} + +/** + *

        Information about the location of a manifest file.

        + */ +export interface S3Location { + /** + *

        The S3 bucket that contain the manifest file.

        + */ + Bucket: string | undefined; + + /** + *

        The path and name of the manifest file with the S3 bucket.

        + */ + Prefix?: string; +} + +export namespace S3Location { + export const filterSensitiveLog = (obj: S3Location): any => ({ + ...obj, + }); +} + +/** + *

        The S3 location where Amazon Lookout for Vision saves model training files.

        + */ +export interface OutputConfig { + /** + *

        The S3 location for the output.

        + */ + S3Location: S3Location | undefined; +} + +export namespace OutputConfig { + export const filterSensitiveLog = (obj: OutputConfig): any => ({ + ...obj, + }); +} + +/** + *

        Information about the evaluation performance of a trained model.

        + */ +export interface ModelPerformance { + /** + *

        The overall F1 score metric for the trained model.

        + */ + F1Score?: number; + + /** + *

        The overall recall metric value for the trained model.

        + */ + Recall?: number; + + /** + *

        The overall precision metric value for the trained model.

        + */ + Precision?: number; +} + +export namespace ModelPerformance { + export const filterSensitiveLog = (obj: ModelPerformance): any => ({ + ...obj, + }); +} + +export enum ModelStatus { + DELETING = "DELETING", + HOSTED = "HOSTED", + HOSTING_FAILED = "HOSTING_FAILED", + STARTING_HOSTING = "STARTING_HOSTING", + STOPPING_HOSTING = "STOPPING_HOSTING", + SYSTEM_UPDATING = "SYSTEM_UPDATING", + TRAINED = "TRAINED", + TRAINING = "TRAINING", + TRAINING_FAILED = "TRAINING_FAILED", +} + +/** + *

        Describes an Amazon Lookout for Vision model.

        + */ +export interface ModelDescription { + /** + *

        The version of the model

        + */ + ModelVersion?: string; + + /** + *

        The Amazon Resource Name (ARN) of the model.

        + */ + ModelArn?: string; + + /** + *

        The unix timestamp for the date and time that the model was created.

        + */ + CreationTimestamp?: Date; + + /** + *

        The description for the model.

        + */ + Description?: string; + + /** + *

        The status of the model.

        + */ + Status?: ModelStatus | string; + + /** + *

        The status message for the model.

        + */ + StatusMessage?: string; + + /** + *

        Performance metrics for the model. Created during training.

        + */ + Performance?: ModelPerformance; + + /** + *

        The S3 location where Amazon Lookout for Vision saves model training files.

        + */ + OutputConfig?: OutputConfig; + + /** + *

        The S3 location where Amazon Lookout for Vision saves the manifest file + * that was used to test the trained model and generate the performance scores.

        + */ + EvaluationManifest?: OutputS3Object; + + /** + *

        The S3 location where Amazon Lookout for Vision saves the performance metrics.

        + */ + EvaluationResult?: OutputS3Object; + + /** + *

        The unix timestamp for the date and time that the evaluation ended.

        + */ + EvaluationEndTimestamp?: Date; + + /** + *

        The identifer for the AWS Key Management Service (AWS KMS) key that was used to encrypt the model + * during training.

        + */ + KmsKeyId?: string; +} + +export namespace ModelDescription { + export const filterSensitiveLog = (obj: ModelDescription): any => ({ + ...obj, + }); +} + +export interface CreateModelRequest { + /** + *

        The name of the project in which you want to create a model version.

        + */ + ProjectName: string | undefined; + + /** + *

        A description for the version of the model.

        + */ + Description?: ModelDescription; + + /** + *

        ClientToken is an idempotency token that ensures a call to CreateModel + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from CreateModel. + * In this case, safely retry your call + * to CreateModel by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to CreateModel. An idempotency + * token is active for 8 hours.

        + */ + ClientToken?: string; + + /** + *

        The location where Amazon Lookout for Vision saves the training results.

        + */ + OutputConfig: OutputConfig | undefined; + + /** + *

        The identifier of the AWS Key Management Service (AWS KMS) customer master key (CMK) + * to use for encypting the model. If this parameter is not specified, the + * model is encrypted by a key that AWS owns and manages.

        + */ + KmsKeyId?: string; +} + +export namespace CreateModelRequest { + export const filterSensitiveLog = (obj: CreateModelRequest): any => ({ + ...obj, + }); +} + +/** + *

        Describes an Amazon Lookout for Vision model.

        + */ +export interface ModelMetadata { + /** + *

        The unix timestamp for the date and time that the model was created.

        + */ + CreationTimestamp?: Date; + + /** + *

        The version of the model.

        + */ + ModelVersion?: string; + + /** + *

        The Amazon Resource Name (ARN) of the model.

        + */ + ModelArn?: string; + + /** + *

        The description for the model.

        + */ + Description?: string; + + /** + *

        The status of the model.

        + */ + Status?: ModelStatus | string; + + /** + *

        The status message for the model.

        + */ + StatusMessage?: string; + + /** + *

        Performance metrics for the model. Created during training.

        + */ + Performance?: ModelPerformance; +} + +export namespace ModelMetadata { + export const filterSensitiveLog = (obj: ModelMetadata): any => ({ + ...obj, + }); +} + +export interface CreateModelResponse { + /** + *

        The response from a call to CreateModel.

        + */ + ModelMetadata?: ModelMetadata; +} + +export namespace CreateModelResponse { + export const filterSensitiveLog = (obj: CreateModelResponse): any => ({ + ...obj, + }); +} + +export interface CreateProjectRequest { + /** + *

        S nsme for the project.

        + */ + ProjectName: string | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to CreateProject + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from CreateProject. + * In this case, safely retry your call + * to CreateProject by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to CreateProject. An idempotency + * token is active for 8 hours.

        + */ + ClientToken?: string; +} + +export namespace CreateProjectRequest { + export const filterSensitiveLog = (obj: CreateProjectRequest): any => ({ + ...obj, + }); +} + +/** + *

        Metadata about an Amazon Lookout for Vision project.

        + */ +export interface ProjectMetadata { + /** + *

        The Amazon Resource Name (ARN) of the project.

        + */ + ProjectArn?: string; + + /** + *

        The name of the project.

        + */ + ProjectName?: string; + + /** + *

        The unix timestamp for the date and time that the project was created.

        + */ + CreationTimestamp?: Date; +} + +export namespace ProjectMetadata { + export const filterSensitiveLog = (obj: ProjectMetadata): any => ({ + ...obj, + }); +} + +export interface CreateProjectResponse { + /** + *

        Information about the project.

        + */ + ProjectMetadata?: ProjectMetadata; +} + +export namespace CreateProjectResponse { + export const filterSensitiveLog = (obj: CreateProjectResponse): any => ({ + ...obj, + }); +} + +/** + *

        Statistics about the images in a dataset.

        + */ +export interface DatasetImageStats { + /** + *

        The total number of images in the dataset.

        + */ + Total?: number; + + /** + *

        The total number of labeled images.

        + */ + Labeled?: number; + + /** + *

        The total number of images labeled as normal.

        + */ + Normal?: number; + + /** + *

        the total number of images labeled as an anomaly.

        + */ + Anomaly?: number; +} + +export namespace DatasetImageStats { + export const filterSensitiveLog = (obj: DatasetImageStats): any => ({ + ...obj, + }); +} + +/** + *

        The description for a dataset. For more information, see DescribeDataset.

        + */ +export interface DatasetDescription { + /** + *

        The name of the project that contains the dataset.

        + */ + ProjectName?: string; + + /** + *

        The type of the dataset. The value train represents a training dataset or single dataset project. + * The value test represents a test dataset.

        + */ + DatasetType?: string; + + /** + *

        The Unix timestamp for the time and date that the dataset was created.

        + */ + CreationTimestamp?: Date; + + /** + *

        The Unix timestamp for the date and time that the dataset was last updated.

        + */ + LastUpdatedTimestamp?: Date; + + /** + *

        The status of the dataset.

        + */ + Status?: DatasetStatus | string; + + /** + *

        The status message for the dataset.

        + */ + StatusMessage?: string; + + /** + *

        + */ + ImageStats?: DatasetImageStats; +} + +export namespace DatasetDescription { + export const filterSensitiveLog = (obj: DatasetDescription): any => ({ + ...obj, + }); +} + +export interface DeleteDatasetRequest { + /** + *

        The name of the project that contains the dataset that you want to delete.

        + */ + ProjectName: string | undefined; + + /** + *

        The type of the dataset to delete. Specify train to delete the training dataset. + * Specify test to delete the test dataset. To delete the dataset in a single dataset project, + * specify train.

        + */ + DatasetType: string | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to DeleteDataset + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from DeleteDataset. + * In this case, safely retry your call + * to DeleteDataset by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to DeleteDataset. An idempotency + * token is active for 8 hours.

        + */ + ClientToken?: string; +} + +export namespace DeleteDatasetRequest { + export const filterSensitiveLog = (obj: DeleteDatasetRequest): any => ({ + ...obj, + }); +} + +export interface DeleteDatasetResponse {} + +export namespace DeleteDatasetResponse { + export const filterSensitiveLog = (obj: DeleteDatasetResponse): any => ({ + ...obj, + }); +} + +export interface DeleteModelRequest { + /** + *

        The name of the project that contains the model that you want to delete.

        + */ + ProjectName: string | undefined; + + /** + *

        The version of the model that you want to delete.

        + */ + ModelVersion: string | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to DeleteModel + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from DeleteModel. + * In this case, safely retry your call + * to DeleteModel by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to DeleteModel. An idempotency + * token is active for 8 hours.

        + */ + ClientToken?: string; +} + +export namespace DeleteModelRequest { + export const filterSensitiveLog = (obj: DeleteModelRequest): any => ({ + ...obj, + }); +} + +export interface DeleteModelResponse { + /** + *

        The Amazon Resource Name (ARN) of the model that was deleted.

        + */ + ModelArn?: string; +} + +export namespace DeleteModelResponse { + export const filterSensitiveLog = (obj: DeleteModelResponse): any => ({ + ...obj, + }); +} + +export interface DeleteProjectRequest { + /** + *

        The name of the project to delete.

        + */ + ProjectName: string | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to DeleteProject + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from DeleteProject. + * In this case, safely retry your call + * to DeleteProject by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to DeleteProject. An idempotency + * token is active for 8 hours.

        + */ + ClientToken?: string; +} + +export namespace DeleteProjectRequest { + export const filterSensitiveLog = (obj: DeleteProjectRequest): any => ({ + ...obj, + }); +} + +export interface DeleteProjectResponse { + /** + *

        The Amazon Resource Name (ARN) of the project that was deleted.

        + */ + ProjectArn?: string; +} + +export namespace DeleteProjectResponse { + export const filterSensitiveLog = (obj: DeleteProjectResponse): any => ({ + ...obj, + }); +} + +export interface DescribeDatasetRequest { + /** + *

        The name of the project that contains the dataset that you want to describe.

        + */ + ProjectName: string | undefined; + + /** + *

        The type of the dataset to describe. Specify train to describe the + * training dataset. Specify test to describe the test dataset. + * If you have a single dataset project, specify train + *

        + */ + DatasetType: string | undefined; +} + +export namespace DescribeDatasetRequest { + export const filterSensitiveLog = (obj: DescribeDatasetRequest): any => ({ + ...obj, + }); +} + +export interface DescribeDatasetResponse { + /** + *

        The description of the requested dataset.

        + */ + DatasetDescription?: DatasetDescription; +} + +export namespace DescribeDatasetResponse { + export const filterSensitiveLog = (obj: DescribeDatasetResponse): any => ({ + ...obj, + }); +} + +export interface DescribeModelRequest { + /** + *

        The project that contains the version of a model that you want to describe.

        + */ + ProjectName: string | undefined; + + /** + *

        The version of the model that you want to describe.

        + */ + ModelVersion: string | undefined; +} + +export namespace DescribeModelRequest { + export const filterSensitiveLog = (obj: DescribeModelRequest): any => ({ + ...obj, + }); +} + +export interface DescribeModelResponse { + /** + *

        Contains the description of the model.

        + */ + ModelDescription?: ModelDescription; +} + +export namespace DescribeModelResponse { + export const filterSensitiveLog = (obj: DescribeModelResponse): any => ({ + ...obj, + }); +} + +export interface DescribeProjectRequest { + /** + *

        The name of the project that you want to describe.

        + */ + ProjectName: string | undefined; +} + +export namespace DescribeProjectRequest { + export const filterSensitiveLog = (obj: DescribeProjectRequest): any => ({ + ...obj, + }); +} + +/** + *

        Describe an Amazon Lookout for Vision project. For more information, see DescribeProject.

        + */ +export interface ProjectDescription { + /** + *

        The Amazon Resource Name (ARN) of the project.

        + */ + ProjectArn?: string; + + /** + *

        The name of the project.

        + */ + ProjectName?: string; + + /** + *

        The unix timestamp for the date and time that the project was created.

        + */ + CreationTimestamp?: Date; + + /** + *

        A list of datasets in the project.

        + */ + Datasets?: DatasetMetadata[]; +} + +export namespace ProjectDescription { + export const filterSensitiveLog = (obj: ProjectDescription): any => ({ + ...obj, + }); +} + +export interface DescribeProjectResponse { + /** + *

        The description of the project.

        + */ + ProjectDescription?: ProjectDescription; +} + +export namespace DescribeProjectResponse { + export const filterSensitiveLog = (obj: DescribeProjectResponse): any => ({ + ...obj, + }); +} + +export interface DetectAnomaliesRequest { + /** + *

        The name of the project that contains the model version that you want to use.

        + */ + ProjectName: string | undefined; + + /** + *

        The version of the model that you want to use.

        + */ + ModelVersion: string | undefined; + + /** + *

        The unencrypted image bytes that you want to analyze.

        + */ + Body: Readable | ReadableStream | Blob | undefined; + + /** + *

        The type of the image passed in Body. + * Valid values are image/png (PNG format images) and image/jpeg (JPG format images).

        + */ + ContentType: string | undefined; +} + +export namespace DetectAnomaliesRequest { + export const filterSensitiveLog = (obj: DetectAnomaliesRequest): any => ({ + ...obj, + }); +} + +/** + *

        The source for an image.

        + */ +export interface ImageSource { + /** + *

        The type of the image.

        + */ + Type?: string; +} + +export namespace ImageSource { + export const filterSensitiveLog = (obj: ImageSource): any => ({ + ...obj, + }); +} + +/** + *

        The prediction results from a call to DetectAnomalies.

        + */ +export interface DetectAnomalyResult { + /** + *

        The source of the image that was analyzed. direct means that the + * images was supplied from the local computer. No other values are supported.

        + */ + Source?: ImageSource; + + /** + *

        True if the image contains an anomaly, otherwise false.

        + */ + IsAnomalous?: boolean; + + /** + *

        The confidence that Amazon Lookout for Vision has in the accuracy of the prediction.

        + */ + Confidence?: number; +} + +export namespace DetectAnomalyResult { + export const filterSensitiveLog = (obj: DetectAnomalyResult): any => ({ + ...obj, + }); +} + +export interface DetectAnomaliesResponse { + /** + *

        The results of the DetectAnomalies operation.

        + */ + DetectAnomalyResult?: DetectAnomalyResult; +} + +export namespace DetectAnomaliesResponse { + export const filterSensitiveLog = (obj: DetectAnomaliesResponse): any => ({ + ...obj, + }); +} + +export interface ListDatasetEntriesRequest { + /** + *

        The name of the project that contains the dataset that you want to list.

        + */ + ProjectName: string | undefined; + + /** + *

        The type of the dataset that you want to list. Specify train to list + * the training dataset. Specify test to list the test dataset. If you have a single dataset + * project, specify train.

        + */ + DatasetType: string | undefined; + + /** + *

        Specify true to include labeled entries, otherwise specify false. If you + * don't specify a value, Lookout for Vision returns all entries.

        + */ + Labeled?: boolean; + + /** + *

        Specify normal to include only normal images. Specify anomaly to only include + * anomalous entries. If you don't specify a value, Amazon Lookout for Vision returns normal and anomalous images.

        + */ + AnomalyClass?: string; + + /** + *

        Only includes entries before the specified date in the response. For example, 2020-06-23T00:00:00.

        + */ + BeforeCreationDate?: Date; + + /** + *

        Only includes entries after the specified date in the response. For example, 2020-06-23T00:00:00.

        + */ + AfterCreationDate?: Date; + + /** + *

        If the previous response was incomplete (because there is more data to retrieve), + * Amazon Lookout for Vision returns a pagination token in the response. You can use this pagination token to + * retrieve the next set of dataset entries.

        + */ + NextToken?: string; + + /** + *

        The maximum number of results to return per paginated call. The largest value you can specify is 100. + * If you specify a value greater than 100, a ValidationException + * error occurs. The default value is 100.

        + */ + MaxResults?: number; + + /** + *

        Perform a "contains" search on the values of the source-ref key within the dataset. + * For example a value of "IMG_17" returns all JSON Lines where the source-ref key value matches *IMG_17*.

        + */ + SourceRefContains?: string; +} + +export namespace ListDatasetEntriesRequest { + export const filterSensitiveLog = (obj: ListDatasetEntriesRequest): any => ({ + ...obj, + }); +} + +export interface ListDatasetEntriesResponse { + /** + *

        A list of the entries (JSON Lines) within the dataset.

        + */ + DatasetEntries?: string[]; + + /** + *

        If the response is truncated, Amazon Lookout for Vision returns this token + * that you can use in the subsequent request to retrieve the next set ofdataset entries.

        + */ + NextToken?: string; +} + +export namespace ListDatasetEntriesResponse { + export const filterSensitiveLog = (obj: ListDatasetEntriesResponse): any => ({ + ...obj, + }); +} + +export interface ListModelsRequest { + /** + *

        The name of the project that contains the model versions that you want to list.

        + */ + ProjectName: string | undefined; + + /** + *

        If the previous response was incomplete (because there is more data to retrieve), + * Amazon Lookout for Vision returns a pagination token in the response. You can use this pagination token to + * retrieve the next set of models.

        + */ + NextToken?: string; + + /** + *

        The maximum number of results to return per paginated call. The largest value you can specify is 100. + * If you specify a value greater than 100, a ValidationException + * error occurs. The default value is 100.

        + */ + MaxResults?: number; +} + +export namespace ListModelsRequest { + export const filterSensitiveLog = (obj: ListModelsRequest): any => ({ + ...obj, + }); +} + +export interface ListModelsResponse { + /** + *

        A list of model versions in the specified project.

        + */ + Models?: ModelMetadata[]; + + /** + *

        If the response is truncated, Amazon Lookout for Vision returns this token + * that you can use in the subsequent request to retrieve the next set of models.

        + */ + NextToken?: string; +} + +export namespace ListModelsResponse { + export const filterSensitiveLog = (obj: ListModelsResponse): any => ({ + ...obj, + }); +} + +export interface ListProjectsRequest { + /** + *

        If the previous response was incomplete (because there is more data to retrieve), + * Amazon Lookout for Vision returns a pagination token in the response. You can use this pagination token to + * retrieve the next set of projects.

        + */ + NextToken?: string; + + /** + *

        The maximum number of results to return per paginated call. The largest value you can specify is 100. + * If you specify a value greater than 100, a ValidationException + * error occurs. The default value is 100.

        + */ + MaxResults?: number; +} + +export namespace ListProjectsRequest { + export const filterSensitiveLog = (obj: ListProjectsRequest): any => ({ + ...obj, + }); +} + +export interface ListProjectsResponse { + /** + *

        A list of projects in your AWS account.

        + */ + Projects?: ProjectMetadata[]; + + /** + *

        If the response is truncated, Amazon Lookout for Vision returns this token + * that you can use in the subsequent request to retrieve the next set of projects.

        + */ + NextToken?: string; +} + +export namespace ListProjectsResponse { + export const filterSensitiveLog = (obj: ListProjectsResponse): any => ({ + ...obj, + }); +} + +export interface StartModelRequest { + /** + *

        The name of the project that contains the model that you want to start.

        + */ + ProjectName: string | undefined; + + /** + *

        The version of the model that you want to start.

        + */ + ModelVersion: string | undefined; + + /** + *

        The minimum number of inference units to use. A single + * inference unit represents 1 hour of processing and can support up to 5 Transaction Pers Second (TPS). + * Use a higher number to increase the TPS throughput of your model. You are charged for the number + * of inference units that you use. + *

        + */ + MinInferenceUnits: number | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to StartModel + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from StartModel. + * In this case, safely retry your call + * to StartModel by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to StartModel. An idempotency + * token is active for 8 hours. + *

        + */ + ClientToken?: string; +} + +export namespace StartModelRequest { + export const filterSensitiveLog = (obj: StartModelRequest): any => ({ + ...obj, + }); +} + +export enum ModelHostingStatus { + FAILED = "FAILED", + RUNNING = "RUNNING", + STARTING = "STARTING", + STOPPED = "STOPPED", +} + +export interface StartModelResponse { + /** + *

        The current running status of the model.

        + */ + Status?: ModelHostingStatus | string; +} + +export namespace StartModelResponse { + export const filterSensitiveLog = (obj: StartModelResponse): any => ({ + ...obj, + }); +} + +export interface StopModelRequest { + /** + *

        The name of the project that contains the model that you want to stop.

        + */ + ProjectName: string | undefined; + + /** + *

        The version of the model that you want to stop.

        + */ + ModelVersion: string | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to StopModel + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from StopModel. + * In this case, safely retry your call + * to StopModel by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to StopModel. An idempotency + * token is active for 8 hours. + * + * + *

        + */ + ClientToken?: string; +} + +export namespace StopModelRequest { + export const filterSensitiveLog = (obj: StopModelRequest): any => ({ + ...obj, + }); +} + +export interface StopModelResponse { + /** + *

        The status of the model.

        + */ + Status?: ModelHostingStatus | string; +} + +export namespace StopModelResponse { + export const filterSensitiveLog = (obj: StopModelResponse): any => ({ + ...obj, + }); +} + +export interface UpdateDatasetEntriesRequest { + /** + *

        The name of the project that contains the dataset that you want to update.

        + */ + ProjectName: string | undefined; + + /** + *

        The type of the dataset that you want to update. Specify train to update + * the training dataset. Specify test to update the test dataset. If you + * have a single dataset project, specify train.

        + */ + DatasetType: string | undefined; + + /** + *

        The entries to add to the dataset.

        + */ + Changes: Uint8Array | undefined; + + /** + *

        ClientToken is an idempotency token that ensures a call to UpdateDatasetEntries + * completes only once. You choose the value to pass. For example, An issue, + * such as an network outage, might prevent you from getting a response from UpdateDatasetEntries. + * In this case, safely retry your call + * to UpdateDatasetEntries by using the same ClientToken parameter value. An error occurs + * if the other input parameters are not the same as in the first request. Using a different + * value for ClientToken is considered a new call to UpdateDatasetEntries. An idempotency + * token is active for 8 hours. + *

        + */ + ClientToken?: string; +} + +export namespace UpdateDatasetEntriesRequest { + export const filterSensitiveLog = (obj: UpdateDatasetEntriesRequest): any => ({ + ...obj, + }); +} + +export interface UpdateDatasetEntriesResponse { + /** + *

        The status of the dataset update.

        + */ + Status?: DatasetStatus | string; +} + +export namespace UpdateDatasetEntriesResponse { + export const filterSensitiveLog = (obj: UpdateDatasetEntriesResponse): any => ({ + ...obj, + }); +} diff --git a/clients/client-lookoutvision/package.json b/clients/client-lookoutvision/package.json new file mode 100644 index 000000000000..af823f93d766 --- /dev/null +++ b/clients/client-lookoutvision/package.json @@ -0,0 +1,85 @@ +{ + "name": "@aws-sdk/client-lookoutvision", + "description": "AWS SDK for JavaScript Lookoutvision Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0", + "uuid": "^3.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "@types/uuid": "^3.0.0", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-lookoutvision", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-lookoutvision" + } +} diff --git a/clients/client-lookoutvision/pagination/Interfaces.ts b/clients/client-lookoutvision/pagination/Interfaces.ts new file mode 100644 index 000000000000..8860cab55270 --- /dev/null +++ b/clients/client-lookoutvision/pagination/Interfaces.ts @@ -0,0 +1,7 @@ +import { LookoutVision } from "../LookoutVision"; +import { LookoutVisionClient } from "../LookoutVisionClient"; +import { PaginationConfiguration } from "@aws-sdk/types"; + +export interface LookoutVisionPaginationConfiguration extends PaginationConfiguration { + client: LookoutVision | LookoutVisionClient; +} diff --git a/clients/client-lookoutvision/pagination/ListDatasetEntriesPaginator.ts b/clients/client-lookoutvision/pagination/ListDatasetEntriesPaginator.ts new file mode 100644 index 000000000000..8fef2021922a --- /dev/null +++ b/clients/client-lookoutvision/pagination/ListDatasetEntriesPaginator.ts @@ -0,0 +1,57 @@ +import { LookoutVision } from "../LookoutVision"; +import { LookoutVisionClient } from "../LookoutVisionClient"; +import { + ListDatasetEntriesCommand, + ListDatasetEntriesCommandInput, + ListDatasetEntriesCommandOutput, +} from "../commands/ListDatasetEntriesCommand"; +import { LookoutVisionPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: LookoutVisionClient, + input: ListDatasetEntriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListDatasetEntriesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: LookoutVision, + input: ListDatasetEntriesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listDatasetEntries(input, ...args); +}; +export async function* paginateListDatasetEntries( + config: LookoutVisionPaginationConfiguration, + input: ListDatasetEntriesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListDatasetEntriesCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof LookoutVision) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof LookoutVisionClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected LookoutVision | LookoutVisionClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-lookoutvision/pagination/ListModelsPaginator.ts b/clients/client-lookoutvision/pagination/ListModelsPaginator.ts new file mode 100644 index 000000000000..9115f754b0b1 --- /dev/null +++ b/clients/client-lookoutvision/pagination/ListModelsPaginator.ts @@ -0,0 +1,53 @@ +import { LookoutVision } from "../LookoutVision"; +import { LookoutVisionClient } from "../LookoutVisionClient"; +import { ListModelsCommand, ListModelsCommandInput, ListModelsCommandOutput } from "../commands/ListModelsCommand"; +import { LookoutVisionPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: LookoutVisionClient, + input: ListModelsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListModelsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: LookoutVision, + input: ListModelsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listModels(input, ...args); +}; +export async function* paginateListModels( + config: LookoutVisionPaginationConfiguration, + input: ListModelsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListModelsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof LookoutVision) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof LookoutVisionClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected LookoutVision | LookoutVisionClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-lookoutvision/pagination/ListProjectsPaginator.ts b/clients/client-lookoutvision/pagination/ListProjectsPaginator.ts new file mode 100644 index 000000000000..8b4831b6369e --- /dev/null +++ b/clients/client-lookoutvision/pagination/ListProjectsPaginator.ts @@ -0,0 +1,57 @@ +import { LookoutVision } from "../LookoutVision"; +import { LookoutVisionClient } from "../LookoutVisionClient"; +import { + ListProjectsCommand, + ListProjectsCommandInput, + ListProjectsCommandOutput, +} from "../commands/ListProjectsCommand"; +import { LookoutVisionPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: LookoutVisionClient, + input: ListProjectsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListProjectsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: LookoutVision, + input: ListProjectsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listProjects(input, ...args); +}; +export async function* paginateListProjects( + config: LookoutVisionPaginationConfiguration, + input: ListProjectsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListProjectsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof LookoutVision) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof LookoutVisionClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected LookoutVision | LookoutVisionClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-lookoutvision/protocols/Aws_restJson1.ts b/clients/client-lookoutvision/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..af3955e2855b --- /dev/null +++ b/clients/client-lookoutvision/protocols/Aws_restJson1.ts @@ -0,0 +1,2723 @@ +import { CreateDatasetCommandInput, CreateDatasetCommandOutput } from "../commands/CreateDatasetCommand"; +import { CreateModelCommandInput, CreateModelCommandOutput } from "../commands/CreateModelCommand"; +import { CreateProjectCommandInput, CreateProjectCommandOutput } from "../commands/CreateProjectCommand"; +import { DeleteDatasetCommandInput, DeleteDatasetCommandOutput } from "../commands/DeleteDatasetCommand"; +import { DeleteModelCommandInput, DeleteModelCommandOutput } from "../commands/DeleteModelCommand"; +import { DeleteProjectCommandInput, DeleteProjectCommandOutput } from "../commands/DeleteProjectCommand"; +import { DescribeDatasetCommandInput, DescribeDatasetCommandOutput } from "../commands/DescribeDatasetCommand"; +import { DescribeModelCommandInput, DescribeModelCommandOutput } from "../commands/DescribeModelCommand"; +import { DescribeProjectCommandInput, DescribeProjectCommandOutput } from "../commands/DescribeProjectCommand"; +import { DetectAnomaliesCommandInput, DetectAnomaliesCommandOutput } from "../commands/DetectAnomaliesCommand"; +import { ListDatasetEntriesCommandInput, ListDatasetEntriesCommandOutput } from "../commands/ListDatasetEntriesCommand"; +import { ListModelsCommandInput, ListModelsCommandOutput } from "../commands/ListModelsCommand"; +import { ListProjectsCommandInput, ListProjectsCommandOutput } from "../commands/ListProjectsCommand"; +import { StartModelCommandInput, StartModelCommandOutput } from "../commands/StartModelCommand"; +import { StopModelCommandInput, StopModelCommandOutput } from "../commands/StopModelCommand"; +import { + UpdateDatasetEntriesCommandInput, + UpdateDatasetEntriesCommandOutput, +} from "../commands/UpdateDatasetEntriesCommand"; +import { + AccessDeniedException, + ConflictException, + DatasetDescription, + DatasetGroundTruthManifest, + DatasetImageStats, + DatasetMetadata, + DatasetSource, + DetectAnomalyResult, + ImageSource, + InputS3Object, + InternalServerException, + ModelDescription, + ModelMetadata, + ModelPerformance, + OutputConfig, + OutputS3Object, + ProjectDescription, + ProjectMetadata, + ResourceNotFoundException, + S3Location, + ServiceQuotaExceededException, + ThrottlingException, + ValidationException, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { + SmithyException as __SmithyException, + extendedEncodeURIComponent as __extendedEncodeURIComponent, +} from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; +import { v4 as generateIdempotencyToken } from "uuid"; + +export const serializeAws_restJson1CreateDatasetCommand = async ( + input: CreateDatasetCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/datasets"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + let body: any; + body = JSON.stringify({ + ...(input.DatasetSource !== undefined && { + DatasetSource: serializeAws_restJson1DatasetSource(input.DatasetSource, context), + }), + ...(input.DatasetType !== undefined && { DatasetType: input.DatasetType }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateModelCommand = async ( + input: CreateModelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + let body: any; + body = JSON.stringify({ + ...(input.Description !== undefined && { + Description: serializeAws_restJson1ModelDescription(input.Description, context), + }), + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + ...(input.OutputConfig !== undefined && { + OutputConfig: serializeAws_restJson1OutputConfig(input.OutputConfig, context), + }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1CreateProjectCommand = async ( + input: CreateProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects"; + let body: any; + body = JSON.stringify({ + ...(input.ProjectName !== undefined && { ProjectName: input.ProjectName }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteDatasetCommand = async ( + input: DeleteDatasetCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/datasets/{DatasetType}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.DatasetType !== undefined) { + const labelValue: string = input.DatasetType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: DatasetType."); + } + resolvedPath = resolvedPath.replace("{DatasetType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: DatasetType."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteModelCommand = async ( + input: DeleteModelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models/{ModelVersion}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.ModelVersion !== undefined) { + const labelValue: string = input.ModelVersion; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ModelVersion."); + } + resolvedPath = resolvedPath.replace("{ModelVersion}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ModelVersion."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DeleteProjectCommand = async ( + input: DeleteProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeDatasetCommand = async ( + input: DescribeDatasetCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/datasets/{DatasetType}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.DatasetType !== undefined) { + const labelValue: string = input.DatasetType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: DatasetType."); + } + resolvedPath = resolvedPath.replace("{DatasetType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: DatasetType."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeModelCommand = async ( + input: DescribeModelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models/{ModelVersion}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.ModelVersion !== undefined) { + const labelValue: string = input.ModelVersion; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ModelVersion."); + } + resolvedPath = resolvedPath.replace("{ModelVersion}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ModelVersion."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DescribeProjectCommand = async ( + input: DescribeProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1DetectAnomaliesCommand = async ( + input: DetectAnomaliesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/octet-stream", + ...(isSerializableHeaderValue(input.ContentType) && { "content-type": input.ContentType! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models/{ModelVersion}/detect"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.ModelVersion !== undefined) { + const labelValue: string = input.ModelVersion; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ModelVersion."); + } + resolvedPath = resolvedPath.replace("{ModelVersion}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ModelVersion."); + } + let body: any; + if (input.Body !== undefined) { + body = input.Body; + } + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1ListDatasetEntriesCommand = async ( + input: ListDatasetEntriesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/datasets/{DatasetType}/entries"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.DatasetType !== undefined) { + const labelValue: string = input.DatasetType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: DatasetType."); + } + resolvedPath = resolvedPath.replace("{DatasetType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: DatasetType."); + } + const query: any = { + ...(input.Labeled !== undefined && { labeled: input.Labeled.toString() }), + ...(input.AnomalyClass !== undefined && { anomalyClass: input.AnomalyClass }), + ...(input.BeforeCreationDate !== undefined && { + createdBefore: (input.BeforeCreationDate.toISOString().split(".")[0] + "Z").toString(), + }), + ...(input.AfterCreationDate !== undefined && { + createdAfter: (input.AfterCreationDate.toISOString().split(".")[0] + "Z").toString(), + }), + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + ...(input.SourceRefContains !== undefined && { sourceRefContains: input.SourceRefContains }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListModelsCommand = async ( + input: ListModelsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1ListProjectsCommand = async ( + input: ListProjectsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/2020-11-20/projects"; + const query: any = { + ...(input.NextToken !== undefined && { nextToken: input.NextToken }), + ...(input.MaxResults !== undefined && { maxResults: input.MaxResults.toString() }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1StartModelCommand = async ( + input: StartModelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models/{ModelVersion}/start"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.ModelVersion !== undefined) { + const labelValue: string = input.ModelVersion; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ModelVersion."); + } + resolvedPath = resolvedPath.replace("{ModelVersion}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ModelVersion."); + } + let body: any; + body = JSON.stringify({ + ...(input.MinInferenceUnits !== undefined && { MinInferenceUnits: input.MinInferenceUnits }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1StopModelCommand = async ( + input: StopModelCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/models/{ModelVersion}/stop"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.ModelVersion !== undefined) { + const labelValue: string = input.ModelVersion; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ModelVersion."); + } + resolvedPath = resolvedPath.replace("{ModelVersion}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ModelVersion."); + } + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "POST", + headers, + path: resolvedPath, + body, + }); +}; + +export const serializeAws_restJson1UpdateDatasetEntriesCommand = async ( + input: UpdateDatasetEntriesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + ...(isSerializableHeaderValue(input.ClientToken) && { "X-Amzn-Client-Token": input.ClientToken! }), + }; + let resolvedPath = "/2020-11-20/projects/{ProjectName}/datasets/{DatasetType}/entries"; + if (input.ProjectName !== undefined) { + const labelValue: string = input.ProjectName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: ProjectName."); + } + resolvedPath = resolvedPath.replace("{ProjectName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: ProjectName."); + } + if (input.DatasetType !== undefined) { + const labelValue: string = input.DatasetType; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: DatasetType."); + } + resolvedPath = resolvedPath.replace("{DatasetType}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: DatasetType."); + } + let body: any; + body = JSON.stringify({ + ...(input.Changes !== undefined && { Changes: context.base64Encoder(input.Changes) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PATCH", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1CreateDatasetCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateDatasetCommandError(output, context); + } + const contents: CreateDatasetCommandOutput = { + $metadata: deserializeMetadata(output), + DatasetMetadata: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.DatasetMetadata !== undefined && data.DatasetMetadata !== null) { + contents.DatasetMetadata = deserializeAws_restJson1DatasetMetadata(data.DatasetMetadata, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateDatasetCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.lookoutvision#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateModelCommandError(output, context); + } + const contents: CreateModelCommandOutput = { + $metadata: deserializeMetadata(output), + ModelMetadata: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ModelMetadata !== undefined && data.ModelMetadata !== null) { + contents.ModelMetadata = deserializeAws_restJson1ModelMetadata(data.ModelMetadata, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.lookoutvision#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1CreateProjectCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1CreateProjectCommandError(output, context); + } + const contents: CreateProjectCommandOutput = { + $metadata: deserializeMetadata(output), + ProjectMetadata: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ProjectMetadata !== undefined && data.ProjectMetadata !== null) { + contents.ProjectMetadata = deserializeAws_restJson1ProjectMetadata(data.ProjectMetadata, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1CreateProjectCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.lookoutvision#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteDatasetCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteDatasetCommandError(output, context); + } + const contents: DeleteDatasetCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteDatasetCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteModelCommandError(output, context); + } + const contents: DeleteModelCommandOutput = { + $metadata: deserializeMetadata(output), + ModelArn: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ModelArn !== undefined && data.ModelArn !== null) { + contents.ModelArn = data.ModelArn; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DeleteProjectCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteProjectCommandError(output, context); + } + const contents: DeleteProjectCommandOutput = { + $metadata: deserializeMetadata(output), + ProjectArn: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ProjectArn !== undefined && data.ProjectArn !== null) { + contents.ProjectArn = data.ProjectArn; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteProjectCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeDatasetCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeDatasetCommandError(output, context); + } + const contents: DescribeDatasetCommandOutput = { + $metadata: deserializeMetadata(output), + DatasetDescription: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.DatasetDescription !== undefined && data.DatasetDescription !== null) { + contents.DatasetDescription = deserializeAws_restJson1DatasetDescription(data.DatasetDescription, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeDatasetCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeModelCommandError(output, context); + } + const contents: DescribeModelCommandOutput = { + $metadata: deserializeMetadata(output), + ModelDescription: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ModelDescription !== undefined && data.ModelDescription !== null) { + contents.ModelDescription = deserializeAws_restJson1ModelDescription(data.ModelDescription, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DescribeProjectCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DescribeProjectCommandError(output, context); + } + const contents: DescribeProjectCommandOutput = { + $metadata: deserializeMetadata(output), + ProjectDescription: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.ProjectDescription !== undefined && data.ProjectDescription !== null) { + contents.ProjectDescription = deserializeAws_restJson1ProjectDescription(data.ProjectDescription, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DescribeProjectCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1DetectAnomaliesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DetectAnomaliesCommandError(output, context); + } + const contents: DetectAnomaliesCommandOutput = { + $metadata: deserializeMetadata(output), + DetectAnomalyResult: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.DetectAnomalyResult !== undefined && data.DetectAnomalyResult !== null) { + contents.DetectAnomalyResult = deserializeAws_restJson1DetectAnomalyResult(data.DetectAnomalyResult, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DetectAnomaliesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListDatasetEntriesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListDatasetEntriesCommandError(output, context); + } + const contents: ListDatasetEntriesCommandOutput = { + $metadata: deserializeMetadata(output), + DatasetEntries: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.DatasetEntries !== undefined && data.DatasetEntries !== null) { + contents.DatasetEntries = deserializeAws_restJson1DatasetEntryList(data.DatasetEntries, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListDatasetEntriesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListModelsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListModelsCommandError(output, context); + } + const contents: ListModelsCommandOutput = { + $metadata: deserializeMetadata(output), + Models: undefined, + NextToken: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Models !== undefined && data.Models !== null) { + contents.Models = deserializeAws_restJson1ModelMetadataList(data.Models, context); + } + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListModelsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1ListProjectsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1ListProjectsCommandError(output, context); + } + const contents: ListProjectsCommandOutput = { + $metadata: deserializeMetadata(output), + NextToken: undefined, + Projects: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.NextToken !== undefined && data.NextToken !== null) { + contents.NextToken = data.NextToken; + } + if (data.Projects !== undefined && data.Projects !== null) { + contents.Projects = deserializeAws_restJson1ProjectMetadataList(data.Projects, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1ListProjectsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1StartModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1StartModelCommandError(output, context); + } + const contents: StartModelCommandOutput = { + $metadata: deserializeMetadata(output), + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Status !== undefined && data.Status !== null) { + contents.Status = data.Status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1StartModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceQuotaExceededException": + case "com.amazonaws.lookoutvision#ServiceQuotaExceededException": + response = { + ...(await deserializeAws_restJson1ServiceQuotaExceededExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1StopModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1StopModelCommandError(output, context); + } + const contents: StopModelCommandOutput = { + $metadata: deserializeMetadata(output), + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Status !== undefined && data.Status !== null) { + contents.Status = data.Status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1StopModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1UpdateDatasetEntriesCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 202 && output.statusCode >= 300) { + return deserializeAws_restJson1UpdateDatasetEntriesCommandError(output, context); + } + const contents: UpdateDatasetEntriesCommandOutput = { + $metadata: deserializeMetadata(output), + Status: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Status !== undefined && data.Status !== null) { + contents.Status = data.Status; + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1UpdateDatasetEntriesCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessDeniedException": + case "com.amazonaws.lookoutvision#AccessDeniedException": + response = { + ...(await deserializeAws_restJson1AccessDeniedExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ConflictException": + case "com.amazonaws.lookoutvision#ConflictException": + response = { + ...(await deserializeAws_restJson1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalServerException": + case "com.amazonaws.lookoutvision#InternalServerException": + response = { + ...(await deserializeAws_restJson1InternalServerExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFoundException": + case "com.amazonaws.lookoutvision#ResourceNotFoundException": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ThrottlingException": + case "com.amazonaws.lookoutvision#ThrottlingException": + response = { + ...(await deserializeAws_restJson1ThrottlingExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationException": + case "com.amazonaws.lookoutvision#ValidationException": + response = { + ...(await deserializeAws_restJson1ValidationExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1AccessDeniedExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: AccessDeniedException = { + name: "AccessDeniedException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ConflictExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ConflictException = { + name: "ConflictException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + ResourceId: undefined, + ResourceType: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.ResourceId !== undefined && data.ResourceId !== null) { + contents.ResourceId = data.ResourceId; + } + if (data.ResourceType !== undefined && data.ResourceType !== null) { + contents.ResourceType = data.ResourceType; + } + return contents; +}; + +const deserializeAws_restJson1InternalServerExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InternalServerException = { + name: "InternalServerException", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + RetryAfterSeconds: undefined, + }; + if (parsedOutput.headers["retry-after"] !== undefined) { + contents.RetryAfterSeconds = parseInt(parsedOutput.headers["retry-after"], 10); + } + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceNotFoundExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceNotFoundException = { + name: "ResourceNotFoundException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + ResourceId: undefined, + ResourceType: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.ResourceId !== undefined && data.ResourceId !== null) { + contents.ResourceId = data.ResourceId; + } + if (data.ResourceType !== undefined && data.ResourceType !== null) { + contents.ResourceType = data.ResourceType; + } + return contents; +}; + +const deserializeAws_restJson1ServiceQuotaExceededExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ServiceQuotaExceededException = { + name: "ServiceQuotaExceededException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + QuotaCode: undefined, + ResourceId: undefined, + ResourceType: undefined, + ServiceCode: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.QuotaCode !== undefined && data.QuotaCode !== null) { + contents.QuotaCode = data.QuotaCode; + } + if (data.ResourceId !== undefined && data.ResourceId !== null) { + contents.ResourceId = data.ResourceId; + } + if (data.ResourceType !== undefined && data.ResourceType !== null) { + contents.ResourceType = data.ResourceType; + } + if (data.ServiceCode !== undefined && data.ServiceCode !== null) { + contents.ServiceCode = data.ServiceCode; + } + return contents; +}; + +const deserializeAws_restJson1ThrottlingExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ThrottlingException = { + name: "ThrottlingException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + QuotaCode: undefined, + RetryAfterSeconds: undefined, + ServiceCode: undefined, + }; + if (parsedOutput.headers["retry-after"] !== undefined) { + contents.RetryAfterSeconds = parseInt(parsedOutput.headers["retry-after"], 10); + } + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + if (data.QuotaCode !== undefined && data.QuotaCode !== null) { + contents.QuotaCode = data.QuotaCode; + } + if (data.ServiceCode !== undefined && data.ServiceCode !== null) { + contents.ServiceCode = data.ServiceCode; + } + return contents; +}; + +const deserializeAws_restJson1ValidationExceptionResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ValidationException = { + name: "ValidationException", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const serializeAws_restJson1DatasetGroundTruthManifest = ( + input: DatasetGroundTruthManifest, + context: __SerdeContext +): any => { + return { + ...(input.S3Object !== undefined && { S3Object: serializeAws_restJson1InputS3Object(input.S3Object, context) }), + }; +}; + +const serializeAws_restJson1DatasetSource = (input: DatasetSource, context: __SerdeContext): any => { + return { + ...(input.GroundTruthManifest !== undefined && { + GroundTruthManifest: serializeAws_restJson1DatasetGroundTruthManifest(input.GroundTruthManifest, context), + }), + }; +}; + +const serializeAws_restJson1InputS3Object = (input: InputS3Object, context: __SerdeContext): any => { + return { + ...(input.Bucket !== undefined && { Bucket: input.Bucket }), + ...(input.Key !== undefined && { Key: input.Key }), + ...(input.VersionId !== undefined && { VersionId: input.VersionId }), + }; +}; + +const serializeAws_restJson1ModelDescription = (input: ModelDescription, context: __SerdeContext): any => { + return { + ...(input.CreationTimestamp !== undefined && { + CreationTimestamp: Math.round(input.CreationTimestamp.getTime() / 1000), + }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.EvaluationEndTimestamp !== undefined && { + EvaluationEndTimestamp: Math.round(input.EvaluationEndTimestamp.getTime() / 1000), + }), + ...(input.EvaluationManifest !== undefined && { + EvaluationManifest: serializeAws_restJson1OutputS3Object(input.EvaluationManifest, context), + }), + ...(input.EvaluationResult !== undefined && { + EvaluationResult: serializeAws_restJson1OutputS3Object(input.EvaluationResult, context), + }), + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + ...(input.ModelArn !== undefined && { ModelArn: input.ModelArn }), + ...(input.ModelVersion !== undefined && { ModelVersion: input.ModelVersion }), + ...(input.OutputConfig !== undefined && { + OutputConfig: serializeAws_restJson1OutputConfig(input.OutputConfig, context), + }), + ...(input.Performance !== undefined && { + Performance: serializeAws_restJson1ModelPerformance(input.Performance, context), + }), + ...(input.Status !== undefined && { Status: input.Status }), + ...(input.StatusMessage !== undefined && { StatusMessage: input.StatusMessage }), + }; +}; + +const serializeAws_restJson1ModelPerformance = (input: ModelPerformance, context: __SerdeContext): any => { + return { + ...(input.F1Score !== undefined && { F1Score: input.F1Score }), + ...(input.Precision !== undefined && { Precision: input.Precision }), + ...(input.Recall !== undefined && { Recall: input.Recall }), + }; +}; + +const serializeAws_restJson1OutputConfig = (input: OutputConfig, context: __SerdeContext): any => { + return { + ...(input.S3Location !== undefined && { S3Location: serializeAws_restJson1S3Location(input.S3Location, context) }), + }; +}; + +const serializeAws_restJson1OutputS3Object = (input: OutputS3Object, context: __SerdeContext): any => { + return { + ...(input.Bucket !== undefined && { Bucket: input.Bucket }), + ...(input.Key !== undefined && { Key: input.Key }), + }; +}; + +const serializeAws_restJson1S3Location = (input: S3Location, context: __SerdeContext): any => { + return { + ...(input.Bucket !== undefined && { Bucket: input.Bucket }), + ...(input.Prefix !== undefined && { Prefix: input.Prefix }), + }; +}; + +const deserializeAws_restJson1DatasetDescription = (output: any, context: __SerdeContext): DatasetDescription => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + DatasetType: output.DatasetType !== undefined && output.DatasetType !== null ? output.DatasetType : undefined, + ImageStats: + output.ImageStats !== undefined && output.ImageStats !== null + ? deserializeAws_restJson1DatasetImageStats(output.ImageStats, context) + : undefined, + LastUpdatedTimestamp: + output.LastUpdatedTimestamp !== undefined && output.LastUpdatedTimestamp !== null + ? new Date(Math.round(output.LastUpdatedTimestamp * 1000)) + : undefined, + ProjectName: output.ProjectName !== undefined && output.ProjectName !== null ? output.ProjectName : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + StatusMessage: + output.StatusMessage !== undefined && output.StatusMessage !== null ? output.StatusMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1DatasetEntryList = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_restJson1DatasetImageStats = (output: any, context: __SerdeContext): DatasetImageStats => { + return { + Anomaly: output.Anomaly !== undefined && output.Anomaly !== null ? output.Anomaly : undefined, + Labeled: output.Labeled !== undefined && output.Labeled !== null ? output.Labeled : undefined, + Normal: output.Normal !== undefined && output.Normal !== null ? output.Normal : undefined, + Total: output.Total !== undefined && output.Total !== null ? output.Total : undefined, + } as any; +}; + +const deserializeAws_restJson1DatasetMetadata = (output: any, context: __SerdeContext): DatasetMetadata => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + DatasetType: output.DatasetType !== undefined && output.DatasetType !== null ? output.DatasetType : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + StatusMessage: + output.StatusMessage !== undefined && output.StatusMessage !== null ? output.StatusMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1DatasetMetadataList = (output: any, context: __SerdeContext): DatasetMetadata[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1DatasetMetadata(entry, context)); +}; + +const deserializeAws_restJson1DetectAnomalyResult = (output: any, context: __SerdeContext): DetectAnomalyResult => { + return { + Confidence: output.Confidence !== undefined && output.Confidence !== null ? output.Confidence : undefined, + IsAnomalous: output.IsAnomalous !== undefined && output.IsAnomalous !== null ? output.IsAnomalous : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_restJson1ImageSource(output.Source, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1ImageSource = (output: any, context: __SerdeContext): ImageSource => { + return { + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + } as any; +}; + +const deserializeAws_restJson1ModelDescription = (output: any, context: __SerdeContext): ModelDescription => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + EvaluationEndTimestamp: + output.EvaluationEndTimestamp !== undefined && output.EvaluationEndTimestamp !== null + ? new Date(Math.round(output.EvaluationEndTimestamp * 1000)) + : undefined, + EvaluationManifest: + output.EvaluationManifest !== undefined && output.EvaluationManifest !== null + ? deserializeAws_restJson1OutputS3Object(output.EvaluationManifest, context) + : undefined, + EvaluationResult: + output.EvaluationResult !== undefined && output.EvaluationResult !== null + ? deserializeAws_restJson1OutputS3Object(output.EvaluationResult, context) + : undefined, + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + ModelArn: output.ModelArn !== undefined && output.ModelArn !== null ? output.ModelArn : undefined, + ModelVersion: output.ModelVersion !== undefined && output.ModelVersion !== null ? output.ModelVersion : undefined, + OutputConfig: + output.OutputConfig !== undefined && output.OutputConfig !== null + ? deserializeAws_restJson1OutputConfig(output.OutputConfig, context) + : undefined, + Performance: + output.Performance !== undefined && output.Performance !== null + ? deserializeAws_restJson1ModelPerformance(output.Performance, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + StatusMessage: + output.StatusMessage !== undefined && output.StatusMessage !== null ? output.StatusMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1ModelMetadata = (output: any, context: __SerdeContext): ModelMetadata => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + ModelArn: output.ModelArn !== undefined && output.ModelArn !== null ? output.ModelArn : undefined, + ModelVersion: output.ModelVersion !== undefined && output.ModelVersion !== null ? output.ModelVersion : undefined, + Performance: + output.Performance !== undefined && output.Performance !== null + ? deserializeAws_restJson1ModelPerformance(output.Performance, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + StatusMessage: + output.StatusMessage !== undefined && output.StatusMessage !== null ? output.StatusMessage : undefined, + } as any; +}; + +const deserializeAws_restJson1ModelMetadataList = (output: any, context: __SerdeContext): ModelMetadata[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ModelMetadata(entry, context)); +}; + +const deserializeAws_restJson1ModelPerformance = (output: any, context: __SerdeContext): ModelPerformance => { + return { + F1Score: output.F1Score !== undefined && output.F1Score !== null ? output.F1Score : undefined, + Precision: output.Precision !== undefined && output.Precision !== null ? output.Precision : undefined, + Recall: output.Recall !== undefined && output.Recall !== null ? output.Recall : undefined, + } as any; +}; + +const deserializeAws_restJson1OutputConfig = (output: any, context: __SerdeContext): OutputConfig => { + return { + S3Location: + output.S3Location !== undefined && output.S3Location !== null + ? deserializeAws_restJson1S3Location(output.S3Location, context) + : undefined, + } as any; +}; + +const deserializeAws_restJson1OutputS3Object = (output: any, context: __SerdeContext): OutputS3Object => { + return { + Bucket: output.Bucket !== undefined && output.Bucket !== null ? output.Bucket : undefined, + Key: output.Key !== undefined && output.Key !== null ? output.Key : undefined, + } as any; +}; + +const deserializeAws_restJson1ProjectDescription = (output: any, context: __SerdeContext): ProjectDescription => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + Datasets: + output.Datasets !== undefined && output.Datasets !== null + ? deserializeAws_restJson1DatasetMetadataList(output.Datasets, context) + : undefined, + ProjectArn: output.ProjectArn !== undefined && output.ProjectArn !== null ? output.ProjectArn : undefined, + ProjectName: output.ProjectName !== undefined && output.ProjectName !== null ? output.ProjectName : undefined, + } as any; +}; + +const deserializeAws_restJson1ProjectMetadata = (output: any, context: __SerdeContext): ProjectMetadata => { + return { + CreationTimestamp: + output.CreationTimestamp !== undefined && output.CreationTimestamp !== null + ? new Date(Math.round(output.CreationTimestamp * 1000)) + : undefined, + ProjectArn: output.ProjectArn !== undefined && output.ProjectArn !== null ? output.ProjectArn : undefined, + ProjectName: output.ProjectName !== undefined && output.ProjectName !== null ? output.ProjectName : undefined, + } as any; +}; + +const deserializeAws_restJson1ProjectMetadataList = (output: any, context: __SerdeContext): ProjectMetadata[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1ProjectMetadata(entry, context)); +}; + +const deserializeAws_restJson1S3Location = (output: any, context: __SerdeContext): S3Location => { + return { + Bucket: output.Bucket !== undefined && output.Bucket !== null ? output.Bucket : undefined, + Prefix: output.Prefix !== undefined && output.Prefix !== null ? output.Prefix : undefined, + } as any; +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-lookoutvision/runtimeConfig.browser.ts b/clients/client-lookoutvision/runtimeConfig.browser.ts new file mode 100644 index 000000000000..174f22a943bb --- /dev/null +++ b/clients/client-lookoutvision/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./LookoutVisionClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-lookoutvision/runtimeConfig.native.ts b/clients/client-lookoutvision/runtimeConfig.native.ts new file mode 100644 index 000000000000..9c425471e054 --- /dev/null +++ b/clients/client-lookoutvision/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./LookoutVisionClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-lookoutvision/runtimeConfig.shared.ts b/clients/client-lookoutvision/runtimeConfig.shared.ts new file mode 100644 index 000000000000..30843d427c0d --- /dev/null +++ b/clients/client-lookoutvision/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-11-20", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "lookoutvision", +}; diff --git a/clients/client-lookoutvision/runtimeConfig.ts b/clients/client-lookoutvision/runtimeConfig.ts new file mode 100644 index 000000000000..9ebb374218c6 --- /dev/null +++ b/clients/client-lookoutvision/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./LookoutVisionClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-lookoutvision/tsconfig.es.json b/clients/client-lookoutvision/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-lookoutvision/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-lookoutvision/tsconfig.json b/clients/client-lookoutvision/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-lookoutvision/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-s3/S3.ts b/clients/client-s3/S3.ts index 7c281b3c64b8..770af387eeda 100644 --- a/clients/client-s3/S3.ts +++ b/clients/client-s3/S3.ts @@ -748,19 +748,12 @@ export class S3 extends S3Client { * x-amz-copy-source, must be signed.

        * *

        - * Encryption + * Server-side encryption *

        - *

        The source object that you are copying can be encrypted or unencrypted. The source - * object can be encrypted with server-side encryption using AWS managed encryption keys - * (SSE-S3 or SSE-KMS) or by using a customer-provided encryption key. With server-side - * encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and - * decrypts the data when you access it.

        - *

        You can optionally use the appropriate encryption-related headers to request server-side - * encryption for the target object. You have the option to provide your own encryption key or - * use SSE-S3 or SSE-KMS, regardless of the form of server-side encryption that was used to - * encrypt the source object. You can even request encryption if the source object was not - * encrypted. For more information about server-side encryption, see Using - * Server-Side Encryption.

        + *

        When you perform a CopyObject operation, you can optionally use the appropriate encryption-related headers to encrypt the object using server-side encryption with AWS managed encryption keys (SSE-S3 or SSE-KMS) or a customer-provided encryption key. With server-side encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and decrypts the data when you access it. For more information about server-side encryption, see Using + * Server-Side Encryption.

        + *

        If a target object uses SSE-KMS, you can enable an S3 Bucket Key for the object. For more + * information, see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        *

        * Access Control List (ACL)-Specific Request * Headers @@ -5266,13 +5259,14 @@ export class S3 extends S3Client { } /** - *

        This implementation of the PUT operation uses the encryption - * subresource to set the default encryption state of an existing bucket.

        - *

        This implementation of the PUT operation sets default encryption for a - * bucket using server-side encryption with Amazon S3-managed keys SSE-S3 or AWS KMS customer - * master keys (CMKs) (SSE-KMS). For information about the Amazon S3 default encryption feature, - * see Amazon S3 Default Bucket - * Encryption.

        + *

        This operation uses the encryption subresource to configure default + * encryption and Amazon S3 Bucket Key for an existing bucket.

        + *

        Default encryption for a bucket can use server-side encryption with Amazon S3-managed keys + * (SSE-S3) or AWS KMS customer master keys (SSE-KMS). If you specify default encryption + * using SSE-KMS, you can also configure Amazon S3 Bucket Key. For information about default + * encryption, see Amazon S3 default bucket encryption + * in the Amazon Simple Storage Service Developer Guide. For more information about S3 Bucket Keys, + * see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        * *

        This operation requires AWS Signature Version 4. For more information, see Authenticating Requests (AWS Signature * Version 4).

        @@ -6052,15 +6046,15 @@ export class S3 extends S3Client { * iam:PassRole permission.

        * *

        Specify the replication configuration in the request body. In the replication - * configuration, you provide the name of the destination bucket where you want Amazon S3 to - * replicate objects, the IAM role that Amazon S3 can assume to replicate objects on your behalf, - * and other relevant information.

        + * configuration, you provide the name of the destination bucket or buckets where you want + * Amazon S3 to replicate objects, the IAM role that Amazon S3 can assume to replicate objects on your + * behalf, and other relevant information.

        * * *

        A replication configuration must include at least one rule, and can contain a maximum of * 1,000. Each rule identifies a subset of objects to replicate by filtering the objects in * the source bucket. To choose additional subsets of objects to replicate, add a rule for - * each subset. All rules must specify the same destination bucket.

        + * each subset.

        * *

        To specify a subset of the objects in the source bucket to apply a replication rule to, * add the Filter element as a child of the Rule element. You can filter objects based on an @@ -6564,11 +6558,11 @@ export class S3 extends S3Client { *

        * Server-side Encryption *

        - *

        You can optionally request server-side encryption. With server-side encryption, Amazon S3 - * encrypts your data as it writes it to disks in its data centers and decrypts the data when - * you access it. You have the option to provide your own encryption key or use AWS managed - * encryption keys. For more information, see Using Server-Side - * Encryption.

        + *

        You can optionally request server-side encryption. With server-side encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and decrypts the data + * when you access it. You have the option to provide your own encryption key or use AWS + * managed encryption keys (SSE-S3 or SSE-KMS). For more information, see Using Server-Side + * Encryption.

        + *

        If you request server-side encryption using AWS Key Management Service (SSE-KMS), you can enable an S3 Bucket Key at the object-level. For more information, see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        *

        * Access Control List (ACL)-Specific Request * Headers diff --git a/clients/client-s3/commands/CopyObjectCommand.ts b/clients/client-s3/commands/CopyObjectCommand.ts index 78e2e9c84e97..8083154d9755 100644 --- a/clients/client-s3/commands/CopyObjectCommand.ts +++ b/clients/client-s3/commands/CopyObjectCommand.ts @@ -136,19 +136,12 @@ export type CopyObjectCommandOutput = CopyObjectOutput & __MetadataBearer; * x-amz-copy-source, must be signed.

        * *

        - * Encryption + * Server-side encryption *

        - *

        The source object that you are copying can be encrypted or unencrypted. The source - * object can be encrypted with server-side encryption using AWS managed encryption keys - * (SSE-S3 or SSE-KMS) or by using a customer-provided encryption key. With server-side - * encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and - * decrypts the data when you access it.

        - *

        You can optionally use the appropriate encryption-related headers to request server-side - * encryption for the target object. You have the option to provide your own encryption key or - * use SSE-S3 or SSE-KMS, regardless of the form of server-side encryption that was used to - * encrypt the source object. You can even request encryption if the source object was not - * encrypted. For more information about server-side encryption, see Using - * Server-Side Encryption.

        + *

        When you perform a CopyObject operation, you can optionally use the appropriate encryption-related headers to encrypt the object using server-side encryption with AWS managed encryption keys (SSE-S3 or SSE-KMS) or a customer-provided encryption key. With server-side encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and decrypts the data when you access it. For more information about server-side encryption, see Using + * Server-Side Encryption.

        + *

        If a target object uses SSE-KMS, you can enable an S3 Bucket Key for the object. For more + * information, see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        *

        * Access Control List (ACL)-Specific Request * Headers diff --git a/clients/client-s3/commands/PutBucketEncryptionCommand.ts b/clients/client-s3/commands/PutBucketEncryptionCommand.ts index e82b890158ab..8ba914907706 100644 --- a/clients/client-s3/commands/PutBucketEncryptionCommand.ts +++ b/clients/client-s3/commands/PutBucketEncryptionCommand.ts @@ -22,13 +22,14 @@ export type PutBucketEncryptionCommandInput = PutBucketEncryptionRequest; export type PutBucketEncryptionCommandOutput = __MetadataBearer; /** - *

        This implementation of the PUT operation uses the encryption - * subresource to set the default encryption state of an existing bucket.

        - *

        This implementation of the PUT operation sets default encryption for a - * bucket using server-side encryption with Amazon S3-managed keys SSE-S3 or AWS KMS customer - * master keys (CMKs) (SSE-KMS). For information about the Amazon S3 default encryption feature, - * see Amazon S3 Default Bucket - * Encryption.

        + *

        This operation uses the encryption subresource to configure default + * encryption and Amazon S3 Bucket Key for an existing bucket.

        + *

        Default encryption for a bucket can use server-side encryption with Amazon S3-managed keys + * (SSE-S3) or AWS KMS customer master keys (SSE-KMS). If you specify default encryption + * using SSE-KMS, you can also configure Amazon S3 Bucket Key. For information about default + * encryption, see Amazon S3 default bucket encryption + * in the Amazon Simple Storage Service Developer Guide. For more information about S3 Bucket Keys, + * see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        * *

        This operation requires AWS Signature Version 4. For more information, see Authenticating Requests (AWS Signature * Version 4).

        diff --git a/clients/client-s3/commands/PutBucketReplicationCommand.ts b/clients/client-s3/commands/PutBucketReplicationCommand.ts index fbf8ae746c89..2282ae32db7c 100644 --- a/clients/client-s3/commands/PutBucketReplicationCommand.ts +++ b/clients/client-s3/commands/PutBucketReplicationCommand.ts @@ -30,15 +30,15 @@ export type PutBucketReplicationCommandOutput = __MetadataBearer; * iam:PassRole permission.

        * *

        Specify the replication configuration in the request body. In the replication - * configuration, you provide the name of the destination bucket where you want Amazon S3 to - * replicate objects, the IAM role that Amazon S3 can assume to replicate objects on your behalf, - * and other relevant information.

        + * configuration, you provide the name of the destination bucket or buckets where you want + * Amazon S3 to replicate objects, the IAM role that Amazon S3 can assume to replicate objects on your + * behalf, and other relevant information.

        * * *

        A replication configuration must include at least one rule, and can contain a maximum of * 1,000. Each rule identifies a subset of objects to replicate by filtering the objects in * the source bucket. To choose additional subsets of objects to replicate, add a rule for - * each subset. All rules must specify the same destination bucket.

        + * each subset.

        * *

        To specify a subset of the objects in the source bucket to apply a replication rule to, * add the Filter element as a child of the Rule element. You can filter objects based on an diff --git a/clients/client-s3/commands/PutObjectCommand.ts b/clients/client-s3/commands/PutObjectCommand.ts index e8378fb26881..c92b272df119 100644 --- a/clients/client-s3/commands/PutObjectCommand.ts +++ b/clients/client-s3/commands/PutObjectCommand.ts @@ -50,11 +50,11 @@ export type PutObjectCommandOutput = PutObjectOutput & __MetadataBearer; *

        * Server-side Encryption *

        - *

        You can optionally request server-side encryption. With server-side encryption, Amazon S3 - * encrypts your data as it writes it to disks in its data centers and decrypts the data when - * you access it. You have the option to provide your own encryption key or use AWS managed - * encryption keys. For more information, see Using Server-Side - * Encryption.

        + *

        You can optionally request server-side encryption. With server-side encryption, Amazon S3 encrypts your data as it writes it to disks in its data centers and decrypts the data + * when you access it. You have the option to provide your own encryption key or use AWS + * managed encryption keys (SSE-S3 or SSE-KMS). For more information, see Using Server-Side + * Encryption.

        + *

        If you request server-side encryption using AWS Key Management Service (SSE-KMS), you can enable an S3 Bucket Key at the object-level. For more information, see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        *

        * Access Control List (ACL)-Specific Request * Headers diff --git a/clients/client-s3/models/models_0.ts b/clients/client-s3/models/models_0.ts index a0507f4021b8..3649ab82bfc5 100644 --- a/clients/client-s3/models/models_0.ts +++ b/clients/client-s3/models/models_0.ts @@ -320,6 +320,11 @@ export interface CompleteMultipartUploadOutput { */ SSEKMSKeyId?: string; + /** + *

        Indicates whether the multipart upload uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

        + */ + BucketKeyEnabled?: boolean; + /** *

        If present, indicates that the requester was successfully charged for the * request.

        @@ -489,6 +494,11 @@ export interface CopyObjectOutput { */ SSEKMSEncryptionContext?: string; + /** + *

        Indicates whether the copied object uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

        + */ + BucketKeyEnabled?: boolean; + /** *

        If present, indicates that the requester was successfully charged for the * request.

        @@ -735,6 +745,12 @@ export interface CopyObjectRequest { */ SSEKMSEncryptionContext?: string; + /** + *

        Specifies whether Amazon S3 should use an S3 Bucket Key for object encryption with server-side encryption using AWS KMS (SSE-KMS). Setting this header to true causes Amazon S3 to use an S3 Bucket Key for object encryption with SSE-KMS.

        + *

        Specifying this header with a COPY operation doesn’t affect bucket-level settings for S3 Bucket Key.

        + */ + BucketKeyEnabled?: boolean; + /** *

        Specifies the algorithm to use when decrypting the source object (for example, * AES256).

        @@ -1037,6 +1053,11 @@ export interface CreateMultipartUploadOutput { */ SSEKMSEncryptionContext?: string; + /** + *

        Indicates whether the multipart upload uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

        + */ + BucketKeyEnabled?: boolean; + /** *

        If present, indicates that the requester was successfully charged for the * request.

        @@ -1194,6 +1215,12 @@ export interface CreateMultipartUploadRequest { */ SSEKMSEncryptionContext?: string; + /** + *

        Specifies whether Amazon S3 should use an S3 Bucket Key for object encryption with server-side encryption using AWS KMS (SSE-KMS). Setting this header to true causes Amazon S3 to use an S3 Bucket Key for object encryption with SSE-KMS.

        + *

        Specifying this header with an object operation doesn’t affect bucket-level settings for S3 Bucket Key.

        + */ + BucketKeyEnabled?: boolean; + /** *

        Confirms that the requester knows that they will be charged for the request. Bucket * owners need not specify this parameter in their requests. For information about downloading @@ -4158,6 +4185,12 @@ export interface ServerSideEncryptionRule { * be applied.

        */ ApplyServerSideEncryptionByDefault?: ServerSideEncryptionByDefault; + + /** + *

        Specifies whether Amazon S3 should use an S3 Bucket Key with server-side encryption using KMS (SSE-KMS) for new objects in the bucket. Existing objects are not affected. Setting the BucketKeyEnabled element to true causes Amazon S3 to use an S3 Bucket Key. By default, S3 Bucket Key is not enabled.

        + *

        For more information, see Amazon S3 Bucket Keys in the Amazon Simple Storage Service Developer Guide.

        + */ + BucketKeyEnabled?: boolean; } export namespace ServerSideEncryptionRule { @@ -5650,9 +5683,9 @@ export type DeleteMarkerReplicationStatus = "Disabled" | "Enabled"; * DeleteMarkerReplication element. If your Filter includes a * Tag element, the DeleteMarkerReplication * Status must be set to Disabled, because Amazon S3 does not support replicating - * delete markers for tag-based rules. For an example configuration, see Basic - * Rule Configuration.

        - *

        For more information about delete marker replication, see Basic Rule Configuration.

        + * delete markers for tag-based rules. For an example configuration, see Basic Rule Configuration.

        + *

        For more information about delete marker replication, see Basic Rule + * Configuration.

        * *

        If you are using an earlier version of the replication configuration, Amazon S3 handles * replication of delete markers differently. For more information, see Backward Compatibility.

        @@ -5968,6 +6001,32 @@ export namespace ReplicationRuleFilter { }; } +export type ReplicaModificationsStatus = "Disabled" | "Enabled"; + +/** + *

        A filter that you can specify for selection for modifications on replicas. Amazon S3 doesn't + * replicate replica modifications by default. In the latest version of replication + * configuration (when Filter is specified), you can specify this element and set + * the status to Enabled to replicate modifications on replicas.

        + * + *

        If you don't specify the Filter element, Amazon S3 assumes that the + * replication configuration is the earlier version, V1. In the earlier version, this + * element is not allowed.

        + *
        + */ +export interface ReplicaModifications { + /** + *

        Specifies whether Amazon S3 replicates modifications on replicas.

        + */ + Status: ReplicaModificationsStatus | string | undefined; +} + +export namespace ReplicaModifications { + export const filterSensitiveLog = (obj: ReplicaModifications): any => ({ + ...obj, + }); +} + export type SseKmsEncryptedObjectsStatus = "Disabled" | "Enabled"; /** @@ -6002,6 +6061,19 @@ export interface SourceSelectionCriteria { * this element is required.

        */ SseKmsEncryptedObjects?: SseKmsEncryptedObjects; + + /** + *

        A filter that you can specify for selections for modifications on replicas. Amazon S3 doesn't + * replicate replica modifications by default. In the latest version of replication + * configuration (when Filter is specified), you can specify this element and set + * the status to Enabled to replicate modifications on replicas.

        + * + *

        If you don't specify the Filter element, Amazon S3 assumes that the + * replication configuration is the earlier version, V1. In the earlier version, this + * element is not allowed

        + *
        + */ + ReplicaModifications?: ReplicaModifications; } export namespace SourceSelectionCriteria { @@ -6022,19 +6094,11 @@ export interface ReplicationRule { ID?: string; /** - *

        The priority associated with the rule. If you specify multiple rules in a replication - * configuration, Amazon S3 prioritizes the rules to prevent conflicts when filtering. If two or - * more rules identify the same object based on a specified filter, the rule with higher - * priority takes precedence. For example:

        - *
          - *
        • - *

          Same object quality prefix-based filter criteria if prefixes you specified in - * multiple rules overlap

          - *
        • - *
        • - *

          Same object qualify tag-based filter criteria specified in multiple rules

          - *
        • - *
        + *

        The priority indicates which rule has precedence whenever two or more replication rules + * conflict. Amazon S3 will attempt to replicate objects according to all replication rules. + * However, if there are two or more rules with the same destination bucket, then objects will + * be replicated according to the rule with the highest priority. The higher the number, the + * higher the priority.

        *

        For more information, see Replication in the * Amazon Simple Storage Service Developer Guide.

        */ @@ -6085,9 +6149,9 @@ export interface ReplicationRule { * DeleteMarkerReplication element. If your Filter includes a * Tag element, the DeleteMarkerReplication * Status must be set to Disabled, because Amazon S3 does not support replicating - * delete markers for tag-based rules. For an example configuration, see Basic - * Rule Configuration.

        - *

        For more information about delete marker replication, see Basic Rule Configuration.

        + * delete markers for tag-based rules. For an example configuration, see Basic Rule Configuration.

        + *

        For more information about delete marker replication, see Basic Rule + * Configuration.

        * *

        If you are using an earlier version of the replication configuration, Amazon S3 handles * replication of delete markers differently. For more information, see Backward Compatibility.

        @@ -6622,6 +6686,11 @@ export interface GetObjectOutput { */ SSEKMSKeyId?: string; + /** + *

        Indicates whether the object uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

        + */ + BucketKeyEnabled?: boolean; + /** *

        Provides storage class information of the object. Amazon S3 returns this header for all * objects except for S3 Standard storage class objects.

        @@ -7506,6 +7575,11 @@ export interface HeadObjectOutput { */ SSEKMSKeyId?: string; + /** + *

        Indicates whether the object uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

        + */ + BucketKeyEnabled?: boolean; + /** *

        Provides storage class information of the object. Amazon S3 returns this header for all * objects except for S3 Standard storage class objects.

        @@ -7523,10 +7597,10 @@ export interface HeadObjectOutput { /** *

        Amazon S3 can return this header if your request involves a bucket that is either a source or - * destination in a replication rule.

        + * a destination in a replication rule.

        * *

        In replication, you have a source bucket on which you configure replication and - * destination bucket where Amazon S3 stores object replicas. When you request an object + * destination bucket or buckets where Amazon S3 stores object replicas. When you request an object * (GetObject) or object metadata (HeadObject) from these * buckets, Amazon S3 will return the x-amz-replication-status header in the response * as follows:

        @@ -7544,9 +7618,18 @@ export interface HeadObjectOutput { * FAILED indicating object replication status.

        * *
      • - *

        If requesting an object from the destination bucket — Amazon S3 will return the + *

        If requesting an object from a destination bucket — Amazon S3 will return the * x-amz-replication-status header with value REPLICA if the object in - * your request is a replica that Amazon S3 created.

        + * your request is a replica that Amazon S3 created and there is no replica modification + * replication in progress.

        + *
      • + *
      • + *

        When replicating objects to multiple destination buckets the + * x-amz-replication-status header acts differently. The header of the + * source object will only return a value of COMPLETED when replication is successful to + * all destinations. The header will remain at value PENDING until replication has + * completed for all destinations. If one or more destinations fails replication the + * header will return FAILED.

        *
      • *
      * @@ -7945,7 +8028,7 @@ export interface Bucket { Name?: string; /** - *

      Date the bucket was created.

      + *

      Date the bucket was created. This date can change when making changes to your bucket, such as editing its bucket policy.

      */ CreationDate?: Date; } @@ -9825,6 +9908,11 @@ export interface PutObjectOutput { */ SSEKMSEncryptionContext?: string; + /** + *

      Indicates whether the uploaded object uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

      + */ + BucketKeyEnabled?: boolean; + /** *

      If present, indicates that the requester was successfully charged for the * request.

      @@ -10028,6 +10116,12 @@ export interface PutObjectRequest { */ SSEKMSEncryptionContext?: string; + /** + *

      Specifies whether Amazon S3 should use an S3 Bucket Key for object encryption with server-side encryption using AWS KMS (SSE-KMS). Setting this header to true causes Amazon S3 to use an S3 Bucket Key for object encryption with SSE-KMS.

      + *

      Specifying this header with a PUT operation doesn’t affect bucket-level settings for S3 Bucket Key.

      + */ + BucketKeyEnabled?: boolean; + /** *

      Confirms that the requester knows that they will be charged for the request. Bucket * owners need not specify this parameter in their requests. For information about downloading @@ -10539,76 +10633,3 @@ export namespace Encryption { ...(obj.KMSKeyId && { KMSKeyId: SENSITIVE_STRING }), }); } - -/** - *

      A metadata key-value pair to store with an object.

      - */ -export interface MetadataEntry { - /** - *

      Name of the Object.

      - */ - Name?: string; - - /** - *

      Value of the Object.

      - */ - Value?: string; -} - -export namespace MetadataEntry { - export const filterSensitiveLog = (obj: MetadataEntry): any => ({ - ...obj, - }); -} - -/** - *

      Describes an Amazon S3 location that will receive the results of the restore request.

      - */ -export interface S3Location { - /** - *

      The name of the bucket where the restore results will be placed.

      - */ - BucketName: string | undefined; - - /** - *

      The prefix that is prepended to the restore results for this request.

      - */ - Prefix: string | undefined; - - /** - *

      Contains the type of server-side encryption used.

      - */ - Encryption?: Encryption; - - /** - *

      The canned ACL to apply to the restore results.

      - */ - CannedACL?: ObjectCannedACL | string; - - /** - *

      A list of grants that control access to the staged results.

      - */ - AccessControlList?: Grant[]; - - /** - *

      The tag-set that is applied to the restore results.

      - */ - Tagging?: Tagging; - - /** - *

      A list of metadata to store with the restore results in S3.

      - */ - UserMetadata?: MetadataEntry[]; - - /** - *

      The class of storage used to store the restore results.

      - */ - StorageClass?: StorageClass | string; -} - -export namespace S3Location { - export const filterSensitiveLog = (obj: S3Location): any => ({ - ...obj, - ...(obj.Encryption && { Encryption: Encryption.filterSensitiveLog(obj.Encryption) }), - }); -} diff --git a/clients/client-s3/models/models_1.ts b/clients/client-s3/models/models_1.ts index 594400ec6d1f..de9ccbb16311 100644 --- a/clients/client-s3/models/models_1.ts +++ b/clients/client-s3/models/models_1.ts @@ -1,7 +1,91 @@ -import { GlacierJobParameters, RequestCharged, RequestPayer, S3Location, ServerSideEncryption, Tier } from "./models_0"; +import { + Encryption, + GlacierJobParameters, + Grant, + ObjectCannedACL, + RequestCharged, + RequestPayer, + ServerSideEncryption, + StorageClass, + Tagging, + Tier, +} from "./models_0"; import { SENSITIVE_STRING } from "@aws-sdk/smithy-client"; import { Readable } from "stream"; +/** + *

      A metadata key-value pair to store with an object.

      + */ +export interface MetadataEntry { + /** + *

      Name of the Object.

      + */ + Name?: string; + + /** + *

      Value of the Object.

      + */ + Value?: string; +} + +export namespace MetadataEntry { + export const filterSensitiveLog = (obj: MetadataEntry): any => ({ + ...obj, + }); +} + +/** + *

      Describes an Amazon S3 location that will receive the results of the restore request.

      + */ +export interface S3Location { + /** + *

      The name of the bucket where the restore results will be placed.

      + */ + BucketName: string | undefined; + + /** + *

      The prefix that is prepended to the restore results for this request.

      + */ + Prefix: string | undefined; + + /** + *

      Contains the type of server-side encryption used.

      + */ + Encryption?: Encryption; + + /** + *

      The canned ACL to apply to the restore results.

      + */ + CannedACL?: ObjectCannedACL | string; + + /** + *

      A list of grants that control access to the staged results.

      + */ + AccessControlList?: Grant[]; + + /** + *

      The tag-set that is applied to the restore results.

      + */ + Tagging?: Tagging; + + /** + *

      A list of metadata to store with the restore results in S3.

      + */ + UserMetadata?: MetadataEntry[]; + + /** + *

      The class of storage used to store the restore results.

      + */ + StorageClass?: StorageClass | string; +} + +export namespace S3Location { + export const filterSensitiveLog = (obj: S3Location): any => ({ + ...obj, + ...(obj.Encryption && { Encryption: Encryption.filterSensitiveLog(obj.Encryption) }), + }); +} + /** *

      Describes the location where the restore job's output is stored.

      */ @@ -827,6 +911,11 @@ export interface UploadPartOutput { */ SSEKMSKeyId?: string; + /** + *

      Indicates whether the multipart upload uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

      + */ + BucketKeyEnabled?: boolean; + /** *

      If present, indicates that the requester was successfully charged for the * request.

      @@ -984,6 +1073,11 @@ export interface UploadPartCopyOutput { */ SSEKMSKeyId?: string; + /** + *

      Indicates whether the multipart upload uses an S3 Bucket Key for server-side encryption with AWS KMS (SSE-KMS).

      + */ + BucketKeyEnabled?: boolean; + /** *

      If present, indicates that the requester was successfully charged for the * request.

      diff --git a/clients/client-s3/protocols/Aws_restXml.ts b/clients/client-s3/protocols/Aws_restXml.ts index 4f2cd653628c..c8937bdd5915 100644 --- a/clients/client-s3/protocols/Aws_restXml.ts +++ b/clients/client-s3/protocols/Aws_restXml.ts @@ -296,7 +296,6 @@ import { LifecycleRuleAndOperator, LifecycleRuleFilter, LoggingEnabled, - MetadataEntry, Metrics, MetricsAndOperator, MetricsConfiguration, @@ -326,6 +325,7 @@ import { QueueConfiguration, Redirect, RedirectAllRequestsTo, + ReplicaModifications, ReplicationConfiguration, ReplicationRule, ReplicationRuleAndOperator, @@ -335,7 +335,6 @@ import { RequestPaymentConfiguration, RoutingRule, S3KeyFilter, - S3Location, SSEKMS, SSES3, ServerSideEncryptionByDefault, @@ -365,6 +364,7 @@ import { InputSerialization, JSONInput, JSONOutput, + MetadataEntry, OutputLocation, OutputSerialization, ParquetInput, @@ -372,6 +372,7 @@ import { RecordsEvent, RequestProgress, RestoreRequest, + S3Location, ScanRange, SelectObjectContentEventStream, SelectParameters, @@ -563,6 +564,9 @@ export const serializeAws_restXmlCopyObjectCommand = async ( ...(isSerializableHeaderValue(input.SSEKMSEncryptionContext) && { "x-amz-server-side-encryption-context": input.SSEKMSEncryptionContext!, }), + ...(isSerializableHeaderValue(input.BucketKeyEnabled) && { + "x-amz-server-side-encryption-bucket-key-enabled": input.BucketKeyEnabled!.toString(), + }), ...(isSerializableHeaderValue(input.CopySourceSSECustomerAlgorithm) && { "x-amz-copy-source-server-side-encryption-customer-algorithm": input.CopySourceSSECustomerAlgorithm!, }), @@ -722,6 +726,9 @@ export const serializeAws_restXmlCreateMultipartUploadCommand = async ( ...(isSerializableHeaderValue(input.SSEKMSEncryptionContext) && { "x-amz-server-side-encryption-context": input.SSEKMSEncryptionContext!, }), + ...(isSerializableHeaderValue(input.BucketKeyEnabled) && { + "x-amz-server-side-encryption-bucket-key-enabled": input.BucketKeyEnabled!.toString(), + }), ...(isSerializableHeaderValue(input.RequestPayer) && { "x-amz-request-payer": input.RequestPayer! }), ...(isSerializableHeaderValue(input.Tagging) && { "x-amz-tagging": input.Tagging! }), ...(isSerializableHeaderValue(input.ObjectLockMode) && { "x-amz-object-lock-mode": input.ObjectLockMode! }), @@ -3992,6 +3999,9 @@ export const serializeAws_restXmlPutObjectCommand = async ( ...(isSerializableHeaderValue(input.SSEKMSEncryptionContext) && { "x-amz-server-side-encryption-context": input.SSEKMSEncryptionContext!, }), + ...(isSerializableHeaderValue(input.BucketKeyEnabled) && { + "x-amz-server-side-encryption-bucket-key-enabled": input.BucketKeyEnabled!.toString(), + }), ...(isSerializableHeaderValue(input.RequestPayer) && { "x-amz-request-payer": input.RequestPayer! }), ...(isSerializableHeaderValue(input.Tagging) && { "x-amz-tagging": input.Tagging! }), ...(isSerializableHeaderValue(input.ObjectLockMode) && { "x-amz-object-lock-mode": input.ObjectLockMode! }), @@ -4790,6 +4800,7 @@ export const deserializeAws_restXmlCompleteMultipartUploadCommand = async ( const contents: CompleteMultipartUploadCommandOutput = { $metadata: deserializeMetadata(output), Bucket: undefined, + BucketKeyEnabled: undefined, ETag: undefined, Expiration: undefined, Key: undefined, @@ -4811,6 +4822,9 @@ export const deserializeAws_restXmlCompleteMultipartUploadCommand = async ( if (output.headers["x-amz-server-side-encryption-aws-kms-key-id"] !== undefined) { contents.SSEKMSKeyId = output.headers["x-amz-server-side-encryption-aws-kms-key-id"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -4868,6 +4882,7 @@ export const deserializeAws_restXmlCopyObjectCommand = async ( } const contents: CopyObjectCommandOutput = { $metadata: deserializeMetadata(output), + BucketKeyEnabled: undefined, CopyObjectResult: undefined, CopySourceVersionId: undefined, Expiration: undefined, @@ -4903,6 +4918,9 @@ export const deserializeAws_restXmlCopyObjectCommand = async ( if (output.headers["x-amz-server-side-encryption-context"] !== undefined) { contents.SSEKMSEncryptionContext = output.headers["x-amz-server-side-encryption-context"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -5023,6 +5041,7 @@ export const deserializeAws_restXmlCreateMultipartUploadCommand = async ( AbortDate: undefined, AbortRuleId: undefined, Bucket: undefined, + BucketKeyEnabled: undefined, Key: undefined, RequestCharged: undefined, SSECustomerAlgorithm: undefined, @@ -5053,6 +5072,9 @@ export const deserializeAws_restXmlCreateMultipartUploadCommand = async ( if (output.headers["x-amz-server-side-encryption-context"] !== undefined) { contents.SSEKMSEncryptionContext = output.headers["x-amz-server-side-encryption-context"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -6865,6 +6887,7 @@ export const deserializeAws_restXmlGetObjectCommand = async ( $metadata: deserializeMetadata(output), AcceptRanges: undefined, Body: undefined, + BucketKeyEnabled: undefined, CacheControl: undefined, ContentDisposition: undefined, ContentEncoding: undefined, @@ -6958,6 +6981,9 @@ export const deserializeAws_restXmlGetObjectCommand = async ( if (output.headers["x-amz-server-side-encryption-aws-kms-key-id"] !== undefined) { contents.SSEKMSKeyId = output.headers["x-amz-server-side-encryption-aws-kms-key-id"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-storage-class"] !== undefined) { contents.StorageClass = output.headers["x-amz-storage-class"]; } @@ -7451,6 +7477,7 @@ export const deserializeAws_restXmlHeadObjectCommand = async ( $metadata: deserializeMetadata(output), AcceptRanges: undefined, ArchiveStatus: undefined, + BucketKeyEnabled: undefined, CacheControl: undefined, ContentDisposition: undefined, ContentEncoding: undefined, @@ -7542,6 +7569,9 @@ export const deserializeAws_restXmlHeadObjectCommand = async ( if (output.headers["x-amz-server-side-encryption-aws-kms-key-id"] !== undefined) { contents.SSEKMSKeyId = output.headers["x-amz-server-side-encryption-aws-kms-key-id"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-storage-class"] !== undefined) { contents.StorageClass = output.headers["x-amz-storage-class"]; } @@ -9226,6 +9256,7 @@ export const deserializeAws_restXmlPutObjectCommand = async ( } const contents: PutObjectCommandOutput = { $metadata: deserializeMetadata(output), + BucketKeyEnabled: undefined, ETag: undefined, Expiration: undefined, RequestCharged: undefined, @@ -9260,6 +9291,9 @@ export const deserializeAws_restXmlPutObjectCommand = async ( if (output.headers["x-amz-server-side-encryption-context"] !== undefined) { contents.SSEKMSEncryptionContext = output.headers["x-amz-server-side-encryption-context"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -9709,6 +9743,7 @@ export const deserializeAws_restXmlUploadPartCommand = async ( } const contents: UploadPartCommandOutput = { $metadata: deserializeMetadata(output), + BucketKeyEnabled: undefined, ETag: undefined, RequestCharged: undefined, SSECustomerAlgorithm: undefined, @@ -9731,6 +9766,9 @@ export const deserializeAws_restXmlUploadPartCommand = async ( if (output.headers["x-amz-server-side-encryption-aws-kms-key-id"] !== undefined) { contents.SSEKMSKeyId = output.headers["x-amz-server-side-encryption-aws-kms-key-id"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -9776,6 +9814,7 @@ export const deserializeAws_restXmlUploadPartCopyCommand = async ( } const contents: UploadPartCopyCommandOutput = { $metadata: deserializeMetadata(output), + BucketKeyEnabled: undefined, CopyPartResult: undefined, CopySourceVersionId: undefined, RequestCharged: undefined, @@ -9799,6 +9838,9 @@ export const deserializeAws_restXmlUploadPartCopyCommand = async ( if (output.headers["x-amz-server-side-encryption-aws-kms-key-id"] !== undefined) { contents.SSEKMSKeyId = output.headers["x-amz-server-side-encryption-aws-kms-key-id"]; } + if (output.headers["x-amz-server-side-encryption-bucket-key-enabled"] !== undefined) { + contents.BucketKeyEnabled = output.headers["x-amz-server-side-encryption-bucket-key-enabled"] === "true"; + } if (output.headers["x-amz-request-charged"] !== undefined) { contents.RequestCharged = output.headers["x-amz-request-charged"]; } @@ -11468,6 +11510,17 @@ const serializeAws_restXmlRedirectAllRequestsTo = (input: RedirectAllRequestsTo, return bodyNode; }; +const serializeAws_restXmlReplicaModifications = (input: ReplicaModifications, context: __SerdeContext): any => { + const bodyNode = new __XmlNode("ReplicaModifications"); + if (input.Status !== undefined) { + const node = new __XmlNode("ReplicaModificationsStatus") + .addChildNode(new __XmlText(input.Status)) + .withName("Status"); + bodyNode.addChildNode(node); + } + return bodyNode; +}; + const serializeAws_restXmlReplicationConfiguration = ( input: ReplicationConfiguration, context: __SerdeContext @@ -11829,6 +11882,12 @@ const serializeAws_restXmlServerSideEncryptionRule = ( ).withName("ApplyServerSideEncryptionByDefault"); bodyNode.addChildNode(node); } + if (input.BucketKeyEnabled !== undefined) { + const node = new __XmlNode("BucketKeyEnabled") + .addChildNode(new __XmlText(String(input.BucketKeyEnabled))) + .withName("BucketKeyEnabled"); + bodyNode.addChildNode(node); + } return bodyNode; }; @@ -11850,6 +11909,12 @@ const serializeAws_restXmlSourceSelectionCriteria = (input: SourceSelectionCrite ); bodyNode.addChildNode(node); } + if (input.ReplicaModifications !== undefined) { + const node = serializeAws_restXmlReplicaModifications(input.ReplicaModifications, context).withName( + "ReplicaModifications" + ); + bodyNode.addChildNode(node); + } return bodyNode; }; @@ -13480,6 +13545,16 @@ const deserializeAws_restXmlRedirectAllRequestsTo = (output: any, context: __Ser return contents; }; +const deserializeAws_restXmlReplicaModifications = (output: any, context: __SerdeContext): ReplicaModifications => { + let contents: any = { + Status: undefined, + }; + if (output["Status"] !== undefined) { + contents.Status = output["Status"]; + } + return contents; +}; + const deserializeAws_restXmlReplicationConfiguration = ( output: any, context: __SerdeContext @@ -13688,6 +13763,7 @@ const deserializeAws_restXmlServerSideEncryptionRule = ( ): ServerSideEncryptionRule => { let contents: any = { ApplyServerSideEncryptionByDefault: undefined, + BucketKeyEnabled: undefined, }; if (output["ApplyServerSideEncryptionByDefault"] !== undefined) { contents.ApplyServerSideEncryptionByDefault = deserializeAws_restXmlServerSideEncryptionByDefault( @@ -13695,6 +13771,9 @@ const deserializeAws_restXmlServerSideEncryptionRule = ( context ); } + if (output["BucketKeyEnabled"] !== undefined) { + contents.BucketKeyEnabled = output["BucketKeyEnabled"] == "true"; + } return contents; }; @@ -13711,6 +13790,7 @@ const deserializeAws_restXmlSourceSelectionCriteria = ( ): SourceSelectionCriteria => { let contents: any = { SseKmsEncryptedObjects: undefined, + ReplicaModifications: undefined, }; if (output["SseKmsEncryptedObjects"] !== undefined) { contents.SseKmsEncryptedObjects = deserializeAws_restXmlSseKmsEncryptedObjects( @@ -13718,6 +13798,9 @@ const deserializeAws_restXmlSourceSelectionCriteria = ( context ); } + if (output["ReplicaModifications"] !== undefined) { + contents.ReplicaModifications = deserializeAws_restXmlReplicaModifications(output["ReplicaModifications"], context); + } return contents; }; diff --git a/clients/client-sagemaker-featurestore-runtime/.gitignore b/clients/client-sagemaker-featurestore-runtime/.gitignore new file mode 100644 index 000000000000..b41c05b597c4 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/.gitignore @@ -0,0 +1,14 @@ +/node_modules/ +/build/ +/coverage/ +/docs/ +/types/ +/dist/ +*.tsbuildinfo +*.tgz +*.log +package-lock.json + +*.d.ts +*.js +*.js.map diff --git a/clients/client-sagemaker-featurestore-runtime/.npmignore b/clients/client-sagemaker-featurestore-runtime/.npmignore new file mode 100644 index 000000000000..b7ff81137c4a --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/.npmignore @@ -0,0 +1,4 @@ +/coverage/ +/docs/ +tsconfig.test.json +*.tsbuildinfo diff --git a/clients/client-sagemaker-featurestore-runtime/LICENSE b/clients/client-sagemaker-featurestore-runtime/LICENSE new file mode 100644 index 000000000000..dd65ae06be7a --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/clients/client-sagemaker-featurestore-runtime/README.md b/clients/client-sagemaker-featurestore-runtime/README.md new file mode 100644 index 000000000000..84ad5d2ef35b --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/README.md @@ -0,0 +1,6 @@ +# @aws-sdk/client-sagemaker-featurestore-runtime + +[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-sagemaker-featurestore-runtime/rc.svg)](https://www.npmjs.com/package/@aws-sdk/client-sagemaker-featurestore-runtime) +[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-sagemaker-featurestore-runtime.svg)](https://www.npmjs.com/package/@aws-sdk/client-sagemaker-featurestore-runtime) + +For SDK usage, please step to [SDK readme](https://github.com/aws/aws-sdk-js-v3). diff --git a/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntime.ts b/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntime.ts new file mode 100644 index 000000000000..6892cf6f340a --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntime.ts @@ -0,0 +1,129 @@ +import { SageMakerFeatureStoreRuntimeClient } from "./SageMakerFeatureStoreRuntimeClient"; +import { + DeleteRecordCommand, + DeleteRecordCommandInput, + DeleteRecordCommandOutput, +} from "./commands/DeleteRecordCommand"; +import { GetRecordCommand, GetRecordCommandInput, GetRecordCommandOutput } from "./commands/GetRecordCommand"; +import { PutRecordCommand, PutRecordCommandInput, PutRecordCommandOutput } from "./commands/PutRecordCommand"; +import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; + +/** + *

      Contains all data plane API operations and data types for the Amazon SageMaker Feature + * Store. Use this API to put, delete, and retrieve (get) features from a feature + * store.

      + *

      Use the following operations to configure your OnlineStore and + * OfflineStore features, and to create and manage feature groups:

      + * + */ +export class SageMakerFeatureStoreRuntime extends SageMakerFeatureStoreRuntimeClient { + /** + *

      Deletes a Record from a FeatureGroup. A new record will show + * up in the OfflineStore when the DeleteRecord API is called. This + * record will have a value of True in the is_deleted column.

      + */ + public deleteRecord( + args: DeleteRecordCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteRecord(args: DeleteRecordCommandInput, cb: (err: any, data?: DeleteRecordCommandOutput) => void): void; + public deleteRecord( + args: DeleteRecordCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteRecordCommandOutput) => void + ): void; + public deleteRecord( + args: DeleteRecordCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteRecordCommandOutput) => void), + cb?: (err: any, data?: DeleteRecordCommandOutput) => void + ): Promise | void { + const command = new DeleteRecordCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

      Use for OnlineStore serving from a FeatureStore. Only the + * latest records stored in the OnlineStore can be retrieved. If no Record with + * RecordIdentifierValue is found, then an empty result is returned.

      + */ + public getRecord(args: GetRecordCommandInput, options?: __HttpHandlerOptions): Promise; + public getRecord(args: GetRecordCommandInput, cb: (err: any, data?: GetRecordCommandOutput) => void): void; + public getRecord( + args: GetRecordCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetRecordCommandOutput) => void + ): void; + public getRecord( + args: GetRecordCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetRecordCommandOutput) => void), + cb?: (err: any, data?: GetRecordCommandOutput) => void + ): Promise | void { + const command = new GetRecordCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

      Used for data ingestion into the FeatureStore. The PutRecord + * API writes to both the OnlineStore and OfflineStore. If the + * record is the latest record for the recordIdentifier, the record is written to + * both the OnlineStore and OfflineStore. If the record is a + * historic record, it is written only to the OfflineStore.

      + */ + public putRecord(args: PutRecordCommandInput, options?: __HttpHandlerOptions): Promise; + public putRecord(args: PutRecordCommandInput, cb: (err: any, data?: PutRecordCommandOutput) => void): void; + public putRecord( + args: PutRecordCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutRecordCommandOutput) => void + ): void; + public putRecord( + args: PutRecordCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutRecordCommandOutput) => void), + cb?: (err: any, data?: PutRecordCommandOutput) => void + ): Promise | void { + const command = new PutRecordCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } +} diff --git a/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntimeClient.ts b/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntimeClient.ts new file mode 100644 index 000000000000..332353d63a7a --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/SageMakerFeatureStoreRuntimeClient.ts @@ -0,0 +1,230 @@ +import { DeleteRecordCommandInput, DeleteRecordCommandOutput } from "./commands/DeleteRecordCommand"; +import { GetRecordCommandInput, GetRecordCommandOutput } from "./commands/GetRecordCommand"; +import { PutRecordCommandInput, PutRecordCommandOutput } from "./commands/PutRecordCommand"; +import { ClientDefaultValues as __ClientDefaultValues } from "./runtimeConfig"; +import { + EndpointsInputConfig, + EndpointsResolvedConfig, + RegionInputConfig, + RegionResolvedConfig, + resolveEndpointsConfig, + resolveRegionConfig, +} from "@aws-sdk/config-resolver"; +import { getContentLengthPlugin } from "@aws-sdk/middleware-content-length"; +import { + HostHeaderInputConfig, + HostHeaderResolvedConfig, + getHostHeaderPlugin, + resolveHostHeaderConfig, +} from "@aws-sdk/middleware-host-header"; +import { getLoggerPlugin } from "@aws-sdk/middleware-logger"; +import { RetryInputConfig, RetryResolvedConfig, getRetryPlugin, resolveRetryConfig } from "@aws-sdk/middleware-retry"; +import { + AwsAuthInputConfig, + AwsAuthResolvedConfig, + getAwsAuthPlugin, + resolveAwsAuthConfig, +} from "@aws-sdk/middleware-signing"; +import { + UserAgentInputConfig, + UserAgentResolvedConfig, + getUserAgentPlugin, + resolveUserAgentConfig, +} from "@aws-sdk/middleware-user-agent"; +import { HttpHandler as __HttpHandler } from "@aws-sdk/protocol-http"; +import { + Client as __Client, + SmithyConfiguration as __SmithyConfiguration, + SmithyResolvedConfiguration as __SmithyResolvedConfiguration, +} from "@aws-sdk/smithy-client"; +import { + RegionInfoProvider, + Credentials as __Credentials, + Decoder as __Decoder, + Encoder as __Encoder, + HashConstructor as __HashConstructor, + HttpHandlerOptions as __HttpHandlerOptions, + Logger as __Logger, + Provider as __Provider, + StreamCollector as __StreamCollector, + UrlParser as __UrlParser, +} from "@aws-sdk/types"; + +export type ServiceInputTypes = DeleteRecordCommandInput | GetRecordCommandInput | PutRecordCommandInput; + +export type ServiceOutputTypes = DeleteRecordCommandOutput | GetRecordCommandOutput | PutRecordCommandOutput; + +export interface ClientDefaults extends Partial<__SmithyResolvedConfiguration<__HttpHandlerOptions>> { + /** + * The HTTP handler to use. Fetch in browser and Https in Nodejs. + */ + requestHandler?: __HttpHandler; + + /** + * A constructor for a class implementing the @aws-sdk/types.Hash interface + * that computes the SHA-256 HMAC or checksum of a string or binary buffer. + */ + sha256?: __HashConstructor; + + /** + * The function that will be used to convert strings into HTTP endpoints. + */ + urlParser?: __UrlParser; + + /** + * A function that can calculate the length of a request body. + */ + bodyLengthChecker?: (body: any) => number | undefined; + + /** + * A function that converts a stream into an array of bytes. + */ + streamCollector?: __StreamCollector; + + /** + * The function that will be used to convert a base64-encoded string to a byte array + */ + base64Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a base64-encoded string + */ + base64Encoder?: __Encoder; + + /** + * The function that will be used to convert a UTF8-encoded string to a byte array + */ + utf8Decoder?: __Decoder; + + /** + * The function that will be used to convert binary data to a UTF-8 encoded string + */ + utf8Encoder?: __Encoder; + + /** + * The string that will be used to populate default value in 'User-Agent' header + */ + defaultUserAgent?: string; + + /** + * The runtime environment + */ + runtime?: string; + + /** + * Disable dyanamically changing the endpoint of the client based on the hostPrefix + * trait of an operation. + */ + disableHostPrefix?: boolean; + + /** + * The service name with which to sign requests. + */ + signingName?: string; + + /** + * Default credentials provider; Not available in browser runtime + */ + credentialDefaultProvider?: (input: any) => __Provider<__Credentials>; + + /** + * The AWS region to which this client will send requests + */ + region?: string | __Provider; + + /** + * Value for how many times a request will be made at most in case of retry. + */ + maxAttempts?: number | __Provider; + + /** + * Optional logger for logging debug/info/warn/error. + */ + logger?: __Logger; + + /** + * Fetch related hostname, signing name or signing region with given region. + */ + regionInfoProvider?: RegionInfoProvider; +} + +export type SageMakerFeatureStoreRuntimeClientConfig = Partial<__SmithyConfiguration<__HttpHandlerOptions>> & + ClientDefaults & + RegionInputConfig & + EndpointsInputConfig & + AwsAuthInputConfig & + RetryInputConfig & + UserAgentInputConfig & + HostHeaderInputConfig; + +export type SageMakerFeatureStoreRuntimeClientResolvedConfig = __SmithyResolvedConfiguration<__HttpHandlerOptions> & + Required & + RegionResolvedConfig & + EndpointsResolvedConfig & + AwsAuthResolvedConfig & + RetryResolvedConfig & + UserAgentResolvedConfig & + HostHeaderResolvedConfig; + +/** + *

      Contains all data plane API operations and data types for the Amazon SageMaker Feature + * Store. Use this API to put, delete, and retrieve (get) features from a feature + * store.

      + *

      Use the following operations to configure your OnlineStore and + * OfflineStore features, and to create and manage feature groups:

      + * + */ +export class SageMakerFeatureStoreRuntimeClient extends __Client< + __HttpHandlerOptions, + ServiceInputTypes, + ServiceOutputTypes, + SageMakerFeatureStoreRuntimeClientResolvedConfig +> { + readonly config: SageMakerFeatureStoreRuntimeClientResolvedConfig; + + constructor(configuration: SageMakerFeatureStoreRuntimeClientConfig) { + let _config_0 = { + ...__ClientDefaultValues, + ...configuration, + }; + let _config_1 = resolveRegionConfig(_config_0); + let _config_2 = resolveEndpointsConfig(_config_1); + let _config_3 = resolveAwsAuthConfig(_config_2); + let _config_4 = resolveRetryConfig(_config_3); + let _config_5 = resolveUserAgentConfig(_config_4); + let _config_6 = resolveHostHeaderConfig(_config_5); + super(_config_6); + this.config = _config_6; + this.middlewareStack.use(getAwsAuthPlugin(this.config)); + this.middlewareStack.use(getRetryPlugin(this.config)); + this.middlewareStack.use(getUserAgentPlugin(this.config)); + this.middlewareStack.use(getContentLengthPlugin(this.config)); + this.middlewareStack.use(getHostHeaderPlugin(this.config)); + this.middlewareStack.use(getLoggerPlugin(this.config)); + } + + destroy(): void { + super.destroy(); + } +} diff --git a/clients/client-sagemaker-featurestore-runtime/commands/DeleteRecordCommand.ts b/clients/client-sagemaker-featurestore-runtime/commands/DeleteRecordCommand.ts new file mode 100644 index 000000000000..06781e1b211d --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/commands/DeleteRecordCommand.ts @@ -0,0 +1,94 @@ +import { + SageMakerFeatureStoreRuntimeClientResolvedConfig, + ServiceInputTypes, + ServiceOutputTypes, +} from "../SageMakerFeatureStoreRuntimeClient"; +import { DeleteRecordRequest } from "../models/models_0"; +import { + deserializeAws_restJson1DeleteRecordCommand, + serializeAws_restJson1DeleteRecordCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteRecordCommandInput = DeleteRecordRequest; +export type DeleteRecordCommandOutput = __MetadataBearer; + +/** + *

      Deletes a Record from a FeatureGroup. A new record will show + * up in the OfflineStore when the DeleteRecord API is called. This + * record will have a value of True in the is_deleted column.

      + */ +export class DeleteRecordCommand extends $Command< + DeleteRecordCommandInput, + DeleteRecordCommandOutput, + SageMakerFeatureStoreRuntimeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteRecordCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerFeatureStoreRuntimeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerFeatureStoreRuntimeClient"; + const commandName = "DeleteRecordCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteRecordRequest.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteRecordCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1DeleteRecordCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1DeleteRecordCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker-featurestore-runtime/commands/GetRecordCommand.ts b/clients/client-sagemaker-featurestore-runtime/commands/GetRecordCommand.ts new file mode 100644 index 000000000000..2e8ac17a4b3d --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/commands/GetRecordCommand.ts @@ -0,0 +1,94 @@ +import { + SageMakerFeatureStoreRuntimeClientResolvedConfig, + ServiceInputTypes, + ServiceOutputTypes, +} from "../SageMakerFeatureStoreRuntimeClient"; +import { GetRecordRequest, GetRecordResponse } from "../models/models_0"; +import { + deserializeAws_restJson1GetRecordCommand, + serializeAws_restJson1GetRecordCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetRecordCommandInput = GetRecordRequest; +export type GetRecordCommandOutput = GetRecordResponse & __MetadataBearer; + +/** + *

      Use for OnlineStore serving from a FeatureStore. Only the + * latest records stored in the OnlineStore can be retrieved. If no Record with + * RecordIdentifierValue is found, then an empty result is returned.

      + */ +export class GetRecordCommand extends $Command< + GetRecordCommandInput, + GetRecordCommandOutput, + SageMakerFeatureStoreRuntimeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetRecordCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerFeatureStoreRuntimeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerFeatureStoreRuntimeClient"; + const commandName = "GetRecordCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetRecordRequest.filterSensitiveLog, + outputFilterSensitiveLog: GetRecordResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetRecordCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1GetRecordCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1GetRecordCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker-featurestore-runtime/commands/PutRecordCommand.ts b/clients/client-sagemaker-featurestore-runtime/commands/PutRecordCommand.ts new file mode 100644 index 000000000000..dd3a62023c5c --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/commands/PutRecordCommand.ts @@ -0,0 +1,96 @@ +import { + SageMakerFeatureStoreRuntimeClientResolvedConfig, + ServiceInputTypes, + ServiceOutputTypes, +} from "../SageMakerFeatureStoreRuntimeClient"; +import { PutRecordRequest } from "../models/models_0"; +import { + deserializeAws_restJson1PutRecordCommand, + serializeAws_restJson1PutRecordCommand, +} from "../protocols/Aws_restJson1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutRecordCommandInput = PutRecordRequest; +export type PutRecordCommandOutput = __MetadataBearer; + +/** + *

      Used for data ingestion into the FeatureStore. The PutRecord + * API writes to both the OnlineStore and OfflineStore. If the + * record is the latest record for the recordIdentifier, the record is written to + * both the OnlineStore and OfflineStore. If the record is a + * historic record, it is written only to the OfflineStore.

      + */ +export class PutRecordCommand extends $Command< + PutRecordCommandInput, + PutRecordCommandOutput, + SageMakerFeatureStoreRuntimeClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutRecordCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerFeatureStoreRuntimeClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerFeatureStoreRuntimeClient"; + const commandName = "PutRecordCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutRecordRequest.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutRecordCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_restJson1PutRecordCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_restJson1PutRecordCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker-featurestore-runtime/endpoints.ts b/clients/client-sagemaker-featurestore-runtime/endpoints.ts new file mode 100644 index 000000000000..b8d3e657976b --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/endpoints.ts @@ -0,0 +1,81 @@ +import { RegionInfo, RegionInfoProvider } from "@aws-sdk/types"; + +// Partition default templates +const AWS_TEMPLATE = "sagemaker.{region}.amazonaws.com"; +const AWS_CN_TEMPLATE = "sagemaker.{region}.amazonaws.com.cn"; +const AWS_ISO_TEMPLATE = "sagemaker.{region}.c2s.ic.gov"; +const AWS_ISO_B_TEMPLATE = "sagemaker.{region}.sc2s.sgov.gov"; +const AWS_US_GOV_TEMPLATE = "sagemaker.{region}.amazonaws.com"; + +// Partition regions +const AWS_REGIONS = new Set([ + "ap-east-1", + "ap-northeast-1", + "ap-northeast-2", + "ap-south-1", + "ap-southeast-1", + "ap-southeast-2", + "ca-central-1", + "eu-central-1", + "eu-north-1", + "eu-west-1", + "eu-west-2", + "eu-west-3", + "me-south-1", + "sa-east-1", + "us-east-1", + "us-east-2", + "us-west-1", + "us-west-2", +]); +const AWS_CN_REGIONS = new Set(["cn-north-1", "cn-northwest-1"]); +const AWS_ISO_REGIONS = new Set(["us-iso-east-1"]); +const AWS_ISO_B_REGIONS = new Set(["us-isob-east-1"]); +const AWS_US_GOV_REGIONS = new Set(["us-gov-east-1", "us-gov-west-1"]); + +export const defaultRegionInfoProvider: RegionInfoProvider = (region: string, options?: any) => { + let regionInfo: RegionInfo | undefined = undefined; + switch (region) { + // First, try to match exact region names. + // Next, try to match partition endpoints. + default: + if (AWS_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + if (AWS_CN_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_CN_TEMPLATE.replace("{region}", region), + partition: "aws-cn", + }; + } + if (AWS_ISO_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_TEMPLATE.replace("{region}", region), + partition: "aws-iso", + }; + } + if (AWS_ISO_B_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_ISO_B_TEMPLATE.replace("{region}", region), + partition: "aws-iso-b", + }; + } + if (AWS_US_GOV_REGIONS.has(region)) { + regionInfo = { + hostname: AWS_US_GOV_TEMPLATE.replace("{region}", region), + partition: "aws-us-gov", + }; + } + // Finally, assume it's an AWS partition endpoint. + if (regionInfo === undefined) { + regionInfo = { + hostname: AWS_TEMPLATE.replace("{region}", region), + partition: "aws", + }; + } + } + return Promise.resolve(regionInfo); +}; diff --git a/clients/client-sagemaker-featurestore-runtime/index.ts b/clients/client-sagemaker-featurestore-runtime/index.ts new file mode 100644 index 000000000000..8a013f2544b1 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/index.ts @@ -0,0 +1,6 @@ +export * from "./SageMakerFeatureStoreRuntimeClient"; +export * from "./SageMakerFeatureStoreRuntime"; +export * from "./commands/DeleteRecordCommand"; +export * from "./commands/GetRecordCommand"; +export * from "./commands/PutRecordCommand"; +export * from "./models/index"; diff --git a/clients/client-sagemaker-featurestore-runtime/models/index.ts b/clients/client-sagemaker-featurestore-runtime/models/index.ts new file mode 100644 index 000000000000..09c5d6e09b8c --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/models/index.ts @@ -0,0 +1 @@ +export * from "./models_0"; diff --git a/clients/client-sagemaker-featurestore-runtime/models/models_0.ts b/clients/client-sagemaker-featurestore-runtime/models/models_0.ts new file mode 100644 index 000000000000..04b55a192e24 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/models/models_0.ts @@ -0,0 +1,193 @@ +import { SENSITIVE_STRING, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; +import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; + +/** + *

      You do not have permission to perform an action.

      + */ +export interface AccessForbidden extends __SmithyException, $MetadataBearer { + name: "AccessForbidden"; + $fault: "client"; + Message?: string; +} + +export namespace AccessForbidden { + export const filterSensitiveLog = (obj: AccessForbidden): any => ({ + ...obj, + }); +} + +export interface DeleteRecordRequest { + /** + *

      The name of the feature group to delete the record from.

      + */ + FeatureGroupName: string | undefined; + + /** + *

      The value for the RecordIdentifier that uniquely identifies the record, in + * string format.

      + */ + RecordIdentifierValueAsString: string | undefined; + + /** + *

      Timestamp indicating when the deletion event occurred. EventTime can be + * used to query data at a certain point in time.

      + */ + EventTime: string | undefined; +} + +export namespace DeleteRecordRequest { + export const filterSensitiveLog = (obj: DeleteRecordRequest): any => ({ + ...obj, + }); +} + +/** + *

      An internal failure occurred. Try your request again. If the problem + * persists, contact AWS customer support.

      + */ +export interface InternalFailure extends __SmithyException, $MetadataBearer { + name: "InternalFailure"; + $fault: "server"; + Message?: string; +} + +export namespace InternalFailure { + export const filterSensitiveLog = (obj: InternalFailure): any => ({ + ...obj, + }); +} + +/** + *

      The service is currently unavailable.

      + */ +export interface ServiceUnavailable extends __SmithyException, $MetadataBearer { + name: "ServiceUnavailable"; + $fault: "server"; + Message?: string; +} + +export namespace ServiceUnavailable { + export const filterSensitiveLog = (obj: ServiceUnavailable): any => ({ + ...obj, + }); +} + +/** + *

      There was an error validating your request.

      + */ +export interface ValidationError extends __SmithyException, $MetadataBearer { + name: "ValidationError"; + $fault: "client"; + Message?: string; +} + +export namespace ValidationError { + export const filterSensitiveLog = (obj: ValidationError): any => ({ + ...obj, + }); +} + +export interface GetRecordRequest { + /** + *

      The name of the feature group in which you want to put the records.

      + */ + FeatureGroupName: string | undefined; + + /** + *

      The value that corresponds to RecordIdentifier type and uniquely identifies + * the record in the FeatureGroup.

      + */ + RecordIdentifierValueAsString: string | undefined; + + /** + *

      List of names of Features to be retrieved. If not specified, the latest value for all + * the Features are returned.

      + */ + FeatureNames?: string[]; +} + +export namespace GetRecordRequest { + export const filterSensitiveLog = (obj: GetRecordRequest): any => ({ + ...obj, + }); +} + +/** + *

      The value associated with a feature.

      + */ +export interface FeatureValue { + /** + *

      The name of a feature that a feature value corresponds to.

      + */ + FeatureName: string | undefined; + + /** + *

      The value associated with a feature, in string format. Note that features types can be + * String, Integral, or Fractional. This value represents all three types as a string.

      + */ + ValueAsString: string | undefined; +} + +export namespace FeatureValue { + export const filterSensitiveLog = (obj: FeatureValue): any => ({ + ...obj, + }); +} + +export interface GetRecordResponse { + /** + *

      The record you requested. A list of FeatureValues.

      + */ + Record?: FeatureValue[]; +} + +export namespace GetRecordResponse { + export const filterSensitiveLog = (obj: GetRecordResponse): any => ({ + ...obj, + }); +} + +/** + *

      A resource that is required to perform an action was not found.

      + */ +export interface ResourceNotFound extends __SmithyException, $MetadataBearer { + name: "ResourceNotFound"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceNotFound { + export const filterSensitiveLog = (obj: ResourceNotFound): any => ({ + ...obj, + }); +} + +export interface PutRecordRequest { + /** + *

      The name of the feature group that you want to insert the record into.

      + */ + FeatureGroupName: string | undefined; + + /** + *

      List of FeatureValues to be inserted. This will be a full over-write. If you only want + * to update few of the feature values, do the following:

      + *
        + *
      • + *

        Use GetRecord to retrieve the latest record.

        + *
      • + *
      • + *

        Update the record returned from GetRecord.

        + *
      • + *
      • + *

        Use PutRecord to update feature values.

        + *
      • + *
      + */ + Record: FeatureValue[] | undefined; +} + +export namespace PutRecordRequest { + export const filterSensitiveLog = (obj: PutRecordRequest): any => ({ + ...obj, + }); +} diff --git a/clients/client-sagemaker-featurestore-runtime/package.json b/clients/client-sagemaker-featurestore-runtime/package.json new file mode 100644 index 000000000000..4b2edf5fad24 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/package.json @@ -0,0 +1,83 @@ +{ + "name": "@aws-sdk/client-sagemaker-featurestore-runtime", + "description": "AWS SDK for JavaScript Sagemaker Featurestore Runtime Client for Node.js, Browser and React Native", + "version": "1.0.0-rc.1", + "scripts": { + "clean": "yarn remove-definitions && yarn remove-dist && yarn remove-documentation", + "build-documentation": "yarn remove-documentation && typedoc ./", + "prepublishOnly": "yarn build", + "pretest": "yarn build:cjs", + "remove-definitions": "rimraf ./types", + "remove-dist": "rimraf ./dist", + "remove-documentation": "rimraf ./docs", + "test": "yarn build && jest --coverage --passWithNoTests", + "build:cjs": "tsc -p tsconfig.json", + "build:es": "tsc -p tsconfig.es.json", + "build": "yarn build:cjs && yarn build:es" + }, + "main": "./dist/cjs/index.js", + "types": "./types/index.d.ts", + "module": "./dist/es/index.js", + "browser": { + "./runtimeConfig": "./runtimeConfig.browser" + }, + "react-native": { + "./runtimeConfig": "./runtimeConfig.native" + }, + "sideEffects": false, + "dependencies": { + "@aws-crypto/sha256-browser": "^1.0.0", + "@aws-crypto/sha256-js": "^1.0.0", + "@aws-sdk/config-resolver": "1.0.0-rc.7", + "@aws-sdk/credential-provider-node": "1.0.0-rc.7", + "@aws-sdk/fetch-http-handler": "1.0.0-rc.7", + "@aws-sdk/hash-node": "1.0.0-rc.7", + "@aws-sdk/invalid-dependency": "1.0.0-rc.3", + "@aws-sdk/middleware-content-length": "1.0.0-rc.7", + "@aws-sdk/middleware-host-header": "1.0.0-rc.7", + "@aws-sdk/middleware-logger": "1.0.0-rc.7", + "@aws-sdk/middleware-retry": "1.0.0-rc.7", + "@aws-sdk/middleware-serde": "1.0.0-rc.7", + "@aws-sdk/middleware-signing": "1.0.0-rc.7", + "@aws-sdk/middleware-stack": "1.0.0-rc.7", + "@aws-sdk/middleware-user-agent": "1.0.0-rc.7", + "@aws-sdk/node-config-provider": "1.0.0-rc.7", + "@aws-sdk/node-http-handler": "1.0.0-rc.7", + "@aws-sdk/protocol-http": "1.0.0-rc.7", + "@aws-sdk/smithy-client": "1.0.0-rc.7", + "@aws-sdk/url-parser-browser": "1.0.0-rc.7", + "@aws-sdk/url-parser-node": "1.0.0-rc.7", + "@aws-sdk/util-base64-browser": "1.0.0-rc.3", + "@aws-sdk/util-base64-node": "1.0.0-rc.3", + "@aws-sdk/util-body-length-browser": "1.0.0-rc.3", + "@aws-sdk/util-body-length-node": "1.0.0-rc.3", + "@aws-sdk/util-user-agent-browser": "1.0.0-rc.7", + "@aws-sdk/util-user-agent-node": "1.0.0-rc.7", + "@aws-sdk/util-utf8-browser": "1.0.0-rc.3", + "@aws-sdk/util-utf8-node": "1.0.0-rc.3", + "tslib": "^2.0.0" + }, + "devDependencies": { + "@aws-sdk/client-documentation-generator": "1.0.0-rc.7", + "@aws-sdk/types": "1.0.0-rc.7", + "@types/node": "^12.7.5", + "jest": "^26.1.0", + "rimraf": "^3.0.0", + "typedoc": "^0.19.2", + "typescript": "~4.1.2" + }, + "engines": { + "node": ">=10.0.0" + }, + "author": { + "name": "AWS SDK for JavaScript Team", + "url": "https://aws.amazon.com/javascript/" + }, + "license": "Apache-2.0", + "homepage": "https://github.com/aws/aws-sdk-js-v3/tree/master/clients/client-sagemaker-featurestore-runtime", + "repository": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-js-v3.git", + "directory": "clients/client-sagemaker-featurestore-runtime" + } +} diff --git a/clients/client-sagemaker-featurestore-runtime/protocols/Aws_restJson1.ts b/clients/client-sagemaker-featurestore-runtime/protocols/Aws_restJson1.ts new file mode 100644 index 000000000000..af5c8e928f25 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/protocols/Aws_restJson1.ts @@ -0,0 +1,539 @@ +import { DeleteRecordCommandInput, DeleteRecordCommandOutput } from "../commands/DeleteRecordCommand"; +import { GetRecordCommandInput, GetRecordCommandOutput } from "../commands/GetRecordCommand"; +import { PutRecordCommandInput, PutRecordCommandOutput } from "../commands/PutRecordCommand"; +import { + AccessForbidden, + FeatureValue, + InternalFailure, + ResourceNotFound, + ServiceUnavailable, + ValidationError, +} from "../models/models_0"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { + SmithyException as __SmithyException, + extendedEncodeURIComponent as __extendedEncodeURIComponent, +} from "@aws-sdk/smithy-client"; +import { + Endpoint as __Endpoint, + MetadataBearer as __MetadataBearer, + ResponseMetadata as __ResponseMetadata, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export const serializeAws_restJson1DeleteRecordCommand = async ( + input: DeleteRecordCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/FeatureGroup/{FeatureGroupName}"; + if (input.FeatureGroupName !== undefined) { + const labelValue: string = input.FeatureGroupName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: FeatureGroupName."); + } + resolvedPath = resolvedPath.replace("{FeatureGroupName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: FeatureGroupName."); + } + const query: any = { + ...(input.RecordIdentifierValueAsString !== undefined && { + RecordIdentifierValueAsString: input.RecordIdentifierValueAsString, + }), + ...(input.EventTime !== undefined && { EventTime: input.EventTime }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "DELETE", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1GetRecordCommand = async ( + input: GetRecordCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "", + }; + let resolvedPath = "/FeatureGroup/{FeatureGroupName}"; + if (input.FeatureGroupName !== undefined) { + const labelValue: string = input.FeatureGroupName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: FeatureGroupName."); + } + resolvedPath = resolvedPath.replace("{FeatureGroupName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: FeatureGroupName."); + } + const query: any = { + ...(input.RecordIdentifierValueAsString !== undefined && { + RecordIdentifierValueAsString: input.RecordIdentifierValueAsString, + }), + ...(input.FeatureNames !== undefined && { FeatureName: (input.FeatureNames || []).map((_entry) => _entry) }), + }; + let body: any; + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "GET", + headers, + path: resolvedPath, + query, + body, + }); +}; + +export const serializeAws_restJson1PutRecordCommand = async ( + input: PutRecordCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: any = { + "Content-Type": "application/json", + }; + let resolvedPath = "/FeatureGroup/{FeatureGroupName}"; + if (input.FeatureGroupName !== undefined) { + const labelValue: string = input.FeatureGroupName; + if (labelValue.length <= 0) { + throw new Error("Empty value provided for input HTTP label: FeatureGroupName."); + } + resolvedPath = resolvedPath.replace("{FeatureGroupName}", __extendedEncodeURIComponent(labelValue)); + } else { + throw new Error("No value provided for input HTTP label: FeatureGroupName."); + } + let body: any; + body = JSON.stringify({ + ...(input.Record !== undefined && { Record: serializeAws_restJson1Record(input.Record, context) }), + }); + const { hostname, protocol = "https", port } = await context.endpoint(); + return new __HttpRequest({ + protocol, + hostname, + port, + method: "PUT", + headers, + path: resolvedPath, + body, + }); +}; + +export const deserializeAws_restJson1DeleteRecordCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1DeleteRecordCommandError(output, context); + } + const contents: DeleteRecordCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1DeleteRecordCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessForbidden": + case "com.amazonaws.sagemakerfeaturestoreruntime#AccessForbidden": + response = { + ...(await deserializeAws_restJson1AccessForbiddenResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalFailure": + case "com.amazonaws.sagemakerfeaturestoreruntime#InternalFailure": + response = { + ...(await deserializeAws_restJson1InternalFailureResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailable": + case "com.amazonaws.sagemakerfeaturestoreruntime#ServiceUnavailable": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationError": + case "com.amazonaws.sagemakerfeaturestoreruntime#ValidationError": + response = { + ...(await deserializeAws_restJson1ValidationErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1GetRecordCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1GetRecordCommandError(output, context); + } + const contents: GetRecordCommandOutput = { + $metadata: deserializeMetadata(output), + Record: undefined, + }; + const data: any = await parseBody(output.body, context); + if (data.Record !== undefined && data.Record !== null) { + contents.Record = deserializeAws_restJson1Record(data.Record, context); + } + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1GetRecordCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessForbidden": + case "com.amazonaws.sagemakerfeaturestoreruntime#AccessForbidden": + response = { + ...(await deserializeAws_restJson1AccessForbiddenResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalFailure": + case "com.amazonaws.sagemakerfeaturestoreruntime#InternalFailure": + response = { + ...(await deserializeAws_restJson1InternalFailureResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemakerfeaturestoreruntime#ResourceNotFound": + response = { + ...(await deserializeAws_restJson1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailable": + case "com.amazonaws.sagemakerfeaturestoreruntime#ServiceUnavailable": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationError": + case "com.amazonaws.sagemakerfeaturestoreruntime#ValidationError": + response = { + ...(await deserializeAws_restJson1ValidationErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_restJson1PutRecordCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode !== 200 && output.statusCode >= 300) { + return deserializeAws_restJson1PutRecordCommandError(output, context); + } + const contents: PutRecordCommandOutput = { + $metadata: deserializeMetadata(output), + }; + await collectBody(output.body, context); + return Promise.resolve(contents); +}; + +const deserializeAws_restJson1PutRecordCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + errorCode = loadRestJsonErrorCode(output, parsedOutput.body); + switch (errorCode) { + case "AccessForbidden": + case "com.amazonaws.sagemakerfeaturestoreruntime#AccessForbidden": + response = { + ...(await deserializeAws_restJson1AccessForbiddenResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "InternalFailure": + case "com.amazonaws.sagemakerfeaturestoreruntime#InternalFailure": + response = { + ...(await deserializeAws_restJson1InternalFailureResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ServiceUnavailable": + case "com.amazonaws.sagemakerfeaturestoreruntime#ServiceUnavailable": + response = { + ...(await deserializeAws_restJson1ServiceUnavailableResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ValidationError": + case "com.amazonaws.sagemakerfeaturestoreruntime#ValidationError": + response = { + ...(await deserializeAws_restJson1ValidationErrorResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +const deserializeAws_restJson1AccessForbiddenResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: AccessForbidden = { + name: "AccessForbidden", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1InternalFailureResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: InternalFailure = { + name: "InternalFailure", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ResourceNotFoundResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ResourceNotFound = { + name: "ResourceNotFound", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ServiceUnavailableResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ServiceUnavailable = { + name: "ServiceUnavailable", + $fault: "server", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const deserializeAws_restJson1ValidationErrorResponse = async ( + parsedOutput: any, + context: __SerdeContext +): Promise => { + const contents: ValidationError = { + name: "ValidationError", + $fault: "client", + $metadata: deserializeMetadata(parsedOutput), + Message: undefined, + }; + const data: any = parsedOutput.body; + if (data.Message !== undefined && data.Message !== null) { + contents.Message = data.Message; + } + return contents; +}; + +const serializeAws_restJson1FeatureValue = (input: FeatureValue, context: __SerdeContext): any => { + return { + ...(input.FeatureName !== undefined && { FeatureName: input.FeatureName }), + ...(input.ValueAsString !== undefined && { ValueAsString: input.ValueAsString }), + }; +}; + +const serializeAws_restJson1Record = (input: FeatureValue[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_restJson1FeatureValue(entry, context)); +}; + +const deserializeAws_restJson1FeatureValue = (output: any, context: __SerdeContext): FeatureValue => { + return { + FeatureName: output.FeatureName !== undefined && output.FeatureName !== null ? output.FeatureName : undefined, + ValueAsString: + output.ValueAsString !== undefined && output.ValueAsString !== null ? output.ValueAsString : undefined, + } as any; +}; + +const deserializeAws_restJson1Record = (output: any, context: __SerdeContext): FeatureValue[] => { + return (output || []).map((entry: any) => deserializeAws_restJson1FeatureValue(entry, context)); +}; + +const deserializeMetadata = (output: __HttpResponse): __ResponseMetadata => ({ + httpStatusCode: output.statusCode, + httpHeaders: output.headers, + requestId: output.headers["x-amzn-requestid"], +}); + +// Collect low-level response body stream to Uint8Array. +const collectBody = (streamBody: any = new Uint8Array(), context: __SerdeContext): Promise => { + if (streamBody instanceof Uint8Array) { + return Promise.resolve(streamBody); + } + return context.streamCollector(streamBody) || Promise.resolve(new Uint8Array()); +}; + +// Encode Uint8Array data into string with utf-8. +const collectBodyString = (streamBody: any, context: __SerdeContext): Promise => + collectBody(streamBody, context).then((body) => context.utf8Encoder(body)); + +const isSerializableHeaderValue = (value: any): boolean => + value !== undefined && + value !== "" && + (!Object.getOwnPropertyNames(value).includes("length") || value.length != 0) && + (!Object.getOwnPropertyNames(value).includes("size") || value.size != 0); + +const parseBody = (streamBody: any, context: __SerdeContext): any => + collectBodyString(streamBody, context).then((encoded) => { + if (encoded.length) { + return JSON.parse(encoded); + } + return {}; + }); + +/** + * Load an error code for the aws.rest-json-1.1 protocol. + */ +const loadRestJsonErrorCode = (output: __HttpResponse, data: any): string => { + const findKey = (object: any, key: string) => Object.keys(object).find((k) => k.toLowerCase() === key.toLowerCase()); + + const sanitizeErrorCode = (rawValue: string): string => { + let cleanValue = rawValue; + if (cleanValue.indexOf(":") >= 0) { + cleanValue = cleanValue.split(":")[0]; + } + if (cleanValue.indexOf("#") >= 0) { + cleanValue = cleanValue.split("#")[1]; + } + return cleanValue; + }; + + const headerKey = findKey(output.headers, "x-amzn-errortype"); + if (headerKey !== undefined) { + return sanitizeErrorCode(output.headers[headerKey]); + } + + if (data.code !== undefined) { + return sanitizeErrorCode(data.code); + } + + if (data["__type"] !== undefined) { + return sanitizeErrorCode(data["__type"]); + } + + return ""; +}; diff --git a/clients/client-sagemaker-featurestore-runtime/runtimeConfig.browser.ts b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.browser.ts new file mode 100644 index 000000000000..14f48f2b1c9b --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.browser.ts @@ -0,0 +1,34 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-browser"; +import { FetchHttpHandler, streamCollector } from "@aws-sdk/fetch-http-handler"; +import { invalidAsyncFunction } from "@aws-sdk/invalid-dependency"; +import { DEFAULT_MAX_ATTEMPTS } from "@aws-sdk/middleware-retry"; +import { parseUrl } from "@aws-sdk/url-parser-browser"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-browser"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-browser"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-browser"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-browser"; +import { ClientDefaults } from "./SageMakerFeatureStoreRuntimeClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "browser", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider: invalidAsyncFunction("Credentialis missing") as any, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: DEFAULT_MAX_ATTEMPTS, + region: invalidAsyncFunction("Region is missing") as any, + requestHandler: new FetchHttpHandler(), + sha256: Sha256, + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-sagemaker-featurestore-runtime/runtimeConfig.native.ts b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.native.ts new file mode 100644 index 000000000000..ab1868223d04 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.native.ts @@ -0,0 +1,17 @@ +import packageInfo from "./package.json"; + +import { Sha256 } from "@aws-crypto/sha256-js"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { ClientDefaults } from "./SageMakerFeatureStoreRuntimeClient"; +import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...BrowserDefaults, + runtime: "react-native", + defaultUserAgent: `aws-sdk-js-v3-react-native-${packageInfo.name}/${packageInfo.version}`, + sha256: Sha256, + urlParser: parseUrl, +}; diff --git a/clients/client-sagemaker-featurestore-runtime/runtimeConfig.shared.ts b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.shared.ts new file mode 100644 index 000000000000..fa67e5168746 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.shared.ts @@ -0,0 +1,13 @@ +import { defaultRegionInfoProvider } from "./endpoints"; +import { Logger as __Logger } from "@aws-sdk/types"; + +/** + * @internal + */ +export const ClientSharedValues = { + apiVersion: "2020-07-01", + disableHostPrefix: false, + logger: {} as __Logger, + regionInfoProvider: defaultRegionInfoProvider, + signingName: "sagemaker", +}; diff --git a/clients/client-sagemaker-featurestore-runtime/runtimeConfig.ts b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.ts new file mode 100644 index 000000000000..4f8fa9b74adc --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/runtimeConfig.ts @@ -0,0 +1,36 @@ +import packageInfo from "./package.json"; + +import { NODE_REGION_CONFIG_FILE_OPTIONS, NODE_REGION_CONFIG_OPTIONS } from "@aws-sdk/config-resolver"; +import { defaultProvider as credentialDefaultProvider } from "@aws-sdk/credential-provider-node"; +import { Hash } from "@aws-sdk/hash-node"; +import { NODE_MAX_ATTEMPT_CONFIG_OPTIONS } from "@aws-sdk/middleware-retry"; +import { loadConfig as loadNodeConfig } from "@aws-sdk/node-config-provider"; +import { NodeHttpHandler, streamCollector } from "@aws-sdk/node-http-handler"; +import { parseUrl } from "@aws-sdk/url-parser-node"; +import { fromBase64, toBase64 } from "@aws-sdk/util-base64-node"; +import { calculateBodyLength } from "@aws-sdk/util-body-length-node"; +import { defaultUserAgent } from "@aws-sdk/util-user-agent-node"; +import { fromUtf8, toUtf8 } from "@aws-sdk/util-utf8-node"; +import { ClientDefaults } from "./SageMakerFeatureStoreRuntimeClient"; +import { ClientSharedValues } from "./runtimeConfig.shared"; + +/** + * @internal + */ +export const ClientDefaultValues: Required = { + ...ClientSharedValues, + runtime: "node", + base64Decoder: fromBase64, + base64Encoder: toBase64, + bodyLengthChecker: calculateBodyLength, + credentialDefaultProvider, + defaultUserAgent: defaultUserAgent(packageInfo.name, packageInfo.version), + maxAttempts: loadNodeConfig(NODE_MAX_ATTEMPT_CONFIG_OPTIONS), + region: loadNodeConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS), + requestHandler: new NodeHttpHandler(), + sha256: Hash.bind(null, "sha256"), + streamCollector, + urlParser: parseUrl, + utf8Decoder: fromUtf8, + utf8Encoder: toUtf8, +}; diff --git a/clients/client-sagemaker-featurestore-runtime/tsconfig.es.json b/clients/client-sagemaker-featurestore-runtime/tsconfig.es.json new file mode 100644 index 000000000000..30df5d2e6986 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/tsconfig.es.json @@ -0,0 +1,12 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "target": "es5", + "module": "esnext", + "moduleResolution": "node", + "declaration": false, + "declarationDir": null, + "lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], + "outDir": "dist/es" + } +} diff --git a/clients/client-sagemaker-featurestore-runtime/tsconfig.json b/clients/client-sagemaker-featurestore-runtime/tsconfig.json new file mode 100644 index 000000000000..4cf936f614b4 --- /dev/null +++ b/clients/client-sagemaker-featurestore-runtime/tsconfig.json @@ -0,0 +1,31 @@ +{ + "compilerOptions": { + "alwaysStrict": true, + "target": "ES2018", + "module": "commonjs", + "declaration": true, + "strict": true, + "sourceMap": true, + "downlevelIteration": true, + "importHelpers": true, + "noEmitHelpers": true, + "incremental": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "declarationDir": "./types", + "outDir": "dist/cjs" + }, + "typedocOptions": { + "exclude": ["**/node_modules/**", "**/*.spec.ts", "./protocols/*.ts", "./e2e/*.ts", "./endpoints.ts"], + "excludeNotExported": true, + "excludePrivate": true, + "hideGenerator": true, + "ignoreCompilerErrors": true, + "includeDeclarations": true, + "readme": "./README.md", + "mode": "file", + "out": "./docs", + "theme": "minimal", + "plugin": ["@aws-sdk/client-documentation-generator"] + } +} diff --git a/clients/client-sagemaker/SageMaker.ts b/clients/client-sagemaker/SageMaker.ts index 7c85bf10112a..5c81735ed45c 100644 --- a/clients/client-sagemaker/SageMaker.ts +++ b/clients/client-sagemaker/SageMaker.ts @@ -1,10 +1,20 @@ import { SageMakerClient } from "./SageMakerClient"; +import { + AddAssociationCommand, + AddAssociationCommandInput, + AddAssociationCommandOutput, +} from "./commands/AddAssociationCommand"; import { AddTagsCommand, AddTagsCommandInput, AddTagsCommandOutput } from "./commands/AddTagsCommand"; import { AssociateTrialComponentCommand, AssociateTrialComponentCommandInput, AssociateTrialComponentCommandOutput, } from "./commands/AssociateTrialComponentCommand"; +import { + CreateActionCommand, + CreateActionCommandInput, + CreateActionCommandOutput, +} from "./commands/CreateActionCommand"; import { CreateAlgorithmCommand, CreateAlgorithmCommandInput, @@ -16,6 +26,11 @@ import { CreateAppImageConfigCommandInput, CreateAppImageConfigCommandOutput, } from "./commands/CreateAppImageConfigCommand"; +import { + CreateArtifactCommand, + CreateArtifactCommandInput, + CreateArtifactCommandOutput, +} from "./commands/CreateArtifactCommand"; import { CreateAutoMLJobCommand, CreateAutoMLJobCommandInput, @@ -31,6 +46,11 @@ import { CreateCompilationJobCommandInput, CreateCompilationJobCommandOutput, } from "./commands/CreateCompilationJobCommand"; +import { + CreateContextCommand, + CreateContextCommandInput, + CreateContextCommandOutput, +} from "./commands/CreateContextCommand"; import { CreateDomainCommand, CreateDomainCommandInput, @@ -51,6 +71,11 @@ import { CreateExperimentCommandInput, CreateExperimentCommandOutput, } from "./commands/CreateExperimentCommand"; +import { + CreateFeatureGroupCommand, + CreateFeatureGroupCommandInput, + CreateFeatureGroupCommandOutput, +} from "./commands/CreateFeatureGroupCommand"; import { CreateFlowDefinitionCommand, CreateFlowDefinitionCommandInput, @@ -83,6 +108,11 @@ import { CreateModelPackageCommandInput, CreateModelPackageCommandOutput, } from "./commands/CreateModelPackageCommand"; +import { + CreateModelPackageGroupCommand, + CreateModelPackageGroupCommandInput, + CreateModelPackageGroupCommandOutput, +} from "./commands/CreateModelPackageGroupCommand"; import { CreateMonitoringScheduleCommand, CreateMonitoringScheduleCommandInput, @@ -98,6 +128,11 @@ import { CreateNotebookInstanceLifecycleConfigCommandInput, CreateNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/CreateNotebookInstanceLifecycleConfigCommand"; +import { + CreatePipelineCommand, + CreatePipelineCommandInput, + CreatePipelineCommandOutput, +} from "./commands/CreatePipelineCommand"; import { CreatePresignedDomainUrlCommand, CreatePresignedDomainUrlCommandInput, @@ -113,6 +148,11 @@ import { CreateProcessingJobCommandInput, CreateProcessingJobCommandOutput, } from "./commands/CreateProcessingJobCommand"; +import { + CreateProjectCommand, + CreateProjectCommandInput, + CreateProjectCommandOutput, +} from "./commands/CreateProjectCommand"; import { CreateTrainingJobCommand, CreateTrainingJobCommandInput, @@ -144,6 +184,11 @@ import { CreateWorkteamCommandInput, CreateWorkteamCommandOutput, } from "./commands/CreateWorkteamCommand"; +import { + DeleteActionCommand, + DeleteActionCommandInput, + DeleteActionCommandOutput, +} from "./commands/DeleteActionCommand"; import { DeleteAlgorithmCommand, DeleteAlgorithmCommandInput, @@ -155,11 +200,26 @@ import { DeleteAppImageConfigCommandInput, DeleteAppImageConfigCommandOutput, } from "./commands/DeleteAppImageConfigCommand"; +import { + DeleteArtifactCommand, + DeleteArtifactCommandInput, + DeleteArtifactCommandOutput, +} from "./commands/DeleteArtifactCommand"; +import { + DeleteAssociationCommand, + DeleteAssociationCommandInput, + DeleteAssociationCommandOutput, +} from "./commands/DeleteAssociationCommand"; import { DeleteCodeRepositoryCommand, DeleteCodeRepositoryCommandInput, DeleteCodeRepositoryCommandOutput, } from "./commands/DeleteCodeRepositoryCommand"; +import { + DeleteContextCommand, + DeleteContextCommandInput, + DeleteContextCommandOutput, +} from "./commands/DeleteContextCommand"; import { DeleteDomainCommand, DeleteDomainCommandInput, @@ -180,6 +240,11 @@ import { DeleteExperimentCommandInput, DeleteExperimentCommandOutput, } from "./commands/DeleteExperimentCommand"; +import { + DeleteFeatureGroupCommand, + DeleteFeatureGroupCommandInput, + DeleteFeatureGroupCommandOutput, +} from "./commands/DeleteFeatureGroupCommand"; import { DeleteFlowDefinitionCommand, DeleteFlowDefinitionCommandInput, @@ -202,6 +267,16 @@ import { DeleteModelPackageCommandInput, DeleteModelPackageCommandOutput, } from "./commands/DeleteModelPackageCommand"; +import { + DeleteModelPackageGroupCommand, + DeleteModelPackageGroupCommandInput, + DeleteModelPackageGroupCommandOutput, +} from "./commands/DeleteModelPackageGroupCommand"; +import { + DeleteModelPackageGroupPolicyCommand, + DeleteModelPackageGroupPolicyCommandInput, + DeleteModelPackageGroupPolicyCommandOutput, +} from "./commands/DeleteModelPackageGroupPolicyCommand"; import { DeleteMonitoringScheduleCommand, DeleteMonitoringScheduleCommandInput, @@ -217,6 +292,16 @@ import { DeleteNotebookInstanceLifecycleConfigCommandInput, DeleteNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/DeleteNotebookInstanceLifecycleConfigCommand"; +import { + DeletePipelineCommand, + DeletePipelineCommandInput, + DeletePipelineCommandOutput, +} from "./commands/DeletePipelineCommand"; +import { + DeleteProjectCommand, + DeleteProjectCommandInput, + DeleteProjectCommandOutput, +} from "./commands/DeleteProjectCommand"; import { DeleteTagsCommand, DeleteTagsCommandInput, DeleteTagsCommandOutput } from "./commands/DeleteTagsCommand"; import { DeleteTrialCommand, DeleteTrialCommandInput, DeleteTrialCommandOutput } from "./commands/DeleteTrialCommand"; import { @@ -239,6 +324,11 @@ import { DeleteWorkteamCommandInput, DeleteWorkteamCommandOutput, } from "./commands/DeleteWorkteamCommand"; +import { + DescribeActionCommand, + DescribeActionCommandInput, + DescribeActionCommandOutput, +} from "./commands/DescribeActionCommand"; import { DescribeAlgorithmCommand, DescribeAlgorithmCommandInput, @@ -250,6 +340,11 @@ import { DescribeAppImageConfigCommandInput, DescribeAppImageConfigCommandOutput, } from "./commands/DescribeAppImageConfigCommand"; +import { + DescribeArtifactCommand, + DescribeArtifactCommandInput, + DescribeArtifactCommandOutput, +} from "./commands/DescribeArtifactCommand"; import { DescribeAutoMLJobCommand, DescribeAutoMLJobCommandInput, @@ -265,6 +360,11 @@ import { DescribeCompilationJobCommandInput, DescribeCompilationJobCommandOutput, } from "./commands/DescribeCompilationJobCommand"; +import { + DescribeContextCommand, + DescribeContextCommandInput, + DescribeContextCommandOutput, +} from "./commands/DescribeContextCommand"; import { DescribeDomainCommand, DescribeDomainCommandInput, @@ -285,6 +385,11 @@ import { DescribeExperimentCommandInput, DescribeExperimentCommandOutput, } from "./commands/DescribeExperimentCommand"; +import { + DescribeFeatureGroupCommand, + DescribeFeatureGroupCommandInput, + DescribeFeatureGroupCommandOutput, +} from "./commands/DescribeFeatureGroupCommand"; import { DescribeFlowDefinitionCommand, DescribeFlowDefinitionCommandInput, @@ -325,6 +430,11 @@ import { DescribeModelPackageCommandInput, DescribeModelPackageCommandOutput, } from "./commands/DescribeModelPackageCommand"; +import { + DescribeModelPackageGroupCommand, + DescribeModelPackageGroupCommandInput, + DescribeModelPackageGroupCommandOutput, +} from "./commands/DescribeModelPackageGroupCommand"; import { DescribeMonitoringScheduleCommand, DescribeMonitoringScheduleCommandInput, @@ -340,11 +450,31 @@ import { DescribeNotebookInstanceLifecycleConfigCommandInput, DescribeNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/DescribeNotebookInstanceLifecycleConfigCommand"; +import { + DescribePipelineCommand, + DescribePipelineCommandInput, + DescribePipelineCommandOutput, +} from "./commands/DescribePipelineCommand"; +import { + DescribePipelineDefinitionForExecutionCommand, + DescribePipelineDefinitionForExecutionCommandInput, + DescribePipelineDefinitionForExecutionCommandOutput, +} from "./commands/DescribePipelineDefinitionForExecutionCommand"; +import { + DescribePipelineExecutionCommand, + DescribePipelineExecutionCommandInput, + DescribePipelineExecutionCommandOutput, +} from "./commands/DescribePipelineExecutionCommand"; import { DescribeProcessingJobCommand, DescribeProcessingJobCommandInput, DescribeProcessingJobCommandOutput, } from "./commands/DescribeProcessingJobCommand"; +import { + DescribeProjectCommand, + DescribeProjectCommandInput, + DescribeProjectCommandOutput, +} from "./commands/DescribeProjectCommand"; import { DescribeSubscribedWorkteamCommand, DescribeSubscribedWorkteamCommandInput, @@ -385,16 +515,37 @@ import { DescribeWorkteamCommandInput, DescribeWorkteamCommandOutput, } from "./commands/DescribeWorkteamCommand"; +import { + DisableSagemakerServicecatalogPortfolioCommand, + DisableSagemakerServicecatalogPortfolioCommandInput, + DisableSagemakerServicecatalogPortfolioCommandOutput, +} from "./commands/DisableSagemakerServicecatalogPortfolioCommand"; import { DisassociateTrialComponentCommand, DisassociateTrialComponentCommandInput, DisassociateTrialComponentCommandOutput, } from "./commands/DisassociateTrialComponentCommand"; +import { + EnableSagemakerServicecatalogPortfolioCommand, + EnableSagemakerServicecatalogPortfolioCommandInput, + EnableSagemakerServicecatalogPortfolioCommandOutput, +} from "./commands/EnableSagemakerServicecatalogPortfolioCommand"; +import { + GetModelPackageGroupPolicyCommand, + GetModelPackageGroupPolicyCommandInput, + GetModelPackageGroupPolicyCommandOutput, +} from "./commands/GetModelPackageGroupPolicyCommand"; +import { + GetSagemakerServicecatalogPortfolioStatusCommand, + GetSagemakerServicecatalogPortfolioStatusCommandInput, + GetSagemakerServicecatalogPortfolioStatusCommandOutput, +} from "./commands/GetSagemakerServicecatalogPortfolioStatusCommand"; import { GetSearchSuggestionsCommand, GetSearchSuggestionsCommandInput, GetSearchSuggestionsCommandOutput, } from "./commands/GetSearchSuggestionsCommand"; +import { ListActionsCommand, ListActionsCommandInput, ListActionsCommandOutput } from "./commands/ListActionsCommand"; import { ListAlgorithmsCommand, ListAlgorithmsCommandInput, @@ -406,6 +557,16 @@ import { ListAppImageConfigsCommandOutput, } from "./commands/ListAppImageConfigsCommand"; import { ListAppsCommand, ListAppsCommandInput, ListAppsCommandOutput } from "./commands/ListAppsCommand"; +import { + ListArtifactsCommand, + ListArtifactsCommandInput, + ListArtifactsCommandOutput, +} from "./commands/ListArtifactsCommand"; +import { + ListAssociationsCommand, + ListAssociationsCommandInput, + ListAssociationsCommandOutput, +} from "./commands/ListAssociationsCommand"; import { ListAutoMLJobsCommand, ListAutoMLJobsCommandInput, @@ -426,6 +587,11 @@ import { ListCompilationJobsCommandInput, ListCompilationJobsCommandOutput, } from "./commands/ListCompilationJobsCommand"; +import { + ListContextsCommand, + ListContextsCommandInput, + ListContextsCommandOutput, +} from "./commands/ListContextsCommand"; import { ListDomainsCommand, ListDomainsCommandInput, ListDomainsCommandOutput } from "./commands/ListDomainsCommand"; import { ListEndpointConfigsCommand, @@ -442,6 +608,11 @@ import { ListExperimentsCommandInput, ListExperimentsCommandOutput, } from "./commands/ListExperimentsCommand"; +import { + ListFeatureGroupsCommand, + ListFeatureGroupsCommandInput, + ListFeatureGroupsCommandOutput, +} from "./commands/ListFeatureGroupsCommand"; import { ListFlowDefinitionsCommand, ListFlowDefinitionsCommandInput, @@ -473,6 +644,11 @@ import { ListLabelingJobsForWorkteamCommandInput, ListLabelingJobsForWorkteamCommandOutput, } from "./commands/ListLabelingJobsForWorkteamCommand"; +import { + ListModelPackageGroupsCommand, + ListModelPackageGroupsCommandInput, + ListModelPackageGroupsCommandOutput, +} from "./commands/ListModelPackageGroupsCommand"; import { ListModelPackagesCommand, ListModelPackagesCommandInput, @@ -499,11 +675,36 @@ import { ListNotebookInstancesCommandInput, ListNotebookInstancesCommandOutput, } from "./commands/ListNotebookInstancesCommand"; +import { + ListPipelineExecutionStepsCommand, + ListPipelineExecutionStepsCommandInput, + ListPipelineExecutionStepsCommandOutput, +} from "./commands/ListPipelineExecutionStepsCommand"; +import { + ListPipelineExecutionsCommand, + ListPipelineExecutionsCommandInput, + ListPipelineExecutionsCommandOutput, +} from "./commands/ListPipelineExecutionsCommand"; +import { + ListPipelineParametersForExecutionCommand, + ListPipelineParametersForExecutionCommandInput, + ListPipelineParametersForExecutionCommandOutput, +} from "./commands/ListPipelineParametersForExecutionCommand"; +import { + ListPipelinesCommand, + ListPipelinesCommandInput, + ListPipelinesCommandOutput, +} from "./commands/ListPipelinesCommand"; import { ListProcessingJobsCommand, ListProcessingJobsCommandInput, ListProcessingJobsCommandOutput, } from "./commands/ListProcessingJobsCommand"; +import { + ListProjectsCommand, + ListProjectsCommandInput, + ListProjectsCommandOutput, +} from "./commands/ListProjectsCommand"; import { ListSubscribedWorkteamsCommand, ListSubscribedWorkteamsCommandInput, @@ -546,6 +747,11 @@ import { ListWorkteamsCommandInput, ListWorkteamsCommandOutput, } from "./commands/ListWorkteamsCommand"; +import { + PutModelPackageGroupPolicyCommand, + PutModelPackageGroupPolicyCommandInput, + PutModelPackageGroupPolicyCommandOutput, +} from "./commands/PutModelPackageGroupPolicyCommand"; import { RenderUiTemplateCommand, RenderUiTemplateCommandInput, @@ -562,6 +768,11 @@ import { StartNotebookInstanceCommandInput, StartNotebookInstanceCommandOutput, } from "./commands/StartNotebookInstanceCommand"; +import { + StartPipelineExecutionCommand, + StartPipelineExecutionCommandInput, + StartPipelineExecutionCommandOutput, +} from "./commands/StartPipelineExecutionCommand"; import { StopAutoMLJobCommand, StopAutoMLJobCommandInput, @@ -592,6 +803,11 @@ import { StopNotebookInstanceCommandInput, StopNotebookInstanceCommandOutput, } from "./commands/StopNotebookInstanceCommand"; +import { + StopPipelineExecutionCommand, + StopPipelineExecutionCommandInput, + StopPipelineExecutionCommandOutput, +} from "./commands/StopPipelineExecutionCommand"; import { StopProcessingJobCommand, StopProcessingJobCommandInput, @@ -607,16 +823,31 @@ import { StopTransformJobCommandInput, StopTransformJobCommandOutput, } from "./commands/StopTransformJobCommand"; +import { + UpdateActionCommand, + UpdateActionCommandInput, + UpdateActionCommandOutput, +} from "./commands/UpdateActionCommand"; import { UpdateAppImageConfigCommand, UpdateAppImageConfigCommandInput, UpdateAppImageConfigCommandOutput, } from "./commands/UpdateAppImageConfigCommand"; +import { + UpdateArtifactCommand, + UpdateArtifactCommandInput, + UpdateArtifactCommandOutput, +} from "./commands/UpdateArtifactCommand"; import { UpdateCodeRepositoryCommand, UpdateCodeRepositoryCommandInput, UpdateCodeRepositoryCommandOutput, } from "./commands/UpdateCodeRepositoryCommand"; +import { + UpdateContextCommand, + UpdateContextCommandInput, + UpdateContextCommandOutput, +} from "./commands/UpdateContextCommand"; import { UpdateDomainCommand, UpdateDomainCommandInput, @@ -638,6 +869,11 @@ import { UpdateExperimentCommandOutput, } from "./commands/UpdateExperimentCommand"; import { UpdateImageCommand, UpdateImageCommandInput, UpdateImageCommandOutput } from "./commands/UpdateImageCommand"; +import { + UpdateModelPackageCommand, + UpdateModelPackageCommandInput, + UpdateModelPackageCommandOutput, +} from "./commands/UpdateModelPackageCommand"; import { UpdateMonitoringScheduleCommand, UpdateMonitoringScheduleCommandInput, @@ -653,6 +889,16 @@ import { UpdateNotebookInstanceLifecycleConfigCommandInput, UpdateNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/UpdateNotebookInstanceLifecycleConfigCommand"; +import { + UpdatePipelineCommand, + UpdatePipelineCommandInput, + UpdatePipelineCommandOutput, +} from "./commands/UpdatePipelineCommand"; +import { + UpdatePipelineExecutionCommand, + UpdatePipelineExecutionCommandInput, + UpdatePipelineExecutionCommandOutput, +} from "./commands/UpdatePipelineExecutionCommand"; import { UpdateTrialCommand, UpdateTrialCommandInput, UpdateTrialCommandOutput } from "./commands/UpdateTrialCommand"; import { UpdateTrialComponentCommand, @@ -695,6 +941,42 @@ import { HttpHandlerOptions as __HttpHandlerOptions } from "@aws-sdk/types"; *
    */ export class SageMaker extends SageMakerClient { + /** + *

    Creates an association between the source and the destination. A + * source can be associated with multiple destinations, and a destination can be associated + * with multiple sources. An association is a lineage tracking entity. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ + public addAssociation( + args: AddAssociationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public addAssociation( + args: AddAssociationCommandInput, + cb: (err: any, data?: AddAssociationCommandOutput) => void + ): void; + public addAssociation( + args: AddAssociationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: AddAssociationCommandOutput) => void + ): void; + public addAssociation( + args: AddAssociationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: AddAssociationCommandOutput) => void), + cb?: (err: any, data?: AddAssociationCommandOutput) => void + ): Promise | void { + const command = new AddAssociationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Adds or overwrites one or more tags for the specified Amazon SageMaker resource. You can add * tags to notebook instances, training jobs, hyperparameter tuning jobs, batch transform @@ -770,6 +1052,39 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates an action. An action is a lineage tracking entity that + * represents an action or activity. For example, a model deployment or an HPO job. + * Generally, an action involves at least one input or output artifact. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ + public createAction( + args: CreateActionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createAction(args: CreateActionCommandInput, cb: (err: any, data?: CreateActionCommandOutput) => void): void; + public createAction( + args: CreateActionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateActionCommandOutput) => void + ): void; + public createAction( + args: CreateActionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateActionCommandOutput) => void), + cb?: (err: any, data?: CreateActionCommandOutput) => void + ): Promise | void { + const command = new CreateActionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Create a machine learning algorithm that you can use in Amazon SageMaker and list in the AWS * Marketplace.

    @@ -868,6 +1183,42 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates an artifact. An artifact is a lineage tracking entity that + * represents a URI addressable object or data. Some examples are the S3 URI of a dataset and + * the ECR registry path of an image. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ + public createArtifact( + args: CreateArtifactCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createArtifact( + args: CreateArtifactCommandInput, + cb: (err: any, data?: CreateArtifactCommandOutput) => void + ): void; + public createArtifact( + args: CreateArtifactCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateArtifactCommandOutput) => void + ): void; + public createArtifact( + args: CreateArtifactCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateArtifactCommandOutput) => void), + cb?: (err: any, data?: CreateArtifactCommandOutput) => void + ): Promise | void { + const command = new CreateArtifactCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates an Autopilot job.

    *

    Find the best performing model after you run an Autopilot job by calling . Deploy that model by following the steps described in @@ -1006,14 +1357,60 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates a context. A context is a lineage tracking entity that + * represents a logical grouping of other tracking or experiment entities. Some examples are + * an endpoint and a model package. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ + public createContext( + args: CreateContextCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createContext( + args: CreateContextCommandInput, + cb: (err: any, data?: CreateContextCommandOutput) => void + ): void; + public createContext( + args: CreateContextCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateContextCommandOutput) => void + ): void; + public createContext( + args: CreateContextCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateContextCommandOutput) => void), + cb?: (err: any, data?: CreateContextCommandOutput) => void + ): Promise | void { + const command = new CreateContextCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates a Domain used by Amazon SageMaker Studio. A domain consists of an associated * Amazon Elastic File System (EFS) volume, a list of authorized users, and a variety of security, application, * policy, and Amazon Virtual Private Cloud (VPC) configurations. An AWS account is limited to one domain per region. * Users within a domain can share notebook files and other artifacts with each other.

    + * + *

    + * EFS storage + *

    *

    When a domain is created, an EFS volume is created for use by all of the users within the * domain. Each user receives a private home directory within the EFS volume for notebooks, * Git repositories, and data files.

    + *

    SageMaker uses the AWS Key Management Service (AWS KMS) to encrypt the EFS volume attached to the domain with + * an AWS managed customer master key (CMK) by default. For more control, you can specify a + * customer managed CMK. For more information, see + * Protect Data at + * Rest Using Encryption.

    + * *

    * VPC configuration *

    @@ -1288,6 +1685,50 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Create a new FeatureGroup. A FeatureGroup is a group of + * Features defined in the FeatureStore to describe a + * Record.

    + *

    The FeatureGroup defines the schema and features contained in the + * FeatureGroup. A FeatureGroup definition is composed of a list of + * Features, a RecordIdentifierFeatureName, an + * EventTimeFeatureName and configurations for its OnlineStore + * and OfflineStore. Check AWS service quotas to see + * the FeatureGroups quota for your AWS account.

    + * + *

    You must include at least one of OnlineStoreConfig and + * OfflineStoreConfig to create a FeatureGroup.

    + *
    + */ + public createFeatureGroup( + args: CreateFeatureGroupCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createFeatureGroup( + args: CreateFeatureGroupCommandInput, + cb: (err: any, data?: CreateFeatureGroupCommandOutput) => void + ): void; + public createFeatureGroup( + args: CreateFeatureGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateFeatureGroupCommandOutput) => void + ): void; + public createFeatureGroup( + args: CreateFeatureGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateFeatureGroupCommandOutput) => void), + cb?: (err: any, data?: CreateFeatureGroupCommandOutput) => void + ): Promise | void { + const command = new CreateFeatureGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates a flow definition.

    */ @@ -1562,13 +2003,24 @@ export class SageMaker extends SageMakerClient { /** *

    Creates a model package that you can use to create Amazon SageMaker models or list on AWS - * Marketplace. Buyers can subscribe to model packages listed on AWS Marketplace to create + * Marketplace, or a versioned model that is part of a model group. Buyers can subscribe to model packages listed on AWS Marketplace to create * models in Amazon SageMaker.

    *

    To create a model package by specifying a Docker container that contains your * inference code and the Amazon S3 location of your model artifacts, provide values for * InferenceSpecification. To create a model from an algorithm resource * that you created or subscribed to in AWS Marketplace, provide a value for * SourceAlgorithmSpecification.

    + * + *

    There are two types of model packages:

    + *
      + *
    • + *

      Versioned - a model that is part of a model group in the model registry.

      + *
    • + *
    • + *

      Unversioned - a model package that is not part of a model group.

      + *
    • + *
    + *
    */ public createModelPackage( args: CreateModelPackageCommandInput, @@ -1599,6 +2051,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates a model group. A model group contains a group of model versions.

    + */ + public createModelPackageGroup( + args: CreateModelPackageGroupCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createModelPackageGroup( + args: CreateModelPackageGroupCommandInput, + cb: (err: any, data?: CreateModelPackageGroupCommandOutput) => void + ): void; + public createModelPackageGroup( + args: CreateModelPackageGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateModelPackageGroupCommandOutput) => void + ): void; + public createModelPackageGroup( + args: CreateModelPackageGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateModelPackageGroupCommandOutput) => void), + cb?: (err: any, data?: CreateModelPackageGroupCommandOutput) => void + ): Promise | void { + const command = new CreateModelPackageGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates a schedule that regularly starts Amazon SageMaker Processing Jobs to monitor the data * captured for an Amazon SageMaker Endoint.

    @@ -1747,6 +2231,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates a pipeline using a JSON pipeline definition.

    + */ + public createPipeline( + args: CreatePipelineCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createPipeline( + args: CreatePipelineCommandInput, + cb: (err: any, data?: CreatePipelineCommandOutput) => void + ): void; + public createPipeline( + args: CreatePipelineCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreatePipelineCommandOutput) => void + ): void; + public createPipeline( + args: CreatePipelineCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreatePipelineCommandOutput) => void), + cb?: (err: any, data?: CreatePipelineCommandOutput) => void + ): Promise | void { + const command = new CreatePipelineCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Creates a URL for a specified UserProfile in a Domain. When accessed in a web browser, * the user will be automatically signed in to Amazon SageMaker Studio, and granted access to all of @@ -1869,13 +2385,46 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Creates a machine learning (ML) project that can contain one or more templates that set + * up an ML pipeline from training to deploying an approved model.

    + */ + public createProject( + args: CreateProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public createProject( + args: CreateProjectCommandInput, + cb: (err: any, data?: CreateProjectCommandOutput) => void + ): void; + public createProject( + args: CreateProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: CreateProjectCommandOutput) => void + ): void; + public createProject( + args: CreateProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: CreateProjectCommandOutput) => void), + cb?: (err: any, data?: CreateProjectCommandOutput) => void + ): Promise | void { + const command = new CreateProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Starts a model training job. After training completes, Amazon SageMaker saves the resulting * model artifacts to an Amazon S3 location that you specify.

    - *

    If you choose to host your model using Amazon SageMaker hosting services, you can use the - * resulting model artifacts as part of the model. You can also use the artifacts in a - * machine learning service other than Amazon SageMaker, provided that you know how to use them for - * inferences. + *

    If you choose to host your model using Amazon SageMaker hosting services, you can use the resulting + * model artifacts as part of the model. You can also use the artifacts in a machine + * learning service other than Amazon SageMaker, provided that you know how to use them for + * inference. * *

    *

    In the request body, you provide the following:

    @@ -1920,7 +2469,7 @@ export class SageMaker extends SageMakerClient { * *
  • *

    - * RoleARN - The Amazon Resource Number (ARN) that Amazon SageMaker assumes + * RoleArn - The Amazon Resource Number (ARN) that Amazon SageMaker assumes * to perform tasks on your behalf during model training. * * You must grant this role the necessary permissions so that Amazon SageMaker can successfully @@ -2240,6 +2789,35 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Deletes an action.

    + */ + public deleteAction( + args: DeleteActionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteAction(args: DeleteActionCommandInput, cb: (err: any, data?: DeleteActionCommandOutput) => void): void; + public deleteAction( + args: DeleteActionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteActionCommandOutput) => void + ): void; + public deleteAction( + args: DeleteActionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteActionCommandOutput) => void), + cb?: (err: any, data?: DeleteActionCommandOutput) => void + ): Promise | void { + const command = new DeleteActionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Removes the specified algorithm from your account.

    */ @@ -2330,6 +2908,71 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Deletes an artifact. Either ArtifactArn or Source must be + * specified.

    + */ + public deleteArtifact( + args: DeleteArtifactCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteArtifact( + args: DeleteArtifactCommandInput, + cb: (err: any, data?: DeleteArtifactCommandOutput) => void + ): void; + public deleteArtifact( + args: DeleteArtifactCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteArtifactCommandOutput) => void + ): void; + public deleteArtifact( + args: DeleteArtifactCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteArtifactCommandOutput) => void), + cb?: (err: any, data?: DeleteArtifactCommandOutput) => void + ): Promise | void { + const command = new DeleteArtifactCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes an association.

    + */ + public deleteAssociation( + args: DeleteAssociationCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteAssociation( + args: DeleteAssociationCommandInput, + cb: (err: any, data?: DeleteAssociationCommandOutput) => void + ): void; + public deleteAssociation( + args: DeleteAssociationCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteAssociationCommandOutput) => void + ): void; + public deleteAssociation( + args: DeleteAssociationCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteAssociationCommandOutput) => void), + cb?: (err: any, data?: DeleteAssociationCommandOutput) => void + ): Promise | void { + const command = new DeleteAssociationCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Deletes the specified Git repository from your account.

    */ @@ -2362,6 +3005,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Deletes an context.

    + */ + public deleteContext( + args: DeleteContextCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteContext( + args: DeleteContextCommandInput, + cb: (err: any, data?: DeleteContextCommandOutput) => void + ): void; + public deleteContext( + args: DeleteContextCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteContextCommandOutput) => void + ): void; + public deleteContext( + args: DeleteContextCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteContextCommandOutput) => void), + cb?: (err: any, data?: DeleteContextCommandOutput) => void + ): Promise | void { + const command = new DeleteContextCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Used to delete a domain. * If you onboarded with IAM mode, you will need to delete your domain to onboard again using SSO. @@ -2505,12 +3180,49 @@ export class SageMaker extends SageMakerClient { } /** - *

    Deletes the specified flow definition.

    + *

    Delete the FeatureGroup and any data that was written to the + * OnlineStore of the FeatureGroup. Data cannot be accessed from + * the OnlineStore immediately after DeleteFeatureGroup is called.

    + *

    Data written into the OfflineStore will not be deleted. The AWS Glue + * database and tables that are automatically created for your OfflineStore are + * not deleted.

    */ - public deleteFlowDefinition( - args: DeleteFlowDefinitionCommandInput, + public deleteFeatureGroup( + args: DeleteFeatureGroupCommandInput, options?: __HttpHandlerOptions - ): Promise; + ): Promise; + public deleteFeatureGroup( + args: DeleteFeatureGroupCommandInput, + cb: (err: any, data?: DeleteFeatureGroupCommandOutput) => void + ): void; + public deleteFeatureGroup( + args: DeleteFeatureGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteFeatureGroupCommandOutput) => void + ): void; + public deleteFeatureGroup( + args: DeleteFeatureGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteFeatureGroupCommandOutput) => void), + cb?: (err: any, data?: DeleteFeatureGroupCommandOutput) => void + ): Promise | void { + const command = new DeleteFeatureGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes the specified flow definition.

    + */ + public deleteFlowDefinition( + args: DeleteFlowDefinitionCommandInput, + options?: __HttpHandlerOptions + ): Promise; public deleteFlowDefinition( args: DeleteFlowDefinitionCommandInput, cb: (err: any, data?: DeleteFlowDefinitionCommandOutput) => void @@ -2695,6 +3407,70 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Deletes the specified model group.

    + */ + public deleteModelPackageGroup( + args: DeleteModelPackageGroupCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteModelPackageGroup( + args: DeleteModelPackageGroupCommandInput, + cb: (err: any, data?: DeleteModelPackageGroupCommandOutput) => void + ): void; + public deleteModelPackageGroup( + args: DeleteModelPackageGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteModelPackageGroupCommandOutput) => void + ): void; + public deleteModelPackageGroup( + args: DeleteModelPackageGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteModelPackageGroupCommandOutput) => void), + cb?: (err: any, data?: DeleteModelPackageGroupCommandOutput) => void + ): Promise | void { + const command = new DeleteModelPackageGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Deletes a model group resource policy.

    + */ + public deleteModelPackageGroupPolicy( + args: DeleteModelPackageGroupPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteModelPackageGroupPolicy( + args: DeleteModelPackageGroupPolicyCommandInput, + cb: (err: any, data?: DeleteModelPackageGroupPolicyCommandOutput) => void + ): void; + public deleteModelPackageGroupPolicy( + args: DeleteModelPackageGroupPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteModelPackageGroupPolicyCommandOutput) => void + ): void; + public deleteModelPackageGroupPolicy( + args: DeleteModelPackageGroupPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteModelPackageGroupPolicyCommandOutput) => void), + cb?: (err: any, data?: DeleteModelPackageGroupPolicyCommandOutput) => void + ): Promise | void { + const command = new DeleteModelPackageGroupPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Deletes a monitoring schedule. Also stops the schedule had not already been stopped. * This does not delete the job execution history of the monitoring schedule.

    @@ -2800,6 +3576,70 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Deletes a pipeline.

    + */ + public deletePipeline( + args: DeletePipelineCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deletePipeline( + args: DeletePipelineCommandInput, + cb: (err: any, data?: DeletePipelineCommandOutput) => void + ): void; + public deletePipeline( + args: DeletePipelineCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeletePipelineCommandOutput) => void + ): void; + public deletePipeline( + args: DeletePipelineCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeletePipelineCommandOutput) => void), + cb?: (err: any, data?: DeletePipelineCommandOutput) => void + ): Promise | void { + const command = new DeletePipelineCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Delete the specified project.

    + */ + public deleteProject( + args: DeleteProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public deleteProject( + args: DeleteProjectCommandInput, + cb: (err: any, data?: DeleteProjectCommandOutput) => void + ): void; + public deleteProject( + args: DeleteProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DeleteProjectCommandOutput) => void + ): void; + public deleteProject( + args: DeleteProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DeleteProjectCommandOutput) => void), + cb?: (err: any, data?: DeleteProjectCommandOutput) => void + ): Promise | void { + const command = new DeleteProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Deletes the specified tags from an Amazon SageMaker resource.

    *

    To list a resource's tags, use the ListTags API.

    @@ -3003,6 +3843,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Describes an action.

    + */ + public describeAction( + args: DescribeActionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeAction( + args: DescribeActionCommandInput, + cb: (err: any, data?: DescribeActionCommandOutput) => void + ): void; + public describeAction( + args: DescribeActionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeActionCommandOutput) => void + ): void; + public describeAction( + args: DescribeActionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeActionCommandOutput) => void), + cb?: (err: any, data?: DescribeActionCommandOutput) => void + ): Promise | void { + const command = new DescribeActionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns a description of the specified algorithm that is in your account.

    */ @@ -3093,6 +3965,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Describes an artifact.

    + */ + public describeArtifact( + args: DescribeArtifactCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeArtifact( + args: DescribeArtifactCommandInput, + cb: (err: any, data?: DescribeArtifactCommandOutput) => void + ): void; + public describeArtifact( + args: DescribeArtifactCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeArtifactCommandOutput) => void + ): void; + public describeArtifact( + args: DescribeArtifactCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeArtifactCommandOutput) => void), + cb?: (err: any, data?: DescribeArtifactCommandOutput) => void + ): Promise | void { + const command = new DescribeArtifactCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns information about an Amazon SageMaker job.

    */ @@ -3191,6 +4095,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Describes a context.

    + */ + public describeContext( + args: DescribeContextCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeContext( + args: DescribeContextCommandInput, + cb: (err: any, data?: DescribeContextCommandOutput) => void + ): void; + public describeContext( + args: DescribeContextCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeContextCommandOutput) => void + ): void; + public describeContext( + args: DescribeContextCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeContextCommandOutput) => void), + cb?: (err: any, data?: DescribeContextCommandOutput) => void + ): Promise | void { + const command = new DescribeContextCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    The description of the domain.

    */ @@ -3320,6 +4256,40 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Use this operation to describe a FeatureGroup. The response includes + * information on the creation time, FeatureGroup name, the unique identifier for + * each FeatureGroup, and more.

    + */ + public describeFeatureGroup( + args: DescribeFeatureGroupCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeFeatureGroup( + args: DescribeFeatureGroupCommandInput, + cb: (err: any, data?: DescribeFeatureGroupCommandOutput) => void + ): void; + public describeFeatureGroup( + args: DescribeFeatureGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeFeatureGroupCommandOutput) => void + ): void; + public describeFeatureGroup( + args: DescribeFeatureGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeFeatureGroupCommandOutput) => void), + cb?: (err: any, data?: DescribeFeatureGroupCommandOutput) => void + ): Promise | void { + const command = new DescribeFeatureGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns information about the specified flow definition.

    */ @@ -3581,6 +4551,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Gets a description for the specified model group.

    + */ + public describeModelPackageGroup( + args: DescribeModelPackageGroupCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeModelPackageGroup( + args: DescribeModelPackageGroupCommandInput, + cb: (err: any, data?: DescribeModelPackageGroupCommandOutput) => void + ): void; + public describeModelPackageGroup( + args: DescribeModelPackageGroupCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeModelPackageGroupCommandOutput) => void + ): void; + public describeModelPackageGroup( + args: DescribeModelPackageGroupCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeModelPackageGroupCommandOutput) => void), + cb?: (err: any, data?: DescribeModelPackageGroupCommandOutput) => void + ): Promise | void { + const command = new DescribeModelPackageGroupCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Describes the schedule for a monitoring job.

    */ @@ -3681,6 +4683,104 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Describes the details of a pipeline.

    + */ + public describePipeline( + args: DescribePipelineCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describePipeline( + args: DescribePipelineCommandInput, + cb: (err: any, data?: DescribePipelineCommandOutput) => void + ): void; + public describePipeline( + args: DescribePipelineCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribePipelineCommandOutput) => void + ): void; + public describePipeline( + args: DescribePipelineCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribePipelineCommandOutput) => void), + cb?: (err: any, data?: DescribePipelineCommandOutput) => void + ): Promise | void { + const command = new DescribePipelineCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Describes the details of an execution's pipeline definition.

    + */ + public describePipelineDefinitionForExecution( + args: DescribePipelineDefinitionForExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describePipelineDefinitionForExecution( + args: DescribePipelineDefinitionForExecutionCommandInput, + cb: (err: any, data?: DescribePipelineDefinitionForExecutionCommandOutput) => void + ): void; + public describePipelineDefinitionForExecution( + args: DescribePipelineDefinitionForExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribePipelineDefinitionForExecutionCommandOutput) => void + ): void; + public describePipelineDefinitionForExecution( + args: DescribePipelineDefinitionForExecutionCommandInput, + optionsOrCb?: + | __HttpHandlerOptions + | ((err: any, data?: DescribePipelineDefinitionForExecutionCommandOutput) => void), + cb?: (err: any, data?: DescribePipelineDefinitionForExecutionCommandOutput) => void + ): Promise | void { + const command = new DescribePipelineDefinitionForExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Describes the details of a pipeline execution.

    + */ + public describePipelineExecution( + args: DescribePipelineExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describePipelineExecution( + args: DescribePipelineExecutionCommandInput, + cb: (err: any, data?: DescribePipelineExecutionCommandOutput) => void + ): void; + public describePipelineExecution( + args: DescribePipelineExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribePipelineExecutionCommandOutput) => void + ): void; + public describePipelineExecution( + args: DescribePipelineExecutionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribePipelineExecutionCommandOutput) => void), + cb?: (err: any, data?: DescribePipelineExecutionCommandOutput) => void + ): Promise | void { + const command = new DescribePipelineExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns a description of a processing job.

    */ @@ -3713,6 +4813,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Describes the details of a project.

    + */ + public describeProject( + args: DescribeProjectCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public describeProject( + args: DescribeProjectCommandInput, + cb: (err: any, data?: DescribeProjectCommandOutput) => void + ): void; + public describeProject( + args: DescribeProjectCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DescribeProjectCommandOutput) => void + ): void; + public describeProject( + args: DescribeProjectCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: DescribeProjectCommandOutput) => void), + cb?: (err: any, data?: DescribeProjectCommandOutput) => void + ): Promise | void { + const command = new DescribeProjectCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Gets information about a work team provided by a vendor. It returns details about the * subscription with a vendor in the AWS Marketplace.

    @@ -3977,6 +5109,41 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Disables using Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ + public disableSagemakerServicecatalogPortfolio( + args: DisableSagemakerServicecatalogPortfolioCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public disableSagemakerServicecatalogPortfolio( + args: DisableSagemakerServicecatalogPortfolioCommandInput, + cb: (err: any, data?: DisableSagemakerServicecatalogPortfolioCommandOutput) => void + ): void; + public disableSagemakerServicecatalogPortfolio( + args: DisableSagemakerServicecatalogPortfolioCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: DisableSagemakerServicecatalogPortfolioCommandOutput) => void + ): void; + public disableSagemakerServicecatalogPortfolio( + args: DisableSagemakerServicecatalogPortfolioCommandInput, + optionsOrCb?: + | __HttpHandlerOptions + | ((err: any, data?: DisableSagemakerServicecatalogPortfolioCommandOutput) => void), + cb?: (err: any, data?: DisableSagemakerServicecatalogPortfolioCommandOutput) => void + ): Promise | void { + const command = new DisableSagemakerServicecatalogPortfolioCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Disassociates a trial component from a trial. This doesn't effect other trials the * component is associated with. Before you can delete a component, you must disassociate the @@ -4014,6 +5181,111 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Enables using Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ + public enableSagemakerServicecatalogPortfolio( + args: EnableSagemakerServicecatalogPortfolioCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public enableSagemakerServicecatalogPortfolio( + args: EnableSagemakerServicecatalogPortfolioCommandInput, + cb: (err: any, data?: EnableSagemakerServicecatalogPortfolioCommandOutput) => void + ): void; + public enableSagemakerServicecatalogPortfolio( + args: EnableSagemakerServicecatalogPortfolioCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: EnableSagemakerServicecatalogPortfolioCommandOutput) => void + ): void; + public enableSagemakerServicecatalogPortfolio( + args: EnableSagemakerServicecatalogPortfolioCommandInput, + optionsOrCb?: + | __HttpHandlerOptions + | ((err: any, data?: EnableSagemakerServicecatalogPortfolioCommandOutput) => void), + cb?: (err: any, data?: EnableSagemakerServicecatalogPortfolioCommandOutput) => void + ): Promise | void { + const command = new EnableSagemakerServicecatalogPortfolioCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Gets a resource policy that manages access for a model group. For information about + * resource policies, see Identity-based + * policies and resource-based policies in the AWS Identity and + * Access Management User Guide..

    + */ + public getModelPackageGroupPolicy( + args: GetModelPackageGroupPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getModelPackageGroupPolicy( + args: GetModelPackageGroupPolicyCommandInput, + cb: (err: any, data?: GetModelPackageGroupPolicyCommandOutput) => void + ): void; + public getModelPackageGroupPolicy( + args: GetModelPackageGroupPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetModelPackageGroupPolicyCommandOutput) => void + ): void; + public getModelPackageGroupPolicy( + args: GetModelPackageGroupPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: GetModelPackageGroupPolicyCommandOutput) => void), + cb?: (err: any, data?: GetModelPackageGroupPolicyCommandOutput) => void + ): Promise | void { + const command = new GetModelPackageGroupPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Gets the status of Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ + public getSagemakerServicecatalogPortfolioStatus( + args: GetSagemakerServicecatalogPortfolioStatusCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public getSagemakerServicecatalogPortfolioStatus( + args: GetSagemakerServicecatalogPortfolioStatusCommandInput, + cb: (err: any, data?: GetSagemakerServicecatalogPortfolioStatusCommandOutput) => void + ): void; + public getSagemakerServicecatalogPortfolioStatus( + args: GetSagemakerServicecatalogPortfolioStatusCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: GetSagemakerServicecatalogPortfolioStatusCommandOutput) => void + ): void; + public getSagemakerServicecatalogPortfolioStatus( + args: GetSagemakerServicecatalogPortfolioStatusCommandInput, + optionsOrCb?: + | __HttpHandlerOptions + | ((err: any, data?: GetSagemakerServicecatalogPortfolioStatusCommandOutput) => void), + cb?: (err: any, data?: GetSagemakerServicecatalogPortfolioStatusCommandOutput) => void + ): Promise | void { + const command = new GetSagemakerServicecatalogPortfolioStatusCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    An auto-complete API for the search functionality in the Amazon SageMaker console. It returns * suggestions of possible matches for the property name to use in Search @@ -4049,6 +5321,32 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Lists the actions in your account and their properties.

    + */ + public listActions(args: ListActionsCommandInput, options?: __HttpHandlerOptions): Promise; + public listActions(args: ListActionsCommandInput, cb: (err: any, data?: ListActionsCommandOutput) => void): void; + public listActions( + args: ListActionsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListActionsCommandOutput) => void + ): void; + public listActions( + args: ListActionsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListActionsCommandOutput) => void), + cb?: (err: any, data?: ListActionsCommandOutput) => void + ): Promise | void { + const command = new ListActionsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Lists the machine learning algorithms that have been created.

    */ @@ -4141,6 +5439,70 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Lists the artifacts in your account and their properties.

    + */ + public listArtifacts( + args: ListArtifactsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listArtifacts( + args: ListArtifactsCommandInput, + cb: (err: any, data?: ListArtifactsCommandOutput) => void + ): void; + public listArtifacts( + args: ListArtifactsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListArtifactsCommandOutput) => void + ): void; + public listArtifacts( + args: ListArtifactsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListArtifactsCommandOutput) => void), + cb?: (err: any, data?: ListArtifactsCommandOutput) => void + ): Promise | void { + const command = new ListArtifactsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Lists the associations in your account and their properties.

    + */ + public listAssociations( + args: ListAssociationsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listAssociations( + args: ListAssociationsCommandInput, + cb: (err: any, data?: ListAssociationsCommandOutput) => void + ): void; + public listAssociations( + args: ListAssociationsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListAssociationsCommandOutput) => void + ): void; + public listAssociations( + args: ListAssociationsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListAssociationsCommandOutput) => void), + cb?: (err: any, data?: ListAssociationsCommandOutput) => void + ): Promise | void { + const command = new ListAssociationsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Request a list of jobs.

    */ @@ -4271,6 +5633,35 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Lists the contexts in your account and their properties.

    + */ + public listContexts( + args: ListContextsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listContexts(args: ListContextsCommandInput, cb: (err: any, data?: ListContextsCommandOutput) => void): void; + public listContexts( + args: ListContextsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListContextsCommandOutput) => void + ): void; + public listContexts( + args: ListContextsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListContextsCommandOutput) => void), + cb?: (err: any, data?: ListContextsCommandOutput) => void + ): Promise | void { + const command = new ListContextsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Lists the domains.

    */ @@ -4395,6 +5786,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    List FeatureGroups based on given filter and order.

    + */ + public listFeatureGroups( + args: ListFeatureGroupsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listFeatureGroups( + args: ListFeatureGroupsCommandInput, + cb: (err: any, data?: ListFeatureGroupsCommandOutput) => void + ): void; + public listFeatureGroups( + args: ListFeatureGroupsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListFeatureGroupsCommandOutput) => void + ): void; + public listFeatureGroups( + args: ListFeatureGroupsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListFeatureGroupsCommandOutput) => void), + cb?: (err: any, data?: ListFeatureGroupsCommandOutput) => void + ): Promise | void { + const command = new ListFeatureGroupsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Returns information about the flow definitions in your account.

    */ @@ -4617,6 +6040,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Gets a list of the model groups in your AWS account.

    + */ + public listModelPackageGroups( + args: ListModelPackageGroupsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listModelPackageGroups( + args: ListModelPackageGroupsCommandInput, + cb: (err: any, data?: ListModelPackageGroupsCommandOutput) => void + ): void; + public listModelPackageGroups( + args: ListModelPackageGroupsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListModelPackageGroupsCommandOutput) => void + ): void; + public listModelPackageGroups( + args: ListModelPackageGroupsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListModelPackageGroupsCommandOutput) => void), + cb?: (err: any, data?: ListModelPackageGroupsCommandOutput) => void + ): Promise | void { + const command = new ListModelPackageGroupsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Lists the model packages that have been created.

    */ @@ -4804,6 +6259,134 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Gets a list of the pipeline executions.

    + */ + public listPipelineExecutions( + args: ListPipelineExecutionsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listPipelineExecutions( + args: ListPipelineExecutionsCommandInput, + cb: (err: any, data?: ListPipelineExecutionsCommandOutput) => void + ): void; + public listPipelineExecutions( + args: ListPipelineExecutionsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListPipelineExecutionsCommandOutput) => void + ): void; + public listPipelineExecutions( + args: ListPipelineExecutionsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListPipelineExecutionsCommandOutput) => void), + cb?: (err: any, data?: ListPipelineExecutionsCommandOutput) => void + ): Promise | void { + const command = new ListPipelineExecutionsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Gets a list of PipeLineExecutionStep objects.

    + */ + public listPipelineExecutionSteps( + args: ListPipelineExecutionStepsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listPipelineExecutionSteps( + args: ListPipelineExecutionStepsCommandInput, + cb: (err: any, data?: ListPipelineExecutionStepsCommandOutput) => void + ): void; + public listPipelineExecutionSteps( + args: ListPipelineExecutionStepsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListPipelineExecutionStepsCommandOutput) => void + ): void; + public listPipelineExecutionSteps( + args: ListPipelineExecutionStepsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListPipelineExecutionStepsCommandOutput) => void), + cb?: (err: any, data?: ListPipelineExecutionStepsCommandOutput) => void + ): Promise | void { + const command = new ListPipelineExecutionStepsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Gets a list of parameters for a pipeline execution.

    + */ + public listPipelineParametersForExecution( + args: ListPipelineParametersForExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listPipelineParametersForExecution( + args: ListPipelineParametersForExecutionCommandInput, + cb: (err: any, data?: ListPipelineParametersForExecutionCommandOutput) => void + ): void; + public listPipelineParametersForExecution( + args: ListPipelineParametersForExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListPipelineParametersForExecutionCommandOutput) => void + ): void; + public listPipelineParametersForExecution( + args: ListPipelineParametersForExecutionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListPipelineParametersForExecutionCommandOutput) => void), + cb?: (err: any, data?: ListPipelineParametersForExecutionCommandOutput) => void + ): Promise | void { + const command = new ListPipelineParametersForExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Gets a list of pipelines.

    + */ + public listPipelines( + args: ListPipelinesCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listPipelines( + args: ListPipelinesCommandInput, + cb: (err: any, data?: ListPipelinesCommandOutput) => void + ): void; + public listPipelines( + args: ListPipelinesCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListPipelinesCommandOutput) => void + ): void; + public listPipelines( + args: ListPipelinesCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListPipelinesCommandOutput) => void), + cb?: (err: any, data?: ListPipelinesCommandOutput) => void + ): Promise | void { + const command = new ListPipelinesCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Lists processing jobs that satisfy various filters.

    */ @@ -4836,6 +6419,35 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Gets a list of the projects in an AWS account.

    + */ + public listProjects( + args: ListProjectsCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public listProjects(args: ListProjectsCommandInput, cb: (err: any, data?: ListProjectsCommandOutput) => void): void; + public listProjects( + args: ListProjectsCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: ListProjectsCommandOutput) => void + ): void; + public listProjects( + args: ListProjectsCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: ListProjectsCommandOutput) => void), + cb?: (err: any, data?: ListProjectsCommandOutput) => void + ): Promise | void { + const command = new ListProjectsCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Gets a list of the work teams that you are subscribed to in the AWS Marketplace. The * list may be empty if no work team satisfies the filter specified in the @@ -5175,6 +6787,40 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Adds a resouce policy to control access to a model group. For information about + * resoure policies, see Identity-based + * policies and resource-based policies in the AWS Identity and Access Management User Guide..

    + */ + public putModelPackageGroupPolicy( + args: PutModelPackageGroupPolicyCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public putModelPackageGroupPolicy( + args: PutModelPackageGroupPolicyCommandInput, + cb: (err: any, data?: PutModelPackageGroupPolicyCommandOutput) => void + ): void; + public putModelPackageGroupPolicy( + args: PutModelPackageGroupPolicyCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: PutModelPackageGroupPolicyCommandOutput) => void + ): void; + public putModelPackageGroupPolicy( + args: PutModelPackageGroupPolicyCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: PutModelPackageGroupPolicyCommandOutput) => void), + cb?: (err: any, data?: PutModelPackageGroupPolicyCommandOutput) => void + ): Promise | void { + const command = new PutModelPackageGroupPolicyCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Renders the UI template so that you can preview the worker's experience.

    */ @@ -5307,6 +6953,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Starts a pipeline execution.

    + */ + public startPipelineExecution( + args: StartPipelineExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public startPipelineExecution( + args: StartPipelineExecutionCommandInput, + cb: (err: any, data?: StartPipelineExecutionCommandOutput) => void + ): void; + public startPipelineExecution( + args: StartPipelineExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StartPipelineExecutionCommandOutput) => void + ): void; + public startPipelineExecution( + args: StartPipelineExecutionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StartPipelineExecutionCommandOutput) => void), + cb?: (err: any, data?: StartPipelineExecutionCommandOutput) => void + ): Promise | void { + const command = new StartPipelineExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    A method for forcing the termination of a running job.

    */ @@ -5519,6 +7197,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Stops a pipeline execution.

    + */ + public stopPipelineExecution( + args: StopPipelineExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public stopPipelineExecution( + args: StopPipelineExecutionCommandInput, + cb: (err: any, data?: StopPipelineExecutionCommandOutput) => void + ): void; + public stopPipelineExecution( + args: StopPipelineExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: StopPipelineExecutionCommandOutput) => void + ): void; + public stopPipelineExecution( + args: StopPipelineExecutionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: StopPipelineExecutionCommandOutput) => void), + cb?: (err: any, data?: StopPipelineExecutionCommandOutput) => void + ): Promise | void { + const command = new StopPipelineExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Stops a processing job.

    */ @@ -5626,6 +7336,35 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Updates an action.

    + */ + public updateAction( + args: UpdateActionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateAction(args: UpdateActionCommandInput, cb: (err: any, data?: UpdateActionCommandOutput) => void): void; + public updateAction( + args: UpdateActionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateActionCommandOutput) => void + ): void; + public updateAction( + args: UpdateActionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateActionCommandOutput) => void), + cb?: (err: any, data?: UpdateActionCommandOutput) => void + ): Promise | void { + const command = new UpdateActionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates the properties of an AppImageConfig.

    */ @@ -5658,6 +7397,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Updates an artifact.

    + */ + public updateArtifact( + args: UpdateArtifactCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateArtifact( + args: UpdateArtifactCommandInput, + cb: (err: any, data?: UpdateArtifactCommandOutput) => void + ): void; + public updateArtifact( + args: UpdateArtifactCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateArtifactCommandOutput) => void + ): void; + public updateArtifact( + args: UpdateArtifactCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateArtifactCommandOutput) => void), + cb?: (err: any, data?: UpdateArtifactCommandOutput) => void + ): Promise | void { + const command = new UpdateArtifactCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates the specified Git repository with the specified values.

    */ @@ -5690,6 +7461,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Updates a context.

    + */ + public updateContext( + args: UpdateContextCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateContext( + args: UpdateContextCommandInput, + cb: (err: any, data?: UpdateContextCommandOutput) => void + ): void; + public updateContext( + args: UpdateContextCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateContextCommandOutput) => void + ): void; + public updateContext( + args: UpdateContextCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateContextCommandOutput) => void), + cb?: (err: any, data?: UpdateContextCommandOutput) => void + ): Promise | void { + const command = new UpdateContextCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates the default settings for new user profiles in the domain.

    */ @@ -5863,6 +7666,38 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Updates a versioned model.

    + */ + public updateModelPackage( + args: UpdateModelPackageCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updateModelPackage( + args: UpdateModelPackageCommandInput, + cb: (err: any, data?: UpdateModelPackageCommandOutput) => void + ): void; + public updateModelPackage( + args: UpdateModelPackageCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdateModelPackageCommandOutput) => void + ): void; + public updateModelPackage( + args: UpdateModelPackageCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdateModelPackageCommandOutput) => void), + cb?: (err: any, data?: UpdateModelPackageCommandOutput) => void + ): Promise | void { + const command = new UpdateModelPackageCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates a previously created schedule.

    */ @@ -5963,6 +7798,70 @@ export class SageMaker extends SageMakerClient { } } + /** + *

    Updates a pipeline.

    + */ + public updatePipeline( + args: UpdatePipelineCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updatePipeline( + args: UpdatePipelineCommandInput, + cb: (err: any, data?: UpdatePipelineCommandOutput) => void + ): void; + public updatePipeline( + args: UpdatePipelineCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdatePipelineCommandOutput) => void + ): void; + public updatePipeline( + args: UpdatePipelineCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdatePipelineCommandOutput) => void), + cb?: (err: any, data?: UpdatePipelineCommandOutput) => void + ): Promise | void { + const command = new UpdatePipelineCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + + /** + *

    Updates a pipeline execution.

    + */ + public updatePipelineExecution( + args: UpdatePipelineExecutionCommandInput, + options?: __HttpHandlerOptions + ): Promise; + public updatePipelineExecution( + args: UpdatePipelineExecutionCommandInput, + cb: (err: any, data?: UpdatePipelineExecutionCommandOutput) => void + ): void; + public updatePipelineExecution( + args: UpdatePipelineExecutionCommandInput, + options: __HttpHandlerOptions, + cb: (err: any, data?: UpdatePipelineExecutionCommandOutput) => void + ): void; + public updatePipelineExecution( + args: UpdatePipelineExecutionCommandInput, + optionsOrCb?: __HttpHandlerOptions | ((err: any, data?: UpdatePipelineExecutionCommandOutput) => void), + cb?: (err: any, data?: UpdatePipelineExecutionCommandOutput) => void + ): Promise | void { + const command = new UpdatePipelineExecutionCommand(args); + if (typeof optionsOrCb === "function") { + this.send(command, optionsOrCb); + } else if (typeof cb === "function") { + if (typeof optionsOrCb !== "object") throw new Error(`Expect http options but get ${typeof optionsOrCb}`); + this.send(command, optionsOrCb || {}, cb); + } else { + return this.send(command, optionsOrCb); + } + } + /** *

    Updates the display name of a trial.

    */ diff --git a/clients/client-sagemaker/SageMakerClient.ts b/clients/client-sagemaker/SageMakerClient.ts index 28386b80fb40..0aa3f54199cb 100644 --- a/clients/client-sagemaker/SageMakerClient.ts +++ b/clients/client-sagemaker/SageMakerClient.ts @@ -1,14 +1,17 @@ +import { AddAssociationCommandInput, AddAssociationCommandOutput } from "./commands/AddAssociationCommand"; import { AddTagsCommandInput, AddTagsCommandOutput } from "./commands/AddTagsCommand"; import { AssociateTrialComponentCommandInput, AssociateTrialComponentCommandOutput, } from "./commands/AssociateTrialComponentCommand"; +import { CreateActionCommandInput, CreateActionCommandOutput } from "./commands/CreateActionCommand"; import { CreateAlgorithmCommandInput, CreateAlgorithmCommandOutput } from "./commands/CreateAlgorithmCommand"; import { CreateAppCommandInput, CreateAppCommandOutput } from "./commands/CreateAppCommand"; import { CreateAppImageConfigCommandInput, CreateAppImageConfigCommandOutput, } from "./commands/CreateAppImageConfigCommand"; +import { CreateArtifactCommandInput, CreateArtifactCommandOutput } from "./commands/CreateArtifactCommand"; import { CreateAutoMLJobCommandInput, CreateAutoMLJobCommandOutput } from "./commands/CreateAutoMLJobCommand"; import { CreateCodeRepositoryCommandInput, @@ -18,6 +21,7 @@ import { CreateCompilationJobCommandInput, CreateCompilationJobCommandOutput, } from "./commands/CreateCompilationJobCommand"; +import { CreateContextCommandInput, CreateContextCommandOutput } from "./commands/CreateContextCommand"; import { CreateDomainCommandInput, CreateDomainCommandOutput } from "./commands/CreateDomainCommand"; import { CreateEndpointCommandInput, CreateEndpointCommandOutput } from "./commands/CreateEndpointCommand"; import { @@ -25,6 +29,7 @@ import { CreateEndpointConfigCommandOutput, } from "./commands/CreateEndpointConfigCommand"; import { CreateExperimentCommandInput, CreateExperimentCommandOutput } from "./commands/CreateExperimentCommand"; +import { CreateFeatureGroupCommandInput, CreateFeatureGroupCommandOutput } from "./commands/CreateFeatureGroupCommand"; import { CreateFlowDefinitionCommandInput, CreateFlowDefinitionCommandOutput, @@ -39,6 +44,10 @@ import { CreateImageVersionCommandInput, CreateImageVersionCommandOutput } from import { CreateLabelingJobCommandInput, CreateLabelingJobCommandOutput } from "./commands/CreateLabelingJobCommand"; import { CreateModelCommandInput, CreateModelCommandOutput } from "./commands/CreateModelCommand"; import { CreateModelPackageCommandInput, CreateModelPackageCommandOutput } from "./commands/CreateModelPackageCommand"; +import { + CreateModelPackageGroupCommandInput, + CreateModelPackageGroupCommandOutput, +} from "./commands/CreateModelPackageGroupCommand"; import { CreateMonitoringScheduleCommandInput, CreateMonitoringScheduleCommandOutput, @@ -51,6 +60,7 @@ import { CreateNotebookInstanceLifecycleConfigCommandInput, CreateNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/CreateNotebookInstanceLifecycleConfigCommand"; +import { CreatePipelineCommandInput, CreatePipelineCommandOutput } from "./commands/CreatePipelineCommand"; import { CreatePresignedDomainUrlCommandInput, CreatePresignedDomainUrlCommandOutput, @@ -63,6 +73,7 @@ import { CreateProcessingJobCommandInput, CreateProcessingJobCommandOutput, } from "./commands/CreateProcessingJobCommand"; +import { CreateProjectCommandInput, CreateProjectCommandOutput } from "./commands/CreateProjectCommand"; import { CreateTrainingJobCommandInput, CreateTrainingJobCommandOutput } from "./commands/CreateTrainingJobCommand"; import { CreateTransformJobCommandInput, CreateTransformJobCommandOutput } from "./commands/CreateTransformJobCommand"; import { CreateTrialCommandInput, CreateTrialCommandOutput } from "./commands/CreateTrialCommand"; @@ -73,16 +84,20 @@ import { import { CreateUserProfileCommandInput, CreateUserProfileCommandOutput } from "./commands/CreateUserProfileCommand"; import { CreateWorkforceCommandInput, CreateWorkforceCommandOutput } from "./commands/CreateWorkforceCommand"; import { CreateWorkteamCommandInput, CreateWorkteamCommandOutput } from "./commands/CreateWorkteamCommand"; +import { DeleteActionCommandInput, DeleteActionCommandOutput } from "./commands/DeleteActionCommand"; import { DeleteAlgorithmCommandInput, DeleteAlgorithmCommandOutput } from "./commands/DeleteAlgorithmCommand"; import { DeleteAppCommandInput, DeleteAppCommandOutput } from "./commands/DeleteAppCommand"; import { DeleteAppImageConfigCommandInput, DeleteAppImageConfigCommandOutput, } from "./commands/DeleteAppImageConfigCommand"; +import { DeleteArtifactCommandInput, DeleteArtifactCommandOutput } from "./commands/DeleteArtifactCommand"; +import { DeleteAssociationCommandInput, DeleteAssociationCommandOutput } from "./commands/DeleteAssociationCommand"; import { DeleteCodeRepositoryCommandInput, DeleteCodeRepositoryCommandOutput, } from "./commands/DeleteCodeRepositoryCommand"; +import { DeleteContextCommandInput, DeleteContextCommandOutput } from "./commands/DeleteContextCommand"; import { DeleteDomainCommandInput, DeleteDomainCommandOutput } from "./commands/DeleteDomainCommand"; import { DeleteEndpointCommandInput, DeleteEndpointCommandOutput } from "./commands/DeleteEndpointCommand"; import { @@ -90,6 +105,7 @@ import { DeleteEndpointConfigCommandOutput, } from "./commands/DeleteEndpointConfigCommand"; import { DeleteExperimentCommandInput, DeleteExperimentCommandOutput } from "./commands/DeleteExperimentCommand"; +import { DeleteFeatureGroupCommandInput, DeleteFeatureGroupCommandOutput } from "./commands/DeleteFeatureGroupCommand"; import { DeleteFlowDefinitionCommandInput, DeleteFlowDefinitionCommandOutput, @@ -99,6 +115,14 @@ import { DeleteImageCommandInput, DeleteImageCommandOutput } from "./commands/De import { DeleteImageVersionCommandInput, DeleteImageVersionCommandOutput } from "./commands/DeleteImageVersionCommand"; import { DeleteModelCommandInput, DeleteModelCommandOutput } from "./commands/DeleteModelCommand"; import { DeleteModelPackageCommandInput, DeleteModelPackageCommandOutput } from "./commands/DeleteModelPackageCommand"; +import { + DeleteModelPackageGroupCommandInput, + DeleteModelPackageGroupCommandOutput, +} from "./commands/DeleteModelPackageGroupCommand"; +import { + DeleteModelPackageGroupPolicyCommandInput, + DeleteModelPackageGroupPolicyCommandOutput, +} from "./commands/DeleteModelPackageGroupPolicyCommand"; import { DeleteMonitoringScheduleCommandInput, DeleteMonitoringScheduleCommandOutput, @@ -111,6 +135,8 @@ import { DeleteNotebookInstanceLifecycleConfigCommandInput, DeleteNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/DeleteNotebookInstanceLifecycleConfigCommand"; +import { DeletePipelineCommandInput, DeletePipelineCommandOutput } from "./commands/DeletePipelineCommand"; +import { DeleteProjectCommandInput, DeleteProjectCommandOutput } from "./commands/DeleteProjectCommand"; import { DeleteTagsCommandInput, DeleteTagsCommandOutput } from "./commands/DeleteTagsCommand"; import { DeleteTrialCommandInput, DeleteTrialCommandOutput } from "./commands/DeleteTrialCommand"; import { @@ -120,12 +146,14 @@ import { import { DeleteUserProfileCommandInput, DeleteUserProfileCommandOutput } from "./commands/DeleteUserProfileCommand"; import { DeleteWorkforceCommandInput, DeleteWorkforceCommandOutput } from "./commands/DeleteWorkforceCommand"; import { DeleteWorkteamCommandInput, DeleteWorkteamCommandOutput } from "./commands/DeleteWorkteamCommand"; +import { DescribeActionCommandInput, DescribeActionCommandOutput } from "./commands/DescribeActionCommand"; import { DescribeAlgorithmCommandInput, DescribeAlgorithmCommandOutput } from "./commands/DescribeAlgorithmCommand"; import { DescribeAppCommandInput, DescribeAppCommandOutput } from "./commands/DescribeAppCommand"; import { DescribeAppImageConfigCommandInput, DescribeAppImageConfigCommandOutput, } from "./commands/DescribeAppImageConfigCommand"; +import { DescribeArtifactCommandInput, DescribeArtifactCommandOutput } from "./commands/DescribeArtifactCommand"; import { DescribeAutoMLJobCommandInput, DescribeAutoMLJobCommandOutput } from "./commands/DescribeAutoMLJobCommand"; import { DescribeCodeRepositoryCommandInput, @@ -135,6 +163,7 @@ import { DescribeCompilationJobCommandInput, DescribeCompilationJobCommandOutput, } from "./commands/DescribeCompilationJobCommand"; +import { DescribeContextCommandInput, DescribeContextCommandOutput } from "./commands/DescribeContextCommand"; import { DescribeDomainCommandInput, DescribeDomainCommandOutput } from "./commands/DescribeDomainCommand"; import { DescribeEndpointCommandInput, DescribeEndpointCommandOutput } from "./commands/DescribeEndpointCommand"; import { @@ -142,6 +171,10 @@ import { DescribeEndpointConfigCommandOutput, } from "./commands/DescribeEndpointConfigCommand"; import { DescribeExperimentCommandInput, DescribeExperimentCommandOutput } from "./commands/DescribeExperimentCommand"; +import { + DescribeFeatureGroupCommandInput, + DescribeFeatureGroupCommandOutput, +} from "./commands/DescribeFeatureGroupCommand"; import { DescribeFlowDefinitionCommandInput, DescribeFlowDefinitionCommandOutput, @@ -168,6 +201,10 @@ import { DescribeModelPackageCommandInput, DescribeModelPackageCommandOutput, } from "./commands/DescribeModelPackageCommand"; +import { + DescribeModelPackageGroupCommandInput, + DescribeModelPackageGroupCommandOutput, +} from "./commands/DescribeModelPackageGroupCommand"; import { DescribeMonitoringScheduleCommandInput, DescribeMonitoringScheduleCommandOutput, @@ -180,10 +217,20 @@ import { DescribeNotebookInstanceLifecycleConfigCommandInput, DescribeNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/DescribeNotebookInstanceLifecycleConfigCommand"; +import { DescribePipelineCommandInput, DescribePipelineCommandOutput } from "./commands/DescribePipelineCommand"; +import { + DescribePipelineDefinitionForExecutionCommandInput, + DescribePipelineDefinitionForExecutionCommandOutput, +} from "./commands/DescribePipelineDefinitionForExecutionCommand"; +import { + DescribePipelineExecutionCommandInput, + DescribePipelineExecutionCommandOutput, +} from "./commands/DescribePipelineExecutionCommand"; import { DescribeProcessingJobCommandInput, DescribeProcessingJobCommandOutput, } from "./commands/DescribeProcessingJobCommand"; +import { DescribeProjectCommandInput, DescribeProjectCommandOutput } from "./commands/DescribeProjectCommand"; import { DescribeSubscribedWorkteamCommandInput, DescribeSubscribedWorkteamCommandOutput, @@ -207,20 +254,39 @@ import { } from "./commands/DescribeUserProfileCommand"; import { DescribeWorkforceCommandInput, DescribeWorkforceCommandOutput } from "./commands/DescribeWorkforceCommand"; import { DescribeWorkteamCommandInput, DescribeWorkteamCommandOutput } from "./commands/DescribeWorkteamCommand"; +import { + DisableSagemakerServicecatalogPortfolioCommandInput, + DisableSagemakerServicecatalogPortfolioCommandOutput, +} from "./commands/DisableSagemakerServicecatalogPortfolioCommand"; import { DisassociateTrialComponentCommandInput, DisassociateTrialComponentCommandOutput, } from "./commands/DisassociateTrialComponentCommand"; +import { + EnableSagemakerServicecatalogPortfolioCommandInput, + EnableSagemakerServicecatalogPortfolioCommandOutput, +} from "./commands/EnableSagemakerServicecatalogPortfolioCommand"; +import { + GetModelPackageGroupPolicyCommandInput, + GetModelPackageGroupPolicyCommandOutput, +} from "./commands/GetModelPackageGroupPolicyCommand"; +import { + GetSagemakerServicecatalogPortfolioStatusCommandInput, + GetSagemakerServicecatalogPortfolioStatusCommandOutput, +} from "./commands/GetSagemakerServicecatalogPortfolioStatusCommand"; import { GetSearchSuggestionsCommandInput, GetSearchSuggestionsCommandOutput, } from "./commands/GetSearchSuggestionsCommand"; +import { ListActionsCommandInput, ListActionsCommandOutput } from "./commands/ListActionsCommand"; import { ListAlgorithmsCommandInput, ListAlgorithmsCommandOutput } from "./commands/ListAlgorithmsCommand"; import { ListAppImageConfigsCommandInput, ListAppImageConfigsCommandOutput, } from "./commands/ListAppImageConfigsCommand"; import { ListAppsCommandInput, ListAppsCommandOutput } from "./commands/ListAppsCommand"; +import { ListArtifactsCommandInput, ListArtifactsCommandOutput } from "./commands/ListArtifactsCommand"; +import { ListAssociationsCommandInput, ListAssociationsCommandOutput } from "./commands/ListAssociationsCommand"; import { ListAutoMLJobsCommandInput, ListAutoMLJobsCommandOutput } from "./commands/ListAutoMLJobsCommand"; import { ListCandidatesForAutoMLJobCommandInput, @@ -234,6 +300,7 @@ import { ListCompilationJobsCommandInput, ListCompilationJobsCommandOutput, } from "./commands/ListCompilationJobsCommand"; +import { ListContextsCommandInput, ListContextsCommandOutput } from "./commands/ListContextsCommand"; import { ListDomainsCommandInput, ListDomainsCommandOutput } from "./commands/ListDomainsCommand"; import { ListEndpointConfigsCommandInput, @@ -241,6 +308,7 @@ import { } from "./commands/ListEndpointConfigsCommand"; import { ListEndpointsCommandInput, ListEndpointsCommandOutput } from "./commands/ListEndpointsCommand"; import { ListExperimentsCommandInput, ListExperimentsCommandOutput } from "./commands/ListExperimentsCommand"; +import { ListFeatureGroupsCommandInput, ListFeatureGroupsCommandOutput } from "./commands/ListFeatureGroupsCommand"; import { ListFlowDefinitionsCommandInput, ListFlowDefinitionsCommandOutput, @@ -257,6 +325,10 @@ import { ListLabelingJobsForWorkteamCommandInput, ListLabelingJobsForWorkteamCommandOutput, } from "./commands/ListLabelingJobsForWorkteamCommand"; +import { + ListModelPackageGroupsCommandInput, + ListModelPackageGroupsCommandOutput, +} from "./commands/ListModelPackageGroupsCommand"; import { ListModelPackagesCommandInput, ListModelPackagesCommandOutput } from "./commands/ListModelPackagesCommand"; import { ListModelsCommandInput, ListModelsCommandOutput } from "./commands/ListModelsCommand"; import { @@ -275,7 +347,21 @@ import { ListNotebookInstancesCommandInput, ListNotebookInstancesCommandOutput, } from "./commands/ListNotebookInstancesCommand"; +import { + ListPipelineExecutionStepsCommandInput, + ListPipelineExecutionStepsCommandOutput, +} from "./commands/ListPipelineExecutionStepsCommand"; +import { + ListPipelineExecutionsCommandInput, + ListPipelineExecutionsCommandOutput, +} from "./commands/ListPipelineExecutionsCommand"; +import { + ListPipelineParametersForExecutionCommandInput, + ListPipelineParametersForExecutionCommandOutput, +} from "./commands/ListPipelineParametersForExecutionCommand"; +import { ListPipelinesCommandInput, ListPipelinesCommandOutput } from "./commands/ListPipelinesCommand"; import { ListProcessingJobsCommandInput, ListProcessingJobsCommandOutput } from "./commands/ListProcessingJobsCommand"; +import { ListProjectsCommandInput, ListProjectsCommandOutput } from "./commands/ListProjectsCommand"; import { ListSubscribedWorkteamsCommandInput, ListSubscribedWorkteamsCommandOutput, @@ -295,6 +381,10 @@ import { ListTrialsCommandInput, ListTrialsCommandOutput } from "./commands/List import { ListUserProfilesCommandInput, ListUserProfilesCommandOutput } from "./commands/ListUserProfilesCommand"; import { ListWorkforcesCommandInput, ListWorkforcesCommandOutput } from "./commands/ListWorkforcesCommand"; import { ListWorkteamsCommandInput, ListWorkteamsCommandOutput } from "./commands/ListWorkteamsCommand"; +import { + PutModelPackageGroupPolicyCommandInput, + PutModelPackageGroupPolicyCommandOutput, +} from "./commands/PutModelPackageGroupPolicyCommand"; import { RenderUiTemplateCommandInput, RenderUiTemplateCommandOutput } from "./commands/RenderUiTemplateCommand"; import { SearchCommandInput, SearchCommandOutput } from "./commands/SearchCommand"; import { @@ -305,6 +395,10 @@ import { StartNotebookInstanceCommandInput, StartNotebookInstanceCommandOutput, } from "./commands/StartNotebookInstanceCommand"; +import { + StartPipelineExecutionCommandInput, + StartPipelineExecutionCommandOutput, +} from "./commands/StartPipelineExecutionCommand"; import { StopAutoMLJobCommandInput, StopAutoMLJobCommandOutput } from "./commands/StopAutoMLJobCommand"; import { StopCompilationJobCommandInput, StopCompilationJobCommandOutput } from "./commands/StopCompilationJobCommand"; import { @@ -320,17 +414,24 @@ import { StopNotebookInstanceCommandInput, StopNotebookInstanceCommandOutput, } from "./commands/StopNotebookInstanceCommand"; +import { + StopPipelineExecutionCommandInput, + StopPipelineExecutionCommandOutput, +} from "./commands/StopPipelineExecutionCommand"; import { StopProcessingJobCommandInput, StopProcessingJobCommandOutput } from "./commands/StopProcessingJobCommand"; import { StopTrainingJobCommandInput, StopTrainingJobCommandOutput } from "./commands/StopTrainingJobCommand"; import { StopTransformJobCommandInput, StopTransformJobCommandOutput } from "./commands/StopTransformJobCommand"; +import { UpdateActionCommandInput, UpdateActionCommandOutput } from "./commands/UpdateActionCommand"; import { UpdateAppImageConfigCommandInput, UpdateAppImageConfigCommandOutput, } from "./commands/UpdateAppImageConfigCommand"; +import { UpdateArtifactCommandInput, UpdateArtifactCommandOutput } from "./commands/UpdateArtifactCommand"; import { UpdateCodeRepositoryCommandInput, UpdateCodeRepositoryCommandOutput, } from "./commands/UpdateCodeRepositoryCommand"; +import { UpdateContextCommandInput, UpdateContextCommandOutput } from "./commands/UpdateContextCommand"; import { UpdateDomainCommandInput, UpdateDomainCommandOutput } from "./commands/UpdateDomainCommand"; import { UpdateEndpointCommandInput, UpdateEndpointCommandOutput } from "./commands/UpdateEndpointCommand"; import { @@ -339,6 +440,7 @@ import { } from "./commands/UpdateEndpointWeightsAndCapacitiesCommand"; import { UpdateExperimentCommandInput, UpdateExperimentCommandOutput } from "./commands/UpdateExperimentCommand"; import { UpdateImageCommandInput, UpdateImageCommandOutput } from "./commands/UpdateImageCommand"; +import { UpdateModelPackageCommandInput, UpdateModelPackageCommandOutput } from "./commands/UpdateModelPackageCommand"; import { UpdateMonitoringScheduleCommandInput, UpdateMonitoringScheduleCommandOutput, @@ -351,6 +453,11 @@ import { UpdateNotebookInstanceLifecycleConfigCommandInput, UpdateNotebookInstanceLifecycleConfigCommandOutput, } from "./commands/UpdateNotebookInstanceLifecycleConfigCommand"; +import { UpdatePipelineCommandInput, UpdatePipelineCommandOutput } from "./commands/UpdatePipelineCommand"; +import { + UpdatePipelineExecutionCommandInput, + UpdatePipelineExecutionCommandOutput, +} from "./commands/UpdatePipelineExecutionCommand"; import { UpdateTrialCommandInput, UpdateTrialCommandOutput } from "./commands/UpdateTrialCommand"; import { UpdateTrialComponentCommandInput, @@ -409,18 +516,23 @@ import { } from "@aws-sdk/types"; export type ServiceInputTypes = + | AddAssociationCommandInput | AddTagsCommandInput | AssociateTrialComponentCommandInput + | CreateActionCommandInput | CreateAlgorithmCommandInput | CreateAppCommandInput | CreateAppImageConfigCommandInput + | CreateArtifactCommandInput | CreateAutoMLJobCommandInput | CreateCodeRepositoryCommandInput | CreateCompilationJobCommandInput + | CreateContextCommandInput | CreateDomainCommandInput | CreateEndpointCommandInput | CreateEndpointConfigCommandInput | CreateExperimentCommandInput + | CreateFeatureGroupCommandInput | CreateFlowDefinitionCommandInput | CreateHumanTaskUiCommandInput | CreateHyperParameterTuningJobCommandInput @@ -429,12 +541,15 @@ export type ServiceInputTypes = | CreateLabelingJobCommandInput | CreateModelCommandInput | CreateModelPackageCommandInput + | CreateModelPackageGroupCommandInput | CreateMonitoringScheduleCommandInput | CreateNotebookInstanceCommandInput | CreateNotebookInstanceLifecycleConfigCommandInput + | CreatePipelineCommandInput | CreatePresignedDomainUrlCommandInput | CreatePresignedNotebookInstanceUrlCommandInput | CreateProcessingJobCommandInput + | CreateProjectCommandInput | CreateTrainingJobCommandInput | CreateTransformJobCommandInput | CreateTrialCommandInput @@ -442,39 +557,52 @@ export type ServiceInputTypes = | CreateUserProfileCommandInput | CreateWorkforceCommandInput | CreateWorkteamCommandInput + | DeleteActionCommandInput | DeleteAlgorithmCommandInput | DeleteAppCommandInput | DeleteAppImageConfigCommandInput + | DeleteArtifactCommandInput + | DeleteAssociationCommandInput | DeleteCodeRepositoryCommandInput + | DeleteContextCommandInput | DeleteDomainCommandInput | DeleteEndpointCommandInput | DeleteEndpointConfigCommandInput | DeleteExperimentCommandInput + | DeleteFeatureGroupCommandInput | DeleteFlowDefinitionCommandInput | DeleteHumanTaskUiCommandInput | DeleteImageCommandInput | DeleteImageVersionCommandInput | DeleteModelCommandInput | DeleteModelPackageCommandInput + | DeleteModelPackageGroupCommandInput + | DeleteModelPackageGroupPolicyCommandInput | DeleteMonitoringScheduleCommandInput | DeleteNotebookInstanceCommandInput | DeleteNotebookInstanceLifecycleConfigCommandInput + | DeletePipelineCommandInput + | DeleteProjectCommandInput | DeleteTagsCommandInput | DeleteTrialCommandInput | DeleteTrialComponentCommandInput | DeleteUserProfileCommandInput | DeleteWorkforceCommandInput | DeleteWorkteamCommandInput + | DescribeActionCommandInput | DescribeAlgorithmCommandInput | DescribeAppCommandInput | DescribeAppImageConfigCommandInput + | DescribeArtifactCommandInput | DescribeAutoMLJobCommandInput | DescribeCodeRepositoryCommandInput | DescribeCompilationJobCommandInput + | DescribeContextCommandInput | DescribeDomainCommandInput | DescribeEndpointCommandInput | DescribeEndpointConfigCommandInput | DescribeExperimentCommandInput + | DescribeFeatureGroupCommandInput | DescribeFlowDefinitionCommandInput | DescribeHumanTaskUiCommandInput | DescribeHyperParameterTuningJobCommandInput @@ -483,10 +611,15 @@ export type ServiceInputTypes = | DescribeLabelingJobCommandInput | DescribeModelCommandInput | DescribeModelPackageCommandInput + | DescribeModelPackageGroupCommandInput | DescribeMonitoringScheduleCommandInput | DescribeNotebookInstanceCommandInput | DescribeNotebookInstanceLifecycleConfigCommandInput + | DescribePipelineCommandInput + | DescribePipelineDefinitionForExecutionCommandInput + | DescribePipelineExecutionCommandInput | DescribeProcessingJobCommandInput + | DescribeProjectCommandInput | DescribeSubscribedWorkteamCommandInput | DescribeTrainingJobCommandInput | DescribeTransformJobCommandInput @@ -495,19 +628,28 @@ export type ServiceInputTypes = | DescribeUserProfileCommandInput | DescribeWorkforceCommandInput | DescribeWorkteamCommandInput + | DisableSagemakerServicecatalogPortfolioCommandInput | DisassociateTrialComponentCommandInput + | EnableSagemakerServicecatalogPortfolioCommandInput + | GetModelPackageGroupPolicyCommandInput + | GetSagemakerServicecatalogPortfolioStatusCommandInput | GetSearchSuggestionsCommandInput + | ListActionsCommandInput | ListAlgorithmsCommandInput | ListAppImageConfigsCommandInput | ListAppsCommandInput + | ListArtifactsCommandInput + | ListAssociationsCommandInput | ListAutoMLJobsCommandInput | ListCandidatesForAutoMLJobCommandInput | ListCodeRepositoriesCommandInput | ListCompilationJobsCommandInput + | ListContextsCommandInput | ListDomainsCommandInput | ListEndpointConfigsCommandInput | ListEndpointsCommandInput | ListExperimentsCommandInput + | ListFeatureGroupsCommandInput | ListFlowDefinitionsCommandInput | ListHumanTaskUisCommandInput | ListHyperParameterTuningJobsCommandInput @@ -515,13 +657,19 @@ export type ServiceInputTypes = | ListImagesCommandInput | ListLabelingJobsCommandInput | ListLabelingJobsForWorkteamCommandInput + | ListModelPackageGroupsCommandInput | ListModelPackagesCommandInput | ListModelsCommandInput | ListMonitoringExecutionsCommandInput | ListMonitoringSchedulesCommandInput | ListNotebookInstanceLifecycleConfigsCommandInput | ListNotebookInstancesCommandInput + | ListPipelineExecutionStepsCommandInput + | ListPipelineExecutionsCommandInput + | ListPipelineParametersForExecutionCommandInput + | ListPipelinesCommandInput | ListProcessingJobsCommandInput + | ListProjectsCommandInput | ListSubscribedWorkteamsCommandInput | ListTagsCommandInput | ListTrainingJobsCommandInput @@ -532,29 +680,38 @@ export type ServiceInputTypes = | ListUserProfilesCommandInput | ListWorkforcesCommandInput | ListWorkteamsCommandInput + | PutModelPackageGroupPolicyCommandInput | RenderUiTemplateCommandInput | SearchCommandInput | StartMonitoringScheduleCommandInput | StartNotebookInstanceCommandInput + | StartPipelineExecutionCommandInput | StopAutoMLJobCommandInput | StopCompilationJobCommandInput | StopHyperParameterTuningJobCommandInput | StopLabelingJobCommandInput | StopMonitoringScheduleCommandInput | StopNotebookInstanceCommandInput + | StopPipelineExecutionCommandInput | StopProcessingJobCommandInput | StopTrainingJobCommandInput | StopTransformJobCommandInput + | UpdateActionCommandInput | UpdateAppImageConfigCommandInput + | UpdateArtifactCommandInput | UpdateCodeRepositoryCommandInput + | UpdateContextCommandInput | UpdateDomainCommandInput | UpdateEndpointCommandInput | UpdateEndpointWeightsAndCapacitiesCommandInput | UpdateExperimentCommandInput | UpdateImageCommandInput + | UpdateModelPackageCommandInput | UpdateMonitoringScheduleCommandInput | UpdateNotebookInstanceCommandInput | UpdateNotebookInstanceLifecycleConfigCommandInput + | UpdatePipelineCommandInput + | UpdatePipelineExecutionCommandInput | UpdateTrialCommandInput | UpdateTrialComponentCommandInput | UpdateUserProfileCommandInput @@ -562,18 +719,23 @@ export type ServiceInputTypes = | UpdateWorkteamCommandInput; export type ServiceOutputTypes = + | AddAssociationCommandOutput | AddTagsCommandOutput | AssociateTrialComponentCommandOutput + | CreateActionCommandOutput | CreateAlgorithmCommandOutput | CreateAppCommandOutput | CreateAppImageConfigCommandOutput + | CreateArtifactCommandOutput | CreateAutoMLJobCommandOutput | CreateCodeRepositoryCommandOutput | CreateCompilationJobCommandOutput + | CreateContextCommandOutput | CreateDomainCommandOutput | CreateEndpointCommandOutput | CreateEndpointConfigCommandOutput | CreateExperimentCommandOutput + | CreateFeatureGroupCommandOutput | CreateFlowDefinitionCommandOutput | CreateHumanTaskUiCommandOutput | CreateHyperParameterTuningJobCommandOutput @@ -582,12 +744,15 @@ export type ServiceOutputTypes = | CreateLabelingJobCommandOutput | CreateModelCommandOutput | CreateModelPackageCommandOutput + | CreateModelPackageGroupCommandOutput | CreateMonitoringScheduleCommandOutput | CreateNotebookInstanceCommandOutput | CreateNotebookInstanceLifecycleConfigCommandOutput + | CreatePipelineCommandOutput | CreatePresignedDomainUrlCommandOutput | CreatePresignedNotebookInstanceUrlCommandOutput | CreateProcessingJobCommandOutput + | CreateProjectCommandOutput | CreateTrainingJobCommandOutput | CreateTransformJobCommandOutput | CreateTrialCommandOutput @@ -595,39 +760,52 @@ export type ServiceOutputTypes = | CreateUserProfileCommandOutput | CreateWorkforceCommandOutput | CreateWorkteamCommandOutput + | DeleteActionCommandOutput | DeleteAlgorithmCommandOutput | DeleteAppCommandOutput | DeleteAppImageConfigCommandOutput + | DeleteArtifactCommandOutput + | DeleteAssociationCommandOutput | DeleteCodeRepositoryCommandOutput + | DeleteContextCommandOutput | DeleteDomainCommandOutput | DeleteEndpointCommandOutput | DeleteEndpointConfigCommandOutput | DeleteExperimentCommandOutput + | DeleteFeatureGroupCommandOutput | DeleteFlowDefinitionCommandOutput | DeleteHumanTaskUiCommandOutput | DeleteImageCommandOutput | DeleteImageVersionCommandOutput | DeleteModelCommandOutput | DeleteModelPackageCommandOutput + | DeleteModelPackageGroupCommandOutput + | DeleteModelPackageGroupPolicyCommandOutput | DeleteMonitoringScheduleCommandOutput | DeleteNotebookInstanceCommandOutput | DeleteNotebookInstanceLifecycleConfigCommandOutput + | DeletePipelineCommandOutput + | DeleteProjectCommandOutput | DeleteTagsCommandOutput | DeleteTrialCommandOutput | DeleteTrialComponentCommandOutput | DeleteUserProfileCommandOutput | DeleteWorkforceCommandOutput | DeleteWorkteamCommandOutput + | DescribeActionCommandOutput | DescribeAlgorithmCommandOutput | DescribeAppCommandOutput | DescribeAppImageConfigCommandOutput + | DescribeArtifactCommandOutput | DescribeAutoMLJobCommandOutput | DescribeCodeRepositoryCommandOutput | DescribeCompilationJobCommandOutput + | DescribeContextCommandOutput | DescribeDomainCommandOutput | DescribeEndpointCommandOutput | DescribeEndpointConfigCommandOutput | DescribeExperimentCommandOutput + | DescribeFeatureGroupCommandOutput | DescribeFlowDefinitionCommandOutput | DescribeHumanTaskUiCommandOutput | DescribeHyperParameterTuningJobCommandOutput @@ -636,10 +814,15 @@ export type ServiceOutputTypes = | DescribeLabelingJobCommandOutput | DescribeModelCommandOutput | DescribeModelPackageCommandOutput + | DescribeModelPackageGroupCommandOutput | DescribeMonitoringScheduleCommandOutput | DescribeNotebookInstanceCommandOutput | DescribeNotebookInstanceLifecycleConfigCommandOutput + | DescribePipelineCommandOutput + | DescribePipelineDefinitionForExecutionCommandOutput + | DescribePipelineExecutionCommandOutput | DescribeProcessingJobCommandOutput + | DescribeProjectCommandOutput | DescribeSubscribedWorkteamCommandOutput | DescribeTrainingJobCommandOutput | DescribeTransformJobCommandOutput @@ -648,19 +831,28 @@ export type ServiceOutputTypes = | DescribeUserProfileCommandOutput | DescribeWorkforceCommandOutput | DescribeWorkteamCommandOutput + | DisableSagemakerServicecatalogPortfolioCommandOutput | DisassociateTrialComponentCommandOutput + | EnableSagemakerServicecatalogPortfolioCommandOutput + | GetModelPackageGroupPolicyCommandOutput + | GetSagemakerServicecatalogPortfolioStatusCommandOutput | GetSearchSuggestionsCommandOutput + | ListActionsCommandOutput | ListAlgorithmsCommandOutput | ListAppImageConfigsCommandOutput | ListAppsCommandOutput + | ListArtifactsCommandOutput + | ListAssociationsCommandOutput | ListAutoMLJobsCommandOutput | ListCandidatesForAutoMLJobCommandOutput | ListCodeRepositoriesCommandOutput | ListCompilationJobsCommandOutput + | ListContextsCommandOutput | ListDomainsCommandOutput | ListEndpointConfigsCommandOutput | ListEndpointsCommandOutput | ListExperimentsCommandOutput + | ListFeatureGroupsCommandOutput | ListFlowDefinitionsCommandOutput | ListHumanTaskUisCommandOutput | ListHyperParameterTuningJobsCommandOutput @@ -668,13 +860,19 @@ export type ServiceOutputTypes = | ListImagesCommandOutput | ListLabelingJobsCommandOutput | ListLabelingJobsForWorkteamCommandOutput + | ListModelPackageGroupsCommandOutput | ListModelPackagesCommandOutput | ListModelsCommandOutput | ListMonitoringExecutionsCommandOutput | ListMonitoringSchedulesCommandOutput | ListNotebookInstanceLifecycleConfigsCommandOutput | ListNotebookInstancesCommandOutput + | ListPipelineExecutionStepsCommandOutput + | ListPipelineExecutionsCommandOutput + | ListPipelineParametersForExecutionCommandOutput + | ListPipelinesCommandOutput | ListProcessingJobsCommandOutput + | ListProjectsCommandOutput | ListSubscribedWorkteamsCommandOutput | ListTagsCommandOutput | ListTrainingJobsCommandOutput @@ -685,29 +883,38 @@ export type ServiceOutputTypes = | ListUserProfilesCommandOutput | ListWorkforcesCommandOutput | ListWorkteamsCommandOutput + | PutModelPackageGroupPolicyCommandOutput | RenderUiTemplateCommandOutput | SearchCommandOutput | StartMonitoringScheduleCommandOutput | StartNotebookInstanceCommandOutput + | StartPipelineExecutionCommandOutput | StopAutoMLJobCommandOutput | StopCompilationJobCommandOutput | StopHyperParameterTuningJobCommandOutput | StopLabelingJobCommandOutput | StopMonitoringScheduleCommandOutput | StopNotebookInstanceCommandOutput + | StopPipelineExecutionCommandOutput | StopProcessingJobCommandOutput | StopTrainingJobCommandOutput | StopTransformJobCommandOutput + | UpdateActionCommandOutput | UpdateAppImageConfigCommandOutput + | UpdateArtifactCommandOutput | UpdateCodeRepositoryCommandOutput + | UpdateContextCommandOutput | UpdateDomainCommandOutput | UpdateEndpointCommandOutput | UpdateEndpointWeightsAndCapacitiesCommandOutput | UpdateExperimentCommandOutput | UpdateImageCommandOutput + | UpdateModelPackageCommandOutput | UpdateMonitoringScheduleCommandOutput | UpdateNotebookInstanceCommandOutput | UpdateNotebookInstanceLifecycleConfigCommandOutput + | UpdatePipelineCommandOutput + | UpdatePipelineExecutionCommandOutput | UpdateTrialCommandOutput | UpdateTrialComponentCommandOutput | UpdateUserProfileCommandOutput diff --git a/clients/client-sagemaker/commands/AddAssociationCommand.ts b/clients/client-sagemaker/commands/AddAssociationCommand.ts new file mode 100644 index 000000000000..6da3f770e671 --- /dev/null +++ b/clients/client-sagemaker/commands/AddAssociationCommand.ts @@ -0,0 +1,92 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { AddAssociationRequest, AddAssociationResponse } from "../models/models_0"; +import { + deserializeAws_json1_1AddAssociationCommand, + serializeAws_json1_1AddAssociationCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type AddAssociationCommandInput = AddAssociationRequest; +export type AddAssociationCommandOutput = AddAssociationResponse & __MetadataBearer; + +/** + *

    Creates an association between the source and the destination. A + * source can be associated with multiple destinations, and a destination can be associated + * with multiple sources. An association is a lineage tracking entity. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ +export class AddAssociationCommand extends $Command< + AddAssociationCommandInput, + AddAssociationCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: AddAssociationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "AddAssociationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: AddAssociationRequest.filterSensitiveLog, + outputFilterSensitiveLog: AddAssociationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: AddAssociationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1AddAssociationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1AddAssociationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateActionCommand.ts b/clients/client-sagemaker/commands/CreateActionCommand.ts new file mode 100644 index 000000000000..3006341ec7f0 --- /dev/null +++ b/clients/client-sagemaker/commands/CreateActionCommand.ts @@ -0,0 +1,92 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateActionRequest, CreateActionResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreateActionCommand, + serializeAws_json1_1CreateActionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateActionCommandInput = CreateActionRequest; +export type CreateActionCommandOutput = CreateActionResponse & __MetadataBearer; + +/** + *

    Creates an action. An action is a lineage tracking entity that + * represents an action or activity. For example, a model deployment or an HPO job. + * Generally, an action involves at least one input or output artifact. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ +export class CreateActionCommand extends $Command< + CreateActionCommandInput, + CreateActionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateActionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateActionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateActionRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateActionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateActionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateActionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateActionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateArtifactCommand.ts b/clients/client-sagemaker/commands/CreateArtifactCommand.ts new file mode 100644 index 000000000000..9e451bbb2332 --- /dev/null +++ b/clients/client-sagemaker/commands/CreateArtifactCommand.ts @@ -0,0 +1,92 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateArtifactRequest, CreateArtifactResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreateArtifactCommand, + serializeAws_json1_1CreateArtifactCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateArtifactCommandInput = CreateArtifactRequest; +export type CreateArtifactCommandOutput = CreateArtifactResponse & __MetadataBearer; + +/** + *

    Creates an artifact. An artifact is a lineage tracking entity that + * represents a URI addressable object or data. Some examples are the S3 URI of a dataset and + * the ECR registry path of an image. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ +export class CreateArtifactCommand extends $Command< + CreateArtifactCommandInput, + CreateArtifactCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateArtifactCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateArtifactCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateArtifactRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateArtifactResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateArtifactCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateArtifactCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateArtifactCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateContextCommand.ts b/clients/client-sagemaker/commands/CreateContextCommand.ts new file mode 100644 index 000000000000..57cdcc9efe72 --- /dev/null +++ b/clients/client-sagemaker/commands/CreateContextCommand.ts @@ -0,0 +1,92 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateContextRequest, CreateContextResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreateContextCommand, + serializeAws_json1_1CreateContextCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateContextCommandInput = CreateContextRequest; +export type CreateContextCommandOutput = CreateContextResponse & __MetadataBearer; + +/** + *

    Creates a context. A context is a lineage tracking entity that + * represents a logical grouping of other tracking or experiment entities. Some examples are + * an endpoint and a model package. For more information, see + * Amazon SageMaker + * ML Lineage Tracking.

    + */ +export class CreateContextCommand extends $Command< + CreateContextCommandInput, + CreateContextCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateContextCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateContextCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateContextRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateContextResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateContextCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateContextCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateContextCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateDomainCommand.ts b/clients/client-sagemaker/commands/CreateDomainCommand.ts index 68dbadfa9346..b10243da7c83 100644 --- a/clients/client-sagemaker/commands/CreateDomainCommand.ts +++ b/clients/client-sagemaker/commands/CreateDomainCommand.ts @@ -25,9 +25,19 @@ export type CreateDomainCommandOutput = CreateDomainResponse & __MetadataBearer; * Amazon Elastic File System (EFS) volume, a list of authorized users, and a variety of security, application, * policy, and Amazon Virtual Private Cloud (VPC) configurations. An AWS account is limited to one domain per region. * Users within a domain can share notebook files and other artifacts with each other.

    + * + *

    + * EFS storage + *

    *

    When a domain is created, an EFS volume is created for use by all of the users within the * domain. Each user receives a private home directory within the EFS volume for notebooks, * Git repositories, and data files.

    + *

    SageMaker uses the AWS Key Management Service (AWS KMS) to encrypt the EFS volume attached to the domain with + * an AWS managed customer master key (CMK) by default. For more control, you can specify a + * customer managed CMK. For more information, see + * Protect Data at + * Rest Using Encryption.

    + * *

    * VPC configuration *

    diff --git a/clients/client-sagemaker/commands/CreateFeatureGroupCommand.ts b/clients/client-sagemaker/commands/CreateFeatureGroupCommand.ts new file mode 100644 index 000000000000..31a2c61872e1 --- /dev/null +++ b/clients/client-sagemaker/commands/CreateFeatureGroupCommand.ts @@ -0,0 +1,100 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateFeatureGroupRequest, CreateFeatureGroupResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreateFeatureGroupCommand, + serializeAws_json1_1CreateFeatureGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateFeatureGroupCommandInput = CreateFeatureGroupRequest; +export type CreateFeatureGroupCommandOutput = CreateFeatureGroupResponse & __MetadataBearer; + +/** + *

    Create a new FeatureGroup. A FeatureGroup is a group of + * Features defined in the FeatureStore to describe a + * Record.

    + *

    The FeatureGroup defines the schema and features contained in the + * FeatureGroup. A FeatureGroup definition is composed of a list of + * Features, a RecordIdentifierFeatureName, an + * EventTimeFeatureName and configurations for its OnlineStore + * and OfflineStore. Check AWS service quotas to see + * the FeatureGroups quota for your AWS account.

    + * + *

    You must include at least one of OnlineStoreConfig and + * OfflineStoreConfig to create a FeatureGroup.

    + *
    + */ +export class CreateFeatureGroupCommand extends $Command< + CreateFeatureGroupCommandInput, + CreateFeatureGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateFeatureGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateFeatureGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateFeatureGroupRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreateFeatureGroupResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateFeatureGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateFeatureGroupCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateFeatureGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateModelPackageCommand.ts b/clients/client-sagemaker/commands/CreateModelPackageCommand.ts index cf4377066146..e5159864d728 100644 --- a/clients/client-sagemaker/commands/CreateModelPackageCommand.ts +++ b/clients/client-sagemaker/commands/CreateModelPackageCommand.ts @@ -22,13 +22,24 @@ export type CreateModelPackageCommandOutput = CreateModelPackageOutput & __Metad /** *

    Creates a model package that you can use to create Amazon SageMaker models or list on AWS - * Marketplace. Buyers can subscribe to model packages listed on AWS Marketplace to create + * Marketplace, or a versioned model that is part of a model group. Buyers can subscribe to model packages listed on AWS Marketplace to create * models in Amazon SageMaker.

    *

    To create a model package by specifying a Docker container that contains your * inference code and the Amazon S3 location of your model artifacts, provide values for * InferenceSpecification. To create a model from an algorithm resource * that you created or subscribed to in AWS Marketplace, provide a value for * SourceAlgorithmSpecification.

    + * + *

    There are two types of model packages:

    + *
      + *
    • + *

      Versioned - a model that is part of a model group in the model registry.

      + *
    • + *
    • + *

      Unversioned - a model package that is not part of a model group.

      + *
    • + *
    + *
    */ export class CreateModelPackageCommand extends $Command< CreateModelPackageCommandInput, diff --git a/clients/client-sagemaker/commands/CreateModelPackageGroupCommand.ts b/clients/client-sagemaker/commands/CreateModelPackageGroupCommand.ts new file mode 100644 index 000000000000..c15721827a0a --- /dev/null +++ b/clients/client-sagemaker/commands/CreateModelPackageGroupCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateModelPackageGroupInput, CreateModelPackageGroupOutput } from "../models/models_0"; +import { + deserializeAws_json1_1CreateModelPackageGroupCommand, + serializeAws_json1_1CreateModelPackageGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateModelPackageGroupCommandInput = CreateModelPackageGroupInput; +export type CreateModelPackageGroupCommandOutput = CreateModelPackageGroupOutput & __MetadataBearer; + +/** + *

    Creates a model group. A model group contains a group of model versions.

    + */ +export class CreateModelPackageGroupCommand extends $Command< + CreateModelPackageGroupCommandInput, + CreateModelPackageGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateModelPackageGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateModelPackageGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateModelPackageGroupInput.filterSensitiveLog, + outputFilterSensitiveLog: CreateModelPackageGroupOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateModelPackageGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateModelPackageGroupCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateModelPackageGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreatePipelineCommand.ts b/clients/client-sagemaker/commands/CreatePipelineCommand.ts new file mode 100644 index 000000000000..a8500687eb9e --- /dev/null +++ b/clients/client-sagemaker/commands/CreatePipelineCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreatePipelineRequest, CreatePipelineResponse } from "../models/models_0"; +import { + deserializeAws_json1_1CreatePipelineCommand, + serializeAws_json1_1CreatePipelineCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreatePipelineCommandInput = CreatePipelineRequest; +export type CreatePipelineCommandOutput = CreatePipelineResponse & __MetadataBearer; + +/** + *

    Creates a pipeline using a JSON pipeline definition.

    + */ +export class CreatePipelineCommand extends $Command< + CreatePipelineCommandInput, + CreatePipelineCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreatePipelineCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreatePipelineCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreatePipelineRequest.filterSensitiveLog, + outputFilterSensitiveLog: CreatePipelineResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreatePipelineCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreatePipelineCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreatePipelineCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreatePresignedDomainUrlCommand.ts b/clients/client-sagemaker/commands/CreatePresignedDomainUrlCommand.ts index cdcd3cfd35f4..f3af193307fe 100644 --- a/clients/client-sagemaker/commands/CreatePresignedDomainUrlCommand.ts +++ b/clients/client-sagemaker/commands/CreatePresignedDomainUrlCommand.ts @@ -1,5 +1,6 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreatePresignedDomainUrlRequest, CreatePresignedDomainUrlResponse } from "../models/models_0"; +import { CreatePresignedDomainUrlRequest } from "../models/models_0"; +import { CreatePresignedDomainUrlResponse } from "../models/models_1"; import { deserializeAws_json1_1CreatePresignedDomainUrlCommand, serializeAws_json1_1CreatePresignedDomainUrlCommand, diff --git a/clients/client-sagemaker/commands/CreatePresignedNotebookInstanceUrlCommand.ts b/clients/client-sagemaker/commands/CreatePresignedNotebookInstanceUrlCommand.ts index e35dd7abacae..5d740d95b9fd 100644 --- a/clients/client-sagemaker/commands/CreatePresignedNotebookInstanceUrlCommand.ts +++ b/clients/client-sagemaker/commands/CreatePresignedNotebookInstanceUrlCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreatePresignedNotebookInstanceUrlInput, CreatePresignedNotebookInstanceUrlOutput } from "../models/models_0"; +import { CreatePresignedNotebookInstanceUrlInput, CreatePresignedNotebookInstanceUrlOutput } from "../models/models_1"; import { deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommand, serializeAws_json1_1CreatePresignedNotebookInstanceUrlCommand, diff --git a/clients/client-sagemaker/commands/CreateProcessingJobCommand.ts b/clients/client-sagemaker/commands/CreateProcessingJobCommand.ts index d7368be1b6ee..818f46cb1632 100644 --- a/clients/client-sagemaker/commands/CreateProcessingJobCommand.ts +++ b/clients/client-sagemaker/commands/CreateProcessingJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateProcessingJobRequest, CreateProcessingJobResponse } from "../models/models_0"; +import { CreateProcessingJobRequest, CreateProcessingJobResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateProcessingJobCommand, serializeAws_json1_1CreateProcessingJobCommand, diff --git a/clients/client-sagemaker/commands/CreateProjectCommand.ts b/clients/client-sagemaker/commands/CreateProjectCommand.ts new file mode 100644 index 000000000000..eaeeacc508ae --- /dev/null +++ b/clients/client-sagemaker/commands/CreateProjectCommand.ts @@ -0,0 +1,89 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { CreateProjectInput, CreateProjectOutput } from "../models/models_1"; +import { + deserializeAws_json1_1CreateProjectCommand, + serializeAws_json1_1CreateProjectCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type CreateProjectCommandInput = CreateProjectInput; +export type CreateProjectCommandOutput = CreateProjectOutput & __MetadataBearer; + +/** + *

    Creates a machine learning (ML) project that can contain one or more templates that set + * up an ML pipeline from training to deploying an approved model.

    + */ +export class CreateProjectCommand extends $Command< + CreateProjectCommandInput, + CreateProjectCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: CreateProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "CreateProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: CreateProjectInput.filterSensitiveLog, + outputFilterSensitiveLog: CreateProjectOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: CreateProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1CreateProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1CreateProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/CreateTrainingJobCommand.ts b/clients/client-sagemaker/commands/CreateTrainingJobCommand.ts index f79e29503d46..7b0ec210d635 100644 --- a/clients/client-sagemaker/commands/CreateTrainingJobCommand.ts +++ b/clients/client-sagemaker/commands/CreateTrainingJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateTrainingJobRequest, CreateTrainingJobResponse } from "../models/models_0"; +import { CreateTrainingJobRequest, CreateTrainingJobResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateTrainingJobCommand, serializeAws_json1_1CreateTrainingJobCommand, @@ -23,10 +23,10 @@ export type CreateTrainingJobCommandOutput = CreateTrainingJobResponse & __Metad /** *

    Starts a model training job. After training completes, Amazon SageMaker saves the resulting * model artifacts to an Amazon S3 location that you specify.

    - *

    If you choose to host your model using Amazon SageMaker hosting services, you can use the - * resulting model artifacts as part of the model. You can also use the artifacts in a - * machine learning service other than Amazon SageMaker, provided that you know how to use them for - * inferences. + *

    If you choose to host your model using Amazon SageMaker hosting services, you can use the resulting + * model artifacts as part of the model. You can also use the artifacts in a machine + * learning service other than Amazon SageMaker, provided that you know how to use them for + * inference. * *

    *

    In the request body, you provide the following:

    @@ -71,7 +71,7 @@ export type CreateTrainingJobCommandOutput = CreateTrainingJobResponse & __Metad *
  • *
  • *

    - * RoleARN - The Amazon Resource Number (ARN) that Amazon SageMaker assumes + * RoleArn - The Amazon Resource Number (ARN) that Amazon SageMaker assumes * to perform tasks on your behalf during model training. * * You must grant this role the necessary permissions so that Amazon SageMaker can successfully diff --git a/clients/client-sagemaker/commands/CreateTransformJobCommand.ts b/clients/client-sagemaker/commands/CreateTransformJobCommand.ts index 498949e41ad7..53118fb4c7b1 100644 --- a/clients/client-sagemaker/commands/CreateTransformJobCommand.ts +++ b/clients/client-sagemaker/commands/CreateTransformJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateTransformJobRequest, CreateTransformJobResponse } from "../models/models_0"; +import { CreateTransformJobRequest, CreateTransformJobResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateTransformJobCommand, serializeAws_json1_1CreateTransformJobCommand, diff --git a/clients/client-sagemaker/commands/CreateTrialCommand.ts b/clients/client-sagemaker/commands/CreateTrialCommand.ts index d7f9c9c0dc3f..7f261665573a 100644 --- a/clients/client-sagemaker/commands/CreateTrialCommand.ts +++ b/clients/client-sagemaker/commands/CreateTrialCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateTrialRequest, CreateTrialResponse } from "../models/models_0"; +import { CreateTrialRequest, CreateTrialResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateTrialCommand, serializeAws_json1_1CreateTrialCommand, diff --git a/clients/client-sagemaker/commands/CreateTrialComponentCommand.ts b/clients/client-sagemaker/commands/CreateTrialComponentCommand.ts index 598252490895..9b56d0ff6e7e 100644 --- a/clients/client-sagemaker/commands/CreateTrialComponentCommand.ts +++ b/clients/client-sagemaker/commands/CreateTrialComponentCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateTrialComponentRequest, CreateTrialComponentResponse } from "../models/models_0"; +import { CreateTrialComponentRequest, CreateTrialComponentResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateTrialComponentCommand, serializeAws_json1_1CreateTrialComponentCommand, diff --git a/clients/client-sagemaker/commands/CreateUserProfileCommand.ts b/clients/client-sagemaker/commands/CreateUserProfileCommand.ts index a648a1838319..864cdf158ca5 100644 --- a/clients/client-sagemaker/commands/CreateUserProfileCommand.ts +++ b/clients/client-sagemaker/commands/CreateUserProfileCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateUserProfileRequest, CreateUserProfileResponse } from "../models/models_0"; +import { CreateUserProfileRequest, CreateUserProfileResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateUserProfileCommand, serializeAws_json1_1CreateUserProfileCommand, diff --git a/clients/client-sagemaker/commands/CreateWorkforceCommand.ts b/clients/client-sagemaker/commands/CreateWorkforceCommand.ts index b2c128158554..a30f4d0e5bad 100644 --- a/clients/client-sagemaker/commands/CreateWorkforceCommand.ts +++ b/clients/client-sagemaker/commands/CreateWorkforceCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateWorkforceRequest, CreateWorkforceResponse } from "../models/models_0"; +import { CreateWorkforceRequest, CreateWorkforceResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateWorkforceCommand, serializeAws_json1_1CreateWorkforceCommand, diff --git a/clients/client-sagemaker/commands/CreateWorkteamCommand.ts b/clients/client-sagemaker/commands/CreateWorkteamCommand.ts index 2ac2ee4ee769..fddfe007e85a 100644 --- a/clients/client-sagemaker/commands/CreateWorkteamCommand.ts +++ b/clients/client-sagemaker/commands/CreateWorkteamCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { CreateWorkteamRequest, CreateWorkteamResponse } from "../models/models_0"; +import { CreateWorkteamRequest, CreateWorkteamResponse } from "../models/models_1"; import { deserializeAws_json1_1CreateWorkteamCommand, serializeAws_json1_1CreateWorkteamCommand, diff --git a/clients/client-sagemaker/commands/DeleteActionCommand.ts b/clients/client-sagemaker/commands/DeleteActionCommand.ts new file mode 100644 index 000000000000..ec0470d88a3f --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteActionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteActionRequest, DeleteActionResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteActionCommand, + serializeAws_json1_1DeleteActionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteActionCommandInput = DeleteActionRequest; +export type DeleteActionCommandOutput = DeleteActionResponse & __MetadataBearer; + +/** + *

    Deletes an action.

    + */ +export class DeleteActionCommand extends $Command< + DeleteActionCommandInput, + DeleteActionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteActionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteActionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteActionRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteActionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteActionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteActionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteActionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteAlgorithmCommand.ts b/clients/client-sagemaker/commands/DeleteAlgorithmCommand.ts index 48dbc402084e..fe35087e97b4 100644 --- a/clients/client-sagemaker/commands/DeleteAlgorithmCommand.ts +++ b/clients/client-sagemaker/commands/DeleteAlgorithmCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { DeleteAlgorithmInput } from "../models/models_0"; +import { DeleteAlgorithmInput } from "../models/models_1"; import { deserializeAws_json1_1DeleteAlgorithmCommand, serializeAws_json1_1DeleteAlgorithmCommand, diff --git a/clients/client-sagemaker/commands/DeleteAppCommand.ts b/clients/client-sagemaker/commands/DeleteAppCommand.ts index 6aa8ebaa4b15..38b2c9bdad4a 100644 --- a/clients/client-sagemaker/commands/DeleteAppCommand.ts +++ b/clients/client-sagemaker/commands/DeleteAppCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { DeleteAppRequest } from "../models/models_0"; +import { DeleteAppRequest } from "../models/models_1"; import { deserializeAws_json1_1DeleteAppCommand, serializeAws_json1_1DeleteAppCommand } from "../protocols/Aws_json1_1"; import { getSerdePlugin } from "@aws-sdk/middleware-serde"; import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; diff --git a/clients/client-sagemaker/commands/DeleteAppImageConfigCommand.ts b/clients/client-sagemaker/commands/DeleteAppImageConfigCommand.ts index e2d23be2f8bb..1133235f4636 100644 --- a/clients/client-sagemaker/commands/DeleteAppImageConfigCommand.ts +++ b/clients/client-sagemaker/commands/DeleteAppImageConfigCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { DeleteAppImageConfigRequest } from "../models/models_0"; +import { DeleteAppImageConfigRequest } from "../models/models_1"; import { deserializeAws_json1_1DeleteAppImageConfigCommand, serializeAws_json1_1DeleteAppImageConfigCommand, diff --git a/clients/client-sagemaker/commands/DeleteArtifactCommand.ts b/clients/client-sagemaker/commands/DeleteArtifactCommand.ts new file mode 100644 index 000000000000..3cbf962cfc55 --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteArtifactCommand.ts @@ -0,0 +1,89 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteArtifactRequest, DeleteArtifactResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteArtifactCommand, + serializeAws_json1_1DeleteArtifactCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteArtifactCommandInput = DeleteArtifactRequest; +export type DeleteArtifactCommandOutput = DeleteArtifactResponse & __MetadataBearer; + +/** + *

    Deletes an artifact. Either ArtifactArn or Source must be + * specified.

    + */ +export class DeleteArtifactCommand extends $Command< + DeleteArtifactCommandInput, + DeleteArtifactCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteArtifactCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteArtifactCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteArtifactRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteArtifactResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteArtifactCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteArtifactCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteArtifactCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteAssociationCommand.ts b/clients/client-sagemaker/commands/DeleteAssociationCommand.ts new file mode 100644 index 000000000000..3a9bd1db2127 --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteAssociationCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteAssociationRequest, DeleteAssociationResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteAssociationCommand, + serializeAws_json1_1DeleteAssociationCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteAssociationCommandInput = DeleteAssociationRequest; +export type DeleteAssociationCommandOutput = DeleteAssociationResponse & __MetadataBearer; + +/** + *

    Deletes an association.

    + */ +export class DeleteAssociationCommand extends $Command< + DeleteAssociationCommandInput, + DeleteAssociationCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteAssociationCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteAssociationCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteAssociationRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteAssociationResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteAssociationCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteAssociationCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteAssociationCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteCodeRepositoryCommand.ts b/clients/client-sagemaker/commands/DeleteCodeRepositoryCommand.ts index 2699123ab77f..b36fe6b5eb77 100644 --- a/clients/client-sagemaker/commands/DeleteCodeRepositoryCommand.ts +++ b/clients/client-sagemaker/commands/DeleteCodeRepositoryCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { DeleteCodeRepositoryInput } from "../models/models_0"; +import { DeleteCodeRepositoryInput } from "../models/models_1"; import { deserializeAws_json1_1DeleteCodeRepositoryCommand, serializeAws_json1_1DeleteCodeRepositoryCommand, diff --git a/clients/client-sagemaker/commands/DeleteContextCommand.ts b/clients/client-sagemaker/commands/DeleteContextCommand.ts new file mode 100644 index 000000000000..6390306d167e --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteContextCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteContextRequest, DeleteContextResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteContextCommand, + serializeAws_json1_1DeleteContextCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteContextCommandInput = DeleteContextRequest; +export type DeleteContextCommandOutput = DeleteContextResponse & __MetadataBearer; + +/** + *

    Deletes an context.

    + */ +export class DeleteContextCommand extends $Command< + DeleteContextCommandInput, + DeleteContextCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteContextCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteContextCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteContextRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeleteContextResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteContextCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteContextCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteContextCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteFeatureGroupCommand.ts b/clients/client-sagemaker/commands/DeleteFeatureGroupCommand.ts new file mode 100644 index 000000000000..ceb7adc330b9 --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteFeatureGroupCommand.ts @@ -0,0 +1,93 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteFeatureGroupRequest } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteFeatureGroupCommand, + serializeAws_json1_1DeleteFeatureGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteFeatureGroupCommandInput = DeleteFeatureGroupRequest; +export type DeleteFeatureGroupCommandOutput = __MetadataBearer; + +/** + *

    Delete the FeatureGroup and any data that was written to the + * OnlineStore of the FeatureGroup. Data cannot be accessed from + * the OnlineStore immediately after DeleteFeatureGroup is called.

    + *

    Data written into the OfflineStore will not be deleted. The AWS Glue + * database and tables that are automatically created for your OfflineStore are + * not deleted.

    + */ +export class DeleteFeatureGroupCommand extends $Command< + DeleteFeatureGroupCommandInput, + DeleteFeatureGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteFeatureGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteFeatureGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteFeatureGroupRequest.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteFeatureGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteFeatureGroupCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteFeatureGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteModelPackageGroupCommand.ts b/clients/client-sagemaker/commands/DeleteModelPackageGroupCommand.ts new file mode 100644 index 000000000000..dee19d14f68c --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteModelPackageGroupCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteModelPackageGroupInput } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteModelPackageGroupCommand, + serializeAws_json1_1DeleteModelPackageGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteModelPackageGroupCommandInput = DeleteModelPackageGroupInput; +export type DeleteModelPackageGroupCommandOutput = __MetadataBearer; + +/** + *

    Deletes the specified model group.

    + */ +export class DeleteModelPackageGroupCommand extends $Command< + DeleteModelPackageGroupCommandInput, + DeleteModelPackageGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteModelPackageGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteModelPackageGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteModelPackageGroupInput.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteModelPackageGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteModelPackageGroupCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteModelPackageGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteModelPackageGroupPolicyCommand.ts b/clients/client-sagemaker/commands/DeleteModelPackageGroupPolicyCommand.ts new file mode 100644 index 000000000000..6f06e4a71ba9 --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteModelPackageGroupPolicyCommand.ts @@ -0,0 +1,91 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteModelPackageGroupPolicyInput } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteModelPackageGroupPolicyCommand, + serializeAws_json1_1DeleteModelPackageGroupPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteModelPackageGroupPolicyCommandInput = DeleteModelPackageGroupPolicyInput; +export type DeleteModelPackageGroupPolicyCommandOutput = __MetadataBearer; + +/** + *

    Deletes a model group resource policy.

    + */ +export class DeleteModelPackageGroupPolicyCommand extends $Command< + DeleteModelPackageGroupPolicyCommandInput, + DeleteModelPackageGroupPolicyCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteModelPackageGroupPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteModelPackageGroupPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteModelPackageGroupPolicyInput.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteModelPackageGroupPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteModelPackageGroupPolicyCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DeleteModelPackageGroupPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeletePipelineCommand.ts b/clients/client-sagemaker/commands/DeletePipelineCommand.ts new file mode 100644 index 000000000000..40142286ba2d --- /dev/null +++ b/clients/client-sagemaker/commands/DeletePipelineCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeletePipelineRequest, DeletePipelineResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DeletePipelineCommand, + serializeAws_json1_1DeletePipelineCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeletePipelineCommandInput = DeletePipelineRequest; +export type DeletePipelineCommandOutput = DeletePipelineResponse & __MetadataBearer; + +/** + *

    Deletes a pipeline.

    + */ +export class DeletePipelineCommand extends $Command< + DeletePipelineCommandInput, + DeletePipelineCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeletePipelineCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeletePipelineCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeletePipelineRequest.filterSensitiveLog, + outputFilterSensitiveLog: DeletePipelineResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeletePipelineCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeletePipelineCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeletePipelineCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DeleteProjectCommand.ts b/clients/client-sagemaker/commands/DeleteProjectCommand.ts new file mode 100644 index 000000000000..4b04fe1cd45c --- /dev/null +++ b/clients/client-sagemaker/commands/DeleteProjectCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DeleteProjectInput } from "../models/models_1"; +import { + deserializeAws_json1_1DeleteProjectCommand, + serializeAws_json1_1DeleteProjectCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DeleteProjectCommandInput = DeleteProjectInput; +export type DeleteProjectCommandOutput = __MetadataBearer; + +/** + *

    Delete the specified project.

    + */ +export class DeleteProjectCommand extends $Command< + DeleteProjectCommandInput, + DeleteProjectCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DeleteProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DeleteProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DeleteProjectInput.filterSensitiveLog, + outputFilterSensitiveLog: (output: any) => output, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DeleteProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DeleteProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DeleteProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeActionCommand.ts b/clients/client-sagemaker/commands/DescribeActionCommand.ts new file mode 100644 index 000000000000..7552edd51009 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeActionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeActionRequest, DescribeActionResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeActionCommand, + serializeAws_json1_1DescribeActionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeActionCommandInput = DescribeActionRequest; +export type DescribeActionCommandOutput = DescribeActionResponse & __MetadataBearer; + +/** + *

    Describes an action.

    + */ +export class DescribeActionCommand extends $Command< + DescribeActionCommandInput, + DescribeActionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeActionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeActionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeActionRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeActionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeActionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeActionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeActionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeArtifactCommand.ts b/clients/client-sagemaker/commands/DescribeArtifactCommand.ts new file mode 100644 index 000000000000..5b315518b635 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeArtifactCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeArtifactRequest, DescribeArtifactResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeArtifactCommand, + serializeAws_json1_1DescribeArtifactCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeArtifactCommandInput = DescribeArtifactRequest; +export type DescribeArtifactCommandOutput = DescribeArtifactResponse & __MetadataBearer; + +/** + *

    Describes an artifact.

    + */ +export class DescribeArtifactCommand extends $Command< + DescribeArtifactCommandInput, + DescribeArtifactCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeArtifactCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeArtifactCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeArtifactRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeArtifactResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeArtifactCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeArtifactCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeArtifactCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeContextCommand.ts b/clients/client-sagemaker/commands/DescribeContextCommand.ts new file mode 100644 index 000000000000..a1c7b244fe46 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeContextCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeContextRequest, DescribeContextResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeContextCommand, + serializeAws_json1_1DescribeContextCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeContextCommandInput = DescribeContextRequest; +export type DescribeContextCommandOutput = DescribeContextResponse & __MetadataBearer; + +/** + *

    Describes a context.

    + */ +export class DescribeContextCommand extends $Command< + DescribeContextCommandInput, + DescribeContextCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeContextCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeContextCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeContextRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeContextResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeContextCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeContextCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeContextCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeFeatureGroupCommand.ts b/clients/client-sagemaker/commands/DescribeFeatureGroupCommand.ts new file mode 100644 index 000000000000..5e96066a8809 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeFeatureGroupCommand.ts @@ -0,0 +1,90 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeFeatureGroupRequest, DescribeFeatureGroupResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeFeatureGroupCommand, + serializeAws_json1_1DescribeFeatureGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeFeatureGroupCommandInput = DescribeFeatureGroupRequest; +export type DescribeFeatureGroupCommandOutput = DescribeFeatureGroupResponse & __MetadataBearer; + +/** + *

    Use this operation to describe a FeatureGroup. The response includes + * information on the creation time, FeatureGroup name, the unique identifier for + * each FeatureGroup, and more.

    + */ +export class DescribeFeatureGroupCommand extends $Command< + DescribeFeatureGroupCommandInput, + DescribeFeatureGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeFeatureGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeFeatureGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeFeatureGroupRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribeFeatureGroupResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeFeatureGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeFeatureGroupCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeFeatureGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeModelPackageGroupCommand.ts b/clients/client-sagemaker/commands/DescribeModelPackageGroupCommand.ts new file mode 100644 index 000000000000..51787c63daa4 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeModelPackageGroupCommand.ts @@ -0,0 +1,91 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeModelPackageGroupInput, DescribeModelPackageGroupOutput } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeModelPackageGroupCommand, + serializeAws_json1_1DescribeModelPackageGroupCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeModelPackageGroupCommandInput = DescribeModelPackageGroupInput; +export type DescribeModelPackageGroupCommandOutput = DescribeModelPackageGroupOutput & __MetadataBearer; + +/** + *

    Gets a description for the specified model group.

    + */ +export class DescribeModelPackageGroupCommand extends $Command< + DescribeModelPackageGroupCommandInput, + DescribeModelPackageGroupCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeModelPackageGroupCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeModelPackageGroupCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeModelPackageGroupInput.filterSensitiveLog, + outputFilterSensitiveLog: DescribeModelPackageGroupOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeModelPackageGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeModelPackageGroupCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DescribeModelPackageGroupCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribePipelineCommand.ts b/clients/client-sagemaker/commands/DescribePipelineCommand.ts new file mode 100644 index 000000000000..557dcac69e09 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribePipelineCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribePipelineRequest, DescribePipelineResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribePipelineCommand, + serializeAws_json1_1DescribePipelineCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribePipelineCommandInput = DescribePipelineRequest; +export type DescribePipelineCommandOutput = DescribePipelineResponse & __MetadataBearer; + +/** + *

    Describes the details of a pipeline.

    + */ +export class DescribePipelineCommand extends $Command< + DescribePipelineCommandInput, + DescribePipelineCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribePipelineCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribePipelineCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribePipelineRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribePipelineResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribePipelineCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribePipelineCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribePipelineCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribePipelineDefinitionForExecutionCommand.ts b/clients/client-sagemaker/commands/DescribePipelineDefinitionForExecutionCommand.ts new file mode 100644 index 000000000000..d7c81ac3c970 --- /dev/null +++ b/clients/client-sagemaker/commands/DescribePipelineDefinitionForExecutionCommand.ts @@ -0,0 +1,98 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { + DescribePipelineDefinitionForExecutionRequest, + DescribePipelineDefinitionForExecutionResponse, +} from "../models/models_1"; +import { + deserializeAws_json1_1DescribePipelineDefinitionForExecutionCommand, + serializeAws_json1_1DescribePipelineDefinitionForExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribePipelineDefinitionForExecutionCommandInput = DescribePipelineDefinitionForExecutionRequest; +export type DescribePipelineDefinitionForExecutionCommandOutput = DescribePipelineDefinitionForExecutionResponse & + __MetadataBearer; + +/** + *

    Describes the details of an execution's pipeline definition.

    + */ +export class DescribePipelineDefinitionForExecutionCommand extends $Command< + DescribePipelineDefinitionForExecutionCommandInput, + DescribePipelineDefinitionForExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribePipelineDefinitionForExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribePipelineDefinitionForExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribePipelineDefinitionForExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribePipelineDefinitionForExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: DescribePipelineDefinitionForExecutionCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_json1_1DescribePipelineDefinitionForExecutionCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DescribePipelineDefinitionForExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribePipelineExecutionCommand.ts b/clients/client-sagemaker/commands/DescribePipelineExecutionCommand.ts new file mode 100644 index 000000000000..2beef8b66e8e --- /dev/null +++ b/clients/client-sagemaker/commands/DescribePipelineExecutionCommand.ts @@ -0,0 +1,91 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribePipelineExecutionRequest, DescribePipelineExecutionResponse } from "../models/models_1"; +import { + deserializeAws_json1_1DescribePipelineExecutionCommand, + serializeAws_json1_1DescribePipelineExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribePipelineExecutionCommandInput = DescribePipelineExecutionRequest; +export type DescribePipelineExecutionCommandOutput = DescribePipelineExecutionResponse & __MetadataBearer; + +/** + *

    Describes the details of a pipeline execution.

    + */ +export class DescribePipelineExecutionCommand extends $Command< + DescribePipelineExecutionCommandInput, + DescribePipelineExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribePipelineExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribePipelineExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribePipelineExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: DescribePipelineExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribePipelineExecutionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribePipelineExecutionCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DescribePipelineExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DescribeProjectCommand.ts b/clients/client-sagemaker/commands/DescribeProjectCommand.ts new file mode 100644 index 000000000000..6ccf31bcf57e --- /dev/null +++ b/clients/client-sagemaker/commands/DescribeProjectCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { DescribeProjectInput, DescribeProjectOutput } from "../models/models_1"; +import { + deserializeAws_json1_1DescribeProjectCommand, + serializeAws_json1_1DescribeProjectCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DescribeProjectCommandInput = DescribeProjectInput; +export type DescribeProjectCommandOutput = DescribeProjectOutput & __MetadataBearer; + +/** + *

    Describes the details of a project.

    + */ +export class DescribeProjectCommand extends $Command< + DescribeProjectCommandInput, + DescribeProjectCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DescribeProjectCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DescribeProjectCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DescribeProjectInput.filterSensitiveLog, + outputFilterSensitiveLog: DescribeProjectOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: DescribeProjectCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1DescribeProjectCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1DescribeProjectCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/DisableSagemakerServicecatalogPortfolioCommand.ts b/clients/client-sagemaker/commands/DisableSagemakerServicecatalogPortfolioCommand.ts new file mode 100644 index 000000000000..c73fa6c4b991 --- /dev/null +++ b/clients/client-sagemaker/commands/DisableSagemakerServicecatalogPortfolioCommand.ts @@ -0,0 +1,102 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { + DisableSagemakerServicecatalogPortfolioInput, + DisableSagemakerServicecatalogPortfolioOutput, +} from "../models/models_1"; +import { + deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand, + serializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type DisableSagemakerServicecatalogPortfolioCommandInput = DisableSagemakerServicecatalogPortfolioInput; +export type DisableSagemakerServicecatalogPortfolioCommandOutput = DisableSagemakerServicecatalogPortfolioOutput & + __MetadataBearer; + +/** + *

    Disables using Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ +export class DisableSagemakerServicecatalogPortfolioCommand extends $Command< + DisableSagemakerServicecatalogPortfolioCommandInput, + DisableSagemakerServicecatalogPortfolioCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: DisableSagemakerServicecatalogPortfolioCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler< + DisableSagemakerServicecatalogPortfolioCommandInput, + DisableSagemakerServicecatalogPortfolioCommandOutput + > { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "DisableSagemakerServicecatalogPortfolioCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: DisableSagemakerServicecatalogPortfolioInput.filterSensitiveLog, + outputFilterSensitiveLog: DisableSagemakerServicecatalogPortfolioOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: DisableSagemakerServicecatalogPortfolioCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/EnableSagemakerServicecatalogPortfolioCommand.ts b/clients/client-sagemaker/commands/EnableSagemakerServicecatalogPortfolioCommand.ts new file mode 100644 index 000000000000..2c9a8940e219 --- /dev/null +++ b/clients/client-sagemaker/commands/EnableSagemakerServicecatalogPortfolioCommand.ts @@ -0,0 +1,99 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { + EnableSagemakerServicecatalogPortfolioInput, + EnableSagemakerServicecatalogPortfolioOutput, +} from "../models/models_1"; +import { + deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand, + serializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type EnableSagemakerServicecatalogPortfolioCommandInput = EnableSagemakerServicecatalogPortfolioInput; +export type EnableSagemakerServicecatalogPortfolioCommandOutput = EnableSagemakerServicecatalogPortfolioOutput & + __MetadataBearer; + +/** + *

    Enables using Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ +export class EnableSagemakerServicecatalogPortfolioCommand extends $Command< + EnableSagemakerServicecatalogPortfolioCommandInput, + EnableSagemakerServicecatalogPortfolioCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: EnableSagemakerServicecatalogPortfolioCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "EnableSagemakerServicecatalogPortfolioCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: EnableSagemakerServicecatalogPortfolioInput.filterSensitiveLog, + outputFilterSensitiveLog: EnableSagemakerServicecatalogPortfolioOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: EnableSagemakerServicecatalogPortfolioCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/GetModelPackageGroupPolicyCommand.ts b/clients/client-sagemaker/commands/GetModelPackageGroupPolicyCommand.ts new file mode 100644 index 000000000000..764cfffd8df5 --- /dev/null +++ b/clients/client-sagemaker/commands/GetModelPackageGroupPolicyCommand.ts @@ -0,0 +1,94 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { GetModelPackageGroupPolicyInput, GetModelPackageGroupPolicyOutput } from "../models/models_1"; +import { + deserializeAws_json1_1GetModelPackageGroupPolicyCommand, + serializeAws_json1_1GetModelPackageGroupPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetModelPackageGroupPolicyCommandInput = GetModelPackageGroupPolicyInput; +export type GetModelPackageGroupPolicyCommandOutput = GetModelPackageGroupPolicyOutput & __MetadataBearer; + +/** + *

    Gets a resource policy that manages access for a model group. For information about + * resource policies, see Identity-based + * policies and resource-based policies in the AWS Identity and + * Access Management User Guide..

    + */ +export class GetModelPackageGroupPolicyCommand extends $Command< + GetModelPackageGroupPolicyCommandInput, + GetModelPackageGroupPolicyCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetModelPackageGroupPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "GetModelPackageGroupPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetModelPackageGroupPolicyInput.filterSensitiveLog, + outputFilterSensitiveLog: GetModelPackageGroupPolicyOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: GetModelPackageGroupPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1GetModelPackageGroupPolicyCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1GetModelPackageGroupPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/GetSagemakerServicecatalogPortfolioStatusCommand.ts b/clients/client-sagemaker/commands/GetSagemakerServicecatalogPortfolioStatusCommand.ts new file mode 100644 index 000000000000..005df582cff4 --- /dev/null +++ b/clients/client-sagemaker/commands/GetSagemakerServicecatalogPortfolioStatusCommand.ts @@ -0,0 +1,102 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { + GetSagemakerServicecatalogPortfolioStatusInput, + GetSagemakerServicecatalogPortfolioStatusOutput, +} from "../models/models_1"; +import { + deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand, + serializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type GetSagemakerServicecatalogPortfolioStatusCommandInput = GetSagemakerServicecatalogPortfolioStatusInput; +export type GetSagemakerServicecatalogPortfolioStatusCommandOutput = GetSagemakerServicecatalogPortfolioStatusOutput & + __MetadataBearer; + +/** + *

    Gets the status of Service Catalog in SageMaker. Service Catalog is used to create + * SageMaker projects.

    + */ +export class GetSagemakerServicecatalogPortfolioStatusCommand extends $Command< + GetSagemakerServicecatalogPortfolioStatusCommandInput, + GetSagemakerServicecatalogPortfolioStatusCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: GetSagemakerServicecatalogPortfolioStatusCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler< + GetSagemakerServicecatalogPortfolioStatusCommandInput, + GetSagemakerServicecatalogPortfolioStatusCommandOutput + > { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "GetSagemakerServicecatalogPortfolioStatusCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: GetSagemakerServicecatalogPortfolioStatusInput.filterSensitiveLog, + outputFilterSensitiveLog: GetSagemakerServicecatalogPortfolioStatusOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: GetSagemakerServicecatalogPortfolioStatusCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListActionsCommand.ts b/clients/client-sagemaker/commands/ListActionsCommand.ts new file mode 100644 index 000000000000..8adc9a183e93 --- /dev/null +++ b/clients/client-sagemaker/commands/ListActionsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListActionsRequest, ListActionsResponse } from "../models/models_1"; +import { + deserializeAws_json1_1ListActionsCommand, + serializeAws_json1_1ListActionsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListActionsCommandInput = ListActionsRequest; +export type ListActionsCommandOutput = ListActionsResponse & __MetadataBearer; + +/** + *

    Lists the actions in your account and their properties.

    + */ +export class ListActionsCommand extends $Command< + ListActionsCommandInput, + ListActionsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListActionsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListActionsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListActionsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListActionsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListActionsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListActionsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListActionsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListArtifactsCommand.ts b/clients/client-sagemaker/commands/ListArtifactsCommand.ts new file mode 100644 index 000000000000..fe2bc0eb7867 --- /dev/null +++ b/clients/client-sagemaker/commands/ListArtifactsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListArtifactsRequest, ListArtifactsResponse } from "../models/models_1"; +import { + deserializeAws_json1_1ListArtifactsCommand, + serializeAws_json1_1ListArtifactsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListArtifactsCommandInput = ListArtifactsRequest; +export type ListArtifactsCommandOutput = ListArtifactsResponse & __MetadataBearer; + +/** + *

    Lists the artifacts in your account and their properties.

    + */ +export class ListArtifactsCommand extends $Command< + ListArtifactsCommandInput, + ListArtifactsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListArtifactsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListArtifactsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListArtifactsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListArtifactsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListArtifactsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListArtifactsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListArtifactsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListAssociationsCommand.ts b/clients/client-sagemaker/commands/ListAssociationsCommand.ts new file mode 100644 index 000000000000..267d0b38e5e1 --- /dev/null +++ b/clients/client-sagemaker/commands/ListAssociationsCommand.ts @@ -0,0 +1,89 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListAssociationsRequest } from "../models/models_1"; +import { ListAssociationsResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListAssociationsCommand, + serializeAws_json1_1ListAssociationsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListAssociationsCommandInput = ListAssociationsRequest; +export type ListAssociationsCommandOutput = ListAssociationsResponse & __MetadataBearer; + +/** + *

    Lists the associations in your account and their properties.

    + */ +export class ListAssociationsCommand extends $Command< + ListAssociationsCommandInput, + ListAssociationsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListAssociationsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListAssociationsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListAssociationsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListAssociationsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListAssociationsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListAssociationsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListAssociationsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListAutoMLJobsCommand.ts b/clients/client-sagemaker/commands/ListAutoMLJobsCommand.ts index 2807f8196c71..35e5b08ffb08 100644 --- a/clients/client-sagemaker/commands/ListAutoMLJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListAutoMLJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListAutoMLJobsRequest, ListAutoMLJobsResponse } from "../models/models_1"; +import { ListAutoMLJobsRequest, ListAutoMLJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListAutoMLJobsCommand, serializeAws_json1_1ListAutoMLJobsCommand, diff --git a/clients/client-sagemaker/commands/ListCandidatesForAutoMLJobCommand.ts b/clients/client-sagemaker/commands/ListCandidatesForAutoMLJobCommand.ts index 9923ee42cdce..dbff2953b478 100644 --- a/clients/client-sagemaker/commands/ListCandidatesForAutoMLJobCommand.ts +++ b/clients/client-sagemaker/commands/ListCandidatesForAutoMLJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListCandidatesForAutoMLJobRequest, ListCandidatesForAutoMLJobResponse } from "../models/models_1"; +import { ListCandidatesForAutoMLJobRequest, ListCandidatesForAutoMLJobResponse } from "../models/models_2"; import { deserializeAws_json1_1ListCandidatesForAutoMLJobCommand, serializeAws_json1_1ListCandidatesForAutoMLJobCommand, diff --git a/clients/client-sagemaker/commands/ListCodeRepositoriesCommand.ts b/clients/client-sagemaker/commands/ListCodeRepositoriesCommand.ts index 2581282e208b..eea6e4d34e21 100644 --- a/clients/client-sagemaker/commands/ListCodeRepositoriesCommand.ts +++ b/clients/client-sagemaker/commands/ListCodeRepositoriesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListCodeRepositoriesInput, ListCodeRepositoriesOutput } from "../models/models_1"; +import { ListCodeRepositoriesInput, ListCodeRepositoriesOutput } from "../models/models_2"; import { deserializeAws_json1_1ListCodeRepositoriesCommand, serializeAws_json1_1ListCodeRepositoriesCommand, diff --git a/clients/client-sagemaker/commands/ListCompilationJobsCommand.ts b/clients/client-sagemaker/commands/ListCompilationJobsCommand.ts index 60300f22da60..271d36a1bbe4 100644 --- a/clients/client-sagemaker/commands/ListCompilationJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListCompilationJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListCompilationJobsRequest, ListCompilationJobsResponse } from "../models/models_1"; +import { ListCompilationJobsRequest, ListCompilationJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListCompilationJobsCommand, serializeAws_json1_1ListCompilationJobsCommand, diff --git a/clients/client-sagemaker/commands/ListContextsCommand.ts b/clients/client-sagemaker/commands/ListContextsCommand.ts new file mode 100644 index 000000000000..16fd6bf6b340 --- /dev/null +++ b/clients/client-sagemaker/commands/ListContextsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListContextsRequest, ListContextsResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListContextsCommand, + serializeAws_json1_1ListContextsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListContextsCommandInput = ListContextsRequest; +export type ListContextsCommandOutput = ListContextsResponse & __MetadataBearer; + +/** + *

    Lists the contexts in your account and their properties.

    + */ +export class ListContextsCommand extends $Command< + ListContextsCommandInput, + ListContextsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListContextsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListContextsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListContextsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListContextsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListContextsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListContextsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListContextsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListDomainsCommand.ts b/clients/client-sagemaker/commands/ListDomainsCommand.ts index 6fde955edd04..f1593b3b9b08 100644 --- a/clients/client-sagemaker/commands/ListDomainsCommand.ts +++ b/clients/client-sagemaker/commands/ListDomainsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListDomainsRequest, ListDomainsResponse } from "../models/models_1"; +import { ListDomainsRequest, ListDomainsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListDomainsCommand, serializeAws_json1_1ListDomainsCommand, diff --git a/clients/client-sagemaker/commands/ListEndpointConfigsCommand.ts b/clients/client-sagemaker/commands/ListEndpointConfigsCommand.ts index 38a27faeb1ba..1a65f42e2dad 100644 --- a/clients/client-sagemaker/commands/ListEndpointConfigsCommand.ts +++ b/clients/client-sagemaker/commands/ListEndpointConfigsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListEndpointConfigsInput, ListEndpointConfigsOutput } from "../models/models_1"; +import { ListEndpointConfigsInput, ListEndpointConfigsOutput } from "../models/models_2"; import { deserializeAws_json1_1ListEndpointConfigsCommand, serializeAws_json1_1ListEndpointConfigsCommand, diff --git a/clients/client-sagemaker/commands/ListEndpointsCommand.ts b/clients/client-sagemaker/commands/ListEndpointsCommand.ts index 84b7100602bb..4e7a48d6255e 100644 --- a/clients/client-sagemaker/commands/ListEndpointsCommand.ts +++ b/clients/client-sagemaker/commands/ListEndpointsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListEndpointsInput, ListEndpointsOutput } from "../models/models_1"; +import { ListEndpointsInput, ListEndpointsOutput } from "../models/models_2"; import { deserializeAws_json1_1ListEndpointsCommand, serializeAws_json1_1ListEndpointsCommand, diff --git a/clients/client-sagemaker/commands/ListExperimentsCommand.ts b/clients/client-sagemaker/commands/ListExperimentsCommand.ts index 9460582e0a6f..cfa5b0c008bf 100644 --- a/clients/client-sagemaker/commands/ListExperimentsCommand.ts +++ b/clients/client-sagemaker/commands/ListExperimentsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListExperimentsRequest, ListExperimentsResponse } from "../models/models_1"; +import { ListExperimentsRequest, ListExperimentsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListExperimentsCommand, serializeAws_json1_1ListExperimentsCommand, diff --git a/clients/client-sagemaker/commands/ListFeatureGroupsCommand.ts b/clients/client-sagemaker/commands/ListFeatureGroupsCommand.ts new file mode 100644 index 000000000000..7f424e3dcc1e --- /dev/null +++ b/clients/client-sagemaker/commands/ListFeatureGroupsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListFeatureGroupsRequest, ListFeatureGroupsResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListFeatureGroupsCommand, + serializeAws_json1_1ListFeatureGroupsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListFeatureGroupsCommandInput = ListFeatureGroupsRequest; +export type ListFeatureGroupsCommandOutput = ListFeatureGroupsResponse & __MetadataBearer; + +/** + *

    List FeatureGroups based on given filter and order.

    + */ +export class ListFeatureGroupsCommand extends $Command< + ListFeatureGroupsCommandInput, + ListFeatureGroupsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListFeatureGroupsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListFeatureGroupsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListFeatureGroupsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListFeatureGroupsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListFeatureGroupsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListFeatureGroupsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListFeatureGroupsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListFlowDefinitionsCommand.ts b/clients/client-sagemaker/commands/ListFlowDefinitionsCommand.ts index a73e5ae7e79f..ac07f82e72ee 100644 --- a/clients/client-sagemaker/commands/ListFlowDefinitionsCommand.ts +++ b/clients/client-sagemaker/commands/ListFlowDefinitionsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListFlowDefinitionsRequest, ListFlowDefinitionsResponse } from "../models/models_1"; +import { ListFlowDefinitionsRequest, ListFlowDefinitionsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListFlowDefinitionsCommand, serializeAws_json1_1ListFlowDefinitionsCommand, diff --git a/clients/client-sagemaker/commands/ListHumanTaskUisCommand.ts b/clients/client-sagemaker/commands/ListHumanTaskUisCommand.ts index d48eb1207f78..04dc0cf605e0 100644 --- a/clients/client-sagemaker/commands/ListHumanTaskUisCommand.ts +++ b/clients/client-sagemaker/commands/ListHumanTaskUisCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListHumanTaskUisRequest, ListHumanTaskUisResponse } from "../models/models_1"; +import { ListHumanTaskUisRequest, ListHumanTaskUisResponse } from "../models/models_2"; import { deserializeAws_json1_1ListHumanTaskUisCommand, serializeAws_json1_1ListHumanTaskUisCommand, diff --git a/clients/client-sagemaker/commands/ListHyperParameterTuningJobsCommand.ts b/clients/client-sagemaker/commands/ListHyperParameterTuningJobsCommand.ts index e01fb417a64e..531c6b1aad4b 100644 --- a/clients/client-sagemaker/commands/ListHyperParameterTuningJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListHyperParameterTuningJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListHyperParameterTuningJobsRequest, ListHyperParameterTuningJobsResponse } from "../models/models_1"; +import { ListHyperParameterTuningJobsRequest, ListHyperParameterTuningJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListHyperParameterTuningJobsCommand, serializeAws_json1_1ListHyperParameterTuningJobsCommand, diff --git a/clients/client-sagemaker/commands/ListImageVersionsCommand.ts b/clients/client-sagemaker/commands/ListImageVersionsCommand.ts index 63f392144732..bafb988368aa 100644 --- a/clients/client-sagemaker/commands/ListImageVersionsCommand.ts +++ b/clients/client-sagemaker/commands/ListImageVersionsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListImageVersionsRequest, ListImageVersionsResponse } from "../models/models_1"; +import { ListImageVersionsRequest, ListImageVersionsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListImageVersionsCommand, serializeAws_json1_1ListImageVersionsCommand, diff --git a/clients/client-sagemaker/commands/ListImagesCommand.ts b/clients/client-sagemaker/commands/ListImagesCommand.ts index 0a7cd8a37f29..9cbef5b7a3fe 100644 --- a/clients/client-sagemaker/commands/ListImagesCommand.ts +++ b/clients/client-sagemaker/commands/ListImagesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListImagesRequest, ListImagesResponse } from "../models/models_1"; +import { ListImagesRequest, ListImagesResponse } from "../models/models_2"; import { deserializeAws_json1_1ListImagesCommand, serializeAws_json1_1ListImagesCommand, diff --git a/clients/client-sagemaker/commands/ListLabelingJobsCommand.ts b/clients/client-sagemaker/commands/ListLabelingJobsCommand.ts index 1ffa30e9954f..b91ea7899a86 100644 --- a/clients/client-sagemaker/commands/ListLabelingJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListLabelingJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListLabelingJobsRequest, ListLabelingJobsResponse } from "../models/models_1"; +import { ListLabelingJobsRequest, ListLabelingJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListLabelingJobsCommand, serializeAws_json1_1ListLabelingJobsCommand, diff --git a/clients/client-sagemaker/commands/ListLabelingJobsForWorkteamCommand.ts b/clients/client-sagemaker/commands/ListLabelingJobsForWorkteamCommand.ts index 7cf0d4928b1b..c392583dc899 100644 --- a/clients/client-sagemaker/commands/ListLabelingJobsForWorkteamCommand.ts +++ b/clients/client-sagemaker/commands/ListLabelingJobsForWorkteamCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListLabelingJobsForWorkteamRequest, ListLabelingJobsForWorkteamResponse } from "../models/models_1"; +import { ListLabelingJobsForWorkteamRequest, ListLabelingJobsForWorkteamResponse } from "../models/models_2"; import { deserializeAws_json1_1ListLabelingJobsForWorkteamCommand, serializeAws_json1_1ListLabelingJobsForWorkteamCommand, diff --git a/clients/client-sagemaker/commands/ListModelPackageGroupsCommand.ts b/clients/client-sagemaker/commands/ListModelPackageGroupsCommand.ts new file mode 100644 index 000000000000..e2c7721a3743 --- /dev/null +++ b/clients/client-sagemaker/commands/ListModelPackageGroupsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListModelPackageGroupsInput, ListModelPackageGroupsOutput } from "../models/models_2"; +import { + deserializeAws_json1_1ListModelPackageGroupsCommand, + serializeAws_json1_1ListModelPackageGroupsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListModelPackageGroupsCommandInput = ListModelPackageGroupsInput; +export type ListModelPackageGroupsCommandOutput = ListModelPackageGroupsOutput & __MetadataBearer; + +/** + *

    Gets a list of the model groups in your AWS account.

    + */ +export class ListModelPackageGroupsCommand extends $Command< + ListModelPackageGroupsCommandInput, + ListModelPackageGroupsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListModelPackageGroupsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListModelPackageGroupsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListModelPackageGroupsInput.filterSensitiveLog, + outputFilterSensitiveLog: ListModelPackageGroupsOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListModelPackageGroupsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListModelPackageGroupsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListModelPackageGroupsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListModelPackagesCommand.ts b/clients/client-sagemaker/commands/ListModelPackagesCommand.ts index 56fa062b077e..0501cdcc30de 100644 --- a/clients/client-sagemaker/commands/ListModelPackagesCommand.ts +++ b/clients/client-sagemaker/commands/ListModelPackagesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListModelPackagesInput, ListModelPackagesOutput } from "../models/models_1"; +import { ListModelPackagesInput, ListModelPackagesOutput } from "../models/models_2"; import { deserializeAws_json1_1ListModelPackagesCommand, serializeAws_json1_1ListModelPackagesCommand, diff --git a/clients/client-sagemaker/commands/ListModelsCommand.ts b/clients/client-sagemaker/commands/ListModelsCommand.ts index 2f7e9dee64aa..affb95ea74e8 100644 --- a/clients/client-sagemaker/commands/ListModelsCommand.ts +++ b/clients/client-sagemaker/commands/ListModelsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListModelsInput, ListModelsOutput } from "../models/models_1"; +import { ListModelsInput, ListModelsOutput } from "../models/models_2"; import { deserializeAws_json1_1ListModelsCommand, serializeAws_json1_1ListModelsCommand, diff --git a/clients/client-sagemaker/commands/ListMonitoringExecutionsCommand.ts b/clients/client-sagemaker/commands/ListMonitoringExecutionsCommand.ts index 76ffe7f0ef14..e1ad4e522d9a 100644 --- a/clients/client-sagemaker/commands/ListMonitoringExecutionsCommand.ts +++ b/clients/client-sagemaker/commands/ListMonitoringExecutionsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListMonitoringExecutionsRequest, ListMonitoringExecutionsResponse } from "../models/models_1"; +import { ListMonitoringExecutionsRequest, ListMonitoringExecutionsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListMonitoringExecutionsCommand, serializeAws_json1_1ListMonitoringExecutionsCommand, diff --git a/clients/client-sagemaker/commands/ListMonitoringSchedulesCommand.ts b/clients/client-sagemaker/commands/ListMonitoringSchedulesCommand.ts index 07cbd1979696..342786480ca9 100644 --- a/clients/client-sagemaker/commands/ListMonitoringSchedulesCommand.ts +++ b/clients/client-sagemaker/commands/ListMonitoringSchedulesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListMonitoringSchedulesRequest, ListMonitoringSchedulesResponse } from "../models/models_1"; +import { ListMonitoringSchedulesRequest, ListMonitoringSchedulesResponse } from "../models/models_2"; import { deserializeAws_json1_1ListMonitoringSchedulesCommand, serializeAws_json1_1ListMonitoringSchedulesCommand, diff --git a/clients/client-sagemaker/commands/ListNotebookInstanceLifecycleConfigsCommand.ts b/clients/client-sagemaker/commands/ListNotebookInstanceLifecycleConfigsCommand.ts index 79e421321195..35feef558527 100644 --- a/clients/client-sagemaker/commands/ListNotebookInstanceLifecycleConfigsCommand.ts +++ b/clients/client-sagemaker/commands/ListNotebookInstanceLifecycleConfigsCommand.ts @@ -2,7 +2,7 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } import { ListNotebookInstanceLifecycleConfigsInput, ListNotebookInstanceLifecycleConfigsOutput, -} from "../models/models_1"; +} from "../models/models_2"; import { deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommand, serializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommand, diff --git a/clients/client-sagemaker/commands/ListNotebookInstancesCommand.ts b/clients/client-sagemaker/commands/ListNotebookInstancesCommand.ts index bbadd6dbba0f..47490332ad21 100644 --- a/clients/client-sagemaker/commands/ListNotebookInstancesCommand.ts +++ b/clients/client-sagemaker/commands/ListNotebookInstancesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListNotebookInstancesInput, ListNotebookInstancesOutput } from "../models/models_1"; +import { ListNotebookInstancesInput, ListNotebookInstancesOutput } from "../models/models_2"; import { deserializeAws_json1_1ListNotebookInstancesCommand, serializeAws_json1_1ListNotebookInstancesCommand, diff --git a/clients/client-sagemaker/commands/ListPipelineExecutionStepsCommand.ts b/clients/client-sagemaker/commands/ListPipelineExecutionStepsCommand.ts new file mode 100644 index 000000000000..07f459086e0f --- /dev/null +++ b/clients/client-sagemaker/commands/ListPipelineExecutionStepsCommand.ts @@ -0,0 +1,91 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListPipelineExecutionStepsRequest, ListPipelineExecutionStepsResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListPipelineExecutionStepsCommand, + serializeAws_json1_1ListPipelineExecutionStepsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListPipelineExecutionStepsCommandInput = ListPipelineExecutionStepsRequest; +export type ListPipelineExecutionStepsCommandOutput = ListPipelineExecutionStepsResponse & __MetadataBearer; + +/** + *

    Gets a list of PipeLineExecutionStep objects.

    + */ +export class ListPipelineExecutionStepsCommand extends $Command< + ListPipelineExecutionStepsCommandInput, + ListPipelineExecutionStepsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListPipelineExecutionStepsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListPipelineExecutionStepsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListPipelineExecutionStepsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListPipelineExecutionStepsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListPipelineExecutionStepsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListPipelineExecutionStepsCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1ListPipelineExecutionStepsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListPipelineExecutionsCommand.ts b/clients/client-sagemaker/commands/ListPipelineExecutionsCommand.ts new file mode 100644 index 000000000000..4f2f77ef6ddc --- /dev/null +++ b/clients/client-sagemaker/commands/ListPipelineExecutionsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListPipelineExecutionsRequest, ListPipelineExecutionsResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListPipelineExecutionsCommand, + serializeAws_json1_1ListPipelineExecutionsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListPipelineExecutionsCommandInput = ListPipelineExecutionsRequest; +export type ListPipelineExecutionsCommandOutput = ListPipelineExecutionsResponse & __MetadataBearer; + +/** + *

    Gets a list of the pipeline executions.

    + */ +export class ListPipelineExecutionsCommand extends $Command< + ListPipelineExecutionsCommandInput, + ListPipelineExecutionsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListPipelineExecutionsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListPipelineExecutionsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListPipelineExecutionsRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListPipelineExecutionsResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListPipelineExecutionsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListPipelineExecutionsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListPipelineExecutionsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListPipelineParametersForExecutionCommand.ts b/clients/client-sagemaker/commands/ListPipelineParametersForExecutionCommand.ts new file mode 100644 index 000000000000..5a66e4135bf8 --- /dev/null +++ b/clients/client-sagemaker/commands/ListPipelineParametersForExecutionCommand.ts @@ -0,0 +1,98 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { + ListPipelineParametersForExecutionRequest, + ListPipelineParametersForExecutionResponse, +} from "../models/models_2"; +import { + deserializeAws_json1_1ListPipelineParametersForExecutionCommand, + serializeAws_json1_1ListPipelineParametersForExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListPipelineParametersForExecutionCommandInput = ListPipelineParametersForExecutionRequest; +export type ListPipelineParametersForExecutionCommandOutput = ListPipelineParametersForExecutionResponse & + __MetadataBearer; + +/** + *

    Gets a list of parameters for a pipeline execution.

    + */ +export class ListPipelineParametersForExecutionCommand extends $Command< + ListPipelineParametersForExecutionCommandInput, + ListPipelineParametersForExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListPipelineParametersForExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListPipelineParametersForExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListPipelineParametersForExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListPipelineParametersForExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize( + input: ListPipelineParametersForExecutionCommandInput, + context: __SerdeContext + ): Promise<__HttpRequest> { + return serializeAws_json1_1ListPipelineParametersForExecutionCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1ListPipelineParametersForExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListPipelinesCommand.ts b/clients/client-sagemaker/commands/ListPipelinesCommand.ts new file mode 100644 index 000000000000..c3e1a34d05b7 --- /dev/null +++ b/clients/client-sagemaker/commands/ListPipelinesCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListPipelinesRequest, ListPipelinesResponse } from "../models/models_2"; +import { + deserializeAws_json1_1ListPipelinesCommand, + serializeAws_json1_1ListPipelinesCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListPipelinesCommandInput = ListPipelinesRequest; +export type ListPipelinesCommandOutput = ListPipelinesResponse & __MetadataBearer; + +/** + *

    Gets a list of pipelines.

    + */ +export class ListPipelinesCommand extends $Command< + ListPipelinesCommandInput, + ListPipelinesCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListPipelinesCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListPipelinesCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListPipelinesRequest.filterSensitiveLog, + outputFilterSensitiveLog: ListPipelinesResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListPipelinesCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListPipelinesCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListPipelinesCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListProcessingJobsCommand.ts b/clients/client-sagemaker/commands/ListProcessingJobsCommand.ts index 5b2fd527a025..eab43fcc2658 100644 --- a/clients/client-sagemaker/commands/ListProcessingJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListProcessingJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListProcessingJobsRequest, ListProcessingJobsResponse } from "../models/models_1"; +import { ListProcessingJobsRequest, ListProcessingJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListProcessingJobsCommand, serializeAws_json1_1ListProcessingJobsCommand, diff --git a/clients/client-sagemaker/commands/ListProjectsCommand.ts b/clients/client-sagemaker/commands/ListProjectsCommand.ts new file mode 100644 index 000000000000..bdbc2b05e994 --- /dev/null +++ b/clients/client-sagemaker/commands/ListProjectsCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { ListProjectsInput, ListProjectsOutput } from "../models/models_2"; +import { + deserializeAws_json1_1ListProjectsCommand, + serializeAws_json1_1ListProjectsCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type ListProjectsCommandInput = ListProjectsInput; +export type ListProjectsCommandOutput = ListProjectsOutput & __MetadataBearer; + +/** + *

    Gets a list of the projects in an AWS account.

    + */ +export class ListProjectsCommand extends $Command< + ListProjectsCommandInput, + ListProjectsCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: ListProjectsCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "ListProjectsCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: ListProjectsInput.filterSensitiveLog, + outputFilterSensitiveLog: ListProjectsOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: ListProjectsCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1ListProjectsCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1ListProjectsCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/ListSubscribedWorkteamsCommand.ts b/clients/client-sagemaker/commands/ListSubscribedWorkteamsCommand.ts index 486060d3e8ca..1a6e343e88ee 100644 --- a/clients/client-sagemaker/commands/ListSubscribedWorkteamsCommand.ts +++ b/clients/client-sagemaker/commands/ListSubscribedWorkteamsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListSubscribedWorkteamsRequest, ListSubscribedWorkteamsResponse } from "../models/models_1"; +import { ListSubscribedWorkteamsRequest, ListSubscribedWorkteamsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListSubscribedWorkteamsCommand, serializeAws_json1_1ListSubscribedWorkteamsCommand, diff --git a/clients/client-sagemaker/commands/ListTagsCommand.ts b/clients/client-sagemaker/commands/ListTagsCommand.ts index 0d09ba9e32fc..8441d1e3e2d2 100644 --- a/clients/client-sagemaker/commands/ListTagsCommand.ts +++ b/clients/client-sagemaker/commands/ListTagsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListTagsInput, ListTagsOutput } from "../models/models_1"; +import { ListTagsInput, ListTagsOutput } from "../models/models_2"; import { deserializeAws_json1_1ListTagsCommand, serializeAws_json1_1ListTagsCommand } from "../protocols/Aws_json1_1"; import { getSerdePlugin } from "@aws-sdk/middleware-serde"; import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; diff --git a/clients/client-sagemaker/commands/ListTrainingJobsCommand.ts b/clients/client-sagemaker/commands/ListTrainingJobsCommand.ts index e5dfc67c1507..45ebf993a2cb 100644 --- a/clients/client-sagemaker/commands/ListTrainingJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListTrainingJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListTrainingJobsRequest, ListTrainingJobsResponse } from "../models/models_1"; +import { ListTrainingJobsRequest, ListTrainingJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListTrainingJobsCommand, serializeAws_json1_1ListTrainingJobsCommand, diff --git a/clients/client-sagemaker/commands/ListTrainingJobsForHyperParameterTuningJobCommand.ts b/clients/client-sagemaker/commands/ListTrainingJobsForHyperParameterTuningJobCommand.ts index 3b8fd10007e2..574b17c27f58 100644 --- a/clients/client-sagemaker/commands/ListTrainingJobsForHyperParameterTuningJobCommand.ts +++ b/clients/client-sagemaker/commands/ListTrainingJobsForHyperParameterTuningJobCommand.ts @@ -2,7 +2,7 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } import { ListTrainingJobsForHyperParameterTuningJobRequest, ListTrainingJobsForHyperParameterTuningJobResponse, -} from "../models/models_1"; +} from "../models/models_2"; import { deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommand, serializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommand, diff --git a/clients/client-sagemaker/commands/ListTransformJobsCommand.ts b/clients/client-sagemaker/commands/ListTransformJobsCommand.ts index 9c78927a4e63..4cdd58e7adfe 100644 --- a/clients/client-sagemaker/commands/ListTransformJobsCommand.ts +++ b/clients/client-sagemaker/commands/ListTransformJobsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListTransformJobsRequest, ListTransformJobsResponse } from "../models/models_1"; +import { ListTransformJobsRequest, ListTransformJobsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListTransformJobsCommand, serializeAws_json1_1ListTransformJobsCommand, diff --git a/clients/client-sagemaker/commands/ListTrialComponentsCommand.ts b/clients/client-sagemaker/commands/ListTrialComponentsCommand.ts index d17d7ab2e570..0534ad95059d 100644 --- a/clients/client-sagemaker/commands/ListTrialComponentsCommand.ts +++ b/clients/client-sagemaker/commands/ListTrialComponentsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListTrialComponentsRequest, ListTrialComponentsResponse } from "../models/models_1"; +import { ListTrialComponentsRequest, ListTrialComponentsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListTrialComponentsCommand, serializeAws_json1_1ListTrialComponentsCommand, diff --git a/clients/client-sagemaker/commands/ListTrialsCommand.ts b/clients/client-sagemaker/commands/ListTrialsCommand.ts index bf490174efbf..25a349326577 100644 --- a/clients/client-sagemaker/commands/ListTrialsCommand.ts +++ b/clients/client-sagemaker/commands/ListTrialsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListTrialsRequest, ListTrialsResponse } from "../models/models_1"; +import { ListTrialsRequest, ListTrialsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListTrialsCommand, serializeAws_json1_1ListTrialsCommand, diff --git a/clients/client-sagemaker/commands/ListUserProfilesCommand.ts b/clients/client-sagemaker/commands/ListUserProfilesCommand.ts index 94e8c349133d..47bf2aaceaba 100644 --- a/clients/client-sagemaker/commands/ListUserProfilesCommand.ts +++ b/clients/client-sagemaker/commands/ListUserProfilesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListUserProfilesRequest, ListUserProfilesResponse } from "../models/models_1"; +import { ListUserProfilesRequest, ListUserProfilesResponse } from "../models/models_2"; import { deserializeAws_json1_1ListUserProfilesCommand, serializeAws_json1_1ListUserProfilesCommand, diff --git a/clients/client-sagemaker/commands/ListWorkforcesCommand.ts b/clients/client-sagemaker/commands/ListWorkforcesCommand.ts index 8620b50a54c7..ccc347cedf46 100644 --- a/clients/client-sagemaker/commands/ListWorkforcesCommand.ts +++ b/clients/client-sagemaker/commands/ListWorkforcesCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListWorkforcesRequest, ListWorkforcesResponse } from "../models/models_1"; +import { ListWorkforcesRequest, ListWorkforcesResponse } from "../models/models_2"; import { deserializeAws_json1_1ListWorkforcesCommand, serializeAws_json1_1ListWorkforcesCommand, diff --git a/clients/client-sagemaker/commands/ListWorkteamsCommand.ts b/clients/client-sagemaker/commands/ListWorkteamsCommand.ts index 2741a900c7ef..77e96c287b28 100644 --- a/clients/client-sagemaker/commands/ListWorkteamsCommand.ts +++ b/clients/client-sagemaker/commands/ListWorkteamsCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { ListWorkteamsRequest, ListWorkteamsResponse } from "../models/models_1"; +import { ListWorkteamsRequest, ListWorkteamsResponse } from "../models/models_2"; import { deserializeAws_json1_1ListWorkteamsCommand, serializeAws_json1_1ListWorkteamsCommand, diff --git a/clients/client-sagemaker/commands/PutModelPackageGroupPolicyCommand.ts b/clients/client-sagemaker/commands/PutModelPackageGroupPolicyCommand.ts new file mode 100644 index 000000000000..a4c568d3ba4b --- /dev/null +++ b/clients/client-sagemaker/commands/PutModelPackageGroupPolicyCommand.ts @@ -0,0 +1,93 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { PutModelPackageGroupPolicyInput, PutModelPackageGroupPolicyOutput } from "../models/models_2"; +import { + deserializeAws_json1_1PutModelPackageGroupPolicyCommand, + serializeAws_json1_1PutModelPackageGroupPolicyCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type PutModelPackageGroupPolicyCommandInput = PutModelPackageGroupPolicyInput; +export type PutModelPackageGroupPolicyCommandOutput = PutModelPackageGroupPolicyOutput & __MetadataBearer; + +/** + *

    Adds a resouce policy to control access to a model group. For information about + * resoure policies, see Identity-based + * policies and resource-based policies in the AWS Identity and Access Management User Guide..

    + */ +export class PutModelPackageGroupPolicyCommand extends $Command< + PutModelPackageGroupPolicyCommandInput, + PutModelPackageGroupPolicyCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: PutModelPackageGroupPolicyCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "PutModelPackageGroupPolicyCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: PutModelPackageGroupPolicyInput.filterSensitiveLog, + outputFilterSensitiveLog: PutModelPackageGroupPolicyOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: PutModelPackageGroupPolicyCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1PutModelPackageGroupPolicyCommand(input, context); + } + + private deserialize( + output: __HttpResponse, + context: __SerdeContext + ): Promise { + return deserializeAws_json1_1PutModelPackageGroupPolicyCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/RenderUiTemplateCommand.ts b/clients/client-sagemaker/commands/RenderUiTemplateCommand.ts index 4b4de5975bdd..0f01daa88f88 100644 --- a/clients/client-sagemaker/commands/RenderUiTemplateCommand.ts +++ b/clients/client-sagemaker/commands/RenderUiTemplateCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { RenderUiTemplateRequest, RenderUiTemplateResponse } from "../models/models_1"; +import { RenderUiTemplateRequest, RenderUiTemplateResponse } from "../models/models_2"; import { deserializeAws_json1_1RenderUiTemplateCommand, serializeAws_json1_1RenderUiTemplateCommand, diff --git a/clients/client-sagemaker/commands/SearchCommand.ts b/clients/client-sagemaker/commands/SearchCommand.ts index 971be9d9b0ab..dc92e79b6f75 100644 --- a/clients/client-sagemaker/commands/SearchCommand.ts +++ b/clients/client-sagemaker/commands/SearchCommand.ts @@ -1,6 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { SearchResponse } from "../models/models_1"; -import { SearchRequest } from "../models/models_2"; +import { SearchRequest, SearchResponse } from "../models/models_2"; import { deserializeAws_json1_1SearchCommand, serializeAws_json1_1SearchCommand } from "../protocols/Aws_json1_1"; import { getSerdePlugin } from "@aws-sdk/middleware-serde"; import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; diff --git a/clients/client-sagemaker/commands/StartMonitoringScheduleCommand.ts b/clients/client-sagemaker/commands/StartMonitoringScheduleCommand.ts index 935b4dbca576..416ae6bd17a2 100644 --- a/clients/client-sagemaker/commands/StartMonitoringScheduleCommand.ts +++ b/clients/client-sagemaker/commands/StartMonitoringScheduleCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StartMonitoringScheduleRequest } from "../models/models_1"; +import { StartMonitoringScheduleRequest } from "../models/models_2"; import { deserializeAws_json1_1StartMonitoringScheduleCommand, serializeAws_json1_1StartMonitoringScheduleCommand, diff --git a/clients/client-sagemaker/commands/StartNotebookInstanceCommand.ts b/clients/client-sagemaker/commands/StartNotebookInstanceCommand.ts index 3b78ec4cda3c..2b7fc2481905 100644 --- a/clients/client-sagemaker/commands/StartNotebookInstanceCommand.ts +++ b/clients/client-sagemaker/commands/StartNotebookInstanceCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StartNotebookInstanceInput } from "../models/models_1"; +import { StartNotebookInstanceInput } from "../models/models_2"; import { deserializeAws_json1_1StartNotebookInstanceCommand, serializeAws_json1_1StartNotebookInstanceCommand, diff --git a/clients/client-sagemaker/commands/StartPipelineExecutionCommand.ts b/clients/client-sagemaker/commands/StartPipelineExecutionCommand.ts new file mode 100644 index 000000000000..83471b04c59d --- /dev/null +++ b/clients/client-sagemaker/commands/StartPipelineExecutionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { StartPipelineExecutionRequest, StartPipelineExecutionResponse } from "../models/models_2"; +import { + deserializeAws_json1_1StartPipelineExecutionCommand, + serializeAws_json1_1StartPipelineExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StartPipelineExecutionCommandInput = StartPipelineExecutionRequest; +export type StartPipelineExecutionCommandOutput = StartPipelineExecutionResponse & __MetadataBearer; + +/** + *

    Starts a pipeline execution.

    + */ +export class StartPipelineExecutionCommand extends $Command< + StartPipelineExecutionCommandInput, + StartPipelineExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StartPipelineExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "StartPipelineExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StartPipelineExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: StartPipelineExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StartPipelineExecutionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1StartPipelineExecutionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1StartPipelineExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/StopAutoMLJobCommand.ts b/clients/client-sagemaker/commands/StopAutoMLJobCommand.ts index 186337bb737f..42f865fda8db 100644 --- a/clients/client-sagemaker/commands/StopAutoMLJobCommand.ts +++ b/clients/client-sagemaker/commands/StopAutoMLJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopAutoMLJobRequest } from "../models/models_1"; +import { StopAutoMLJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopAutoMLJobCommand, serializeAws_json1_1StopAutoMLJobCommand, diff --git a/clients/client-sagemaker/commands/StopCompilationJobCommand.ts b/clients/client-sagemaker/commands/StopCompilationJobCommand.ts index 7c6ce80ac644..fd0247912eb8 100644 --- a/clients/client-sagemaker/commands/StopCompilationJobCommand.ts +++ b/clients/client-sagemaker/commands/StopCompilationJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopCompilationJobRequest } from "../models/models_1"; +import { StopCompilationJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopCompilationJobCommand, serializeAws_json1_1StopCompilationJobCommand, diff --git a/clients/client-sagemaker/commands/StopHyperParameterTuningJobCommand.ts b/clients/client-sagemaker/commands/StopHyperParameterTuningJobCommand.ts index b9378b32120a..a89fabc72d19 100644 --- a/clients/client-sagemaker/commands/StopHyperParameterTuningJobCommand.ts +++ b/clients/client-sagemaker/commands/StopHyperParameterTuningJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopHyperParameterTuningJobRequest } from "../models/models_1"; +import { StopHyperParameterTuningJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopHyperParameterTuningJobCommand, serializeAws_json1_1StopHyperParameterTuningJobCommand, diff --git a/clients/client-sagemaker/commands/StopLabelingJobCommand.ts b/clients/client-sagemaker/commands/StopLabelingJobCommand.ts index c57383fd380c..ca3f24202284 100644 --- a/clients/client-sagemaker/commands/StopLabelingJobCommand.ts +++ b/clients/client-sagemaker/commands/StopLabelingJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopLabelingJobRequest } from "../models/models_1"; +import { StopLabelingJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopLabelingJobCommand, serializeAws_json1_1StopLabelingJobCommand, diff --git a/clients/client-sagemaker/commands/StopMonitoringScheduleCommand.ts b/clients/client-sagemaker/commands/StopMonitoringScheduleCommand.ts index c058f902d493..393c06007d5d 100644 --- a/clients/client-sagemaker/commands/StopMonitoringScheduleCommand.ts +++ b/clients/client-sagemaker/commands/StopMonitoringScheduleCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopMonitoringScheduleRequest } from "../models/models_1"; +import { StopMonitoringScheduleRequest } from "../models/models_2"; import { deserializeAws_json1_1StopMonitoringScheduleCommand, serializeAws_json1_1StopMonitoringScheduleCommand, diff --git a/clients/client-sagemaker/commands/StopNotebookInstanceCommand.ts b/clients/client-sagemaker/commands/StopNotebookInstanceCommand.ts index 39fa9b171921..77b30487ccac 100644 --- a/clients/client-sagemaker/commands/StopNotebookInstanceCommand.ts +++ b/clients/client-sagemaker/commands/StopNotebookInstanceCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopNotebookInstanceInput } from "../models/models_1"; +import { StopNotebookInstanceInput } from "../models/models_2"; import { deserializeAws_json1_1StopNotebookInstanceCommand, serializeAws_json1_1StopNotebookInstanceCommand, diff --git a/clients/client-sagemaker/commands/StopPipelineExecutionCommand.ts b/clients/client-sagemaker/commands/StopPipelineExecutionCommand.ts new file mode 100644 index 000000000000..ce07ff503800 --- /dev/null +++ b/clients/client-sagemaker/commands/StopPipelineExecutionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { StopPipelineExecutionRequest, StopPipelineExecutionResponse } from "../models/models_2"; +import { + deserializeAws_json1_1StopPipelineExecutionCommand, + serializeAws_json1_1StopPipelineExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type StopPipelineExecutionCommandInput = StopPipelineExecutionRequest; +export type StopPipelineExecutionCommandOutput = StopPipelineExecutionResponse & __MetadataBearer; + +/** + *

    Stops a pipeline execution.

    + */ +export class StopPipelineExecutionCommand extends $Command< + StopPipelineExecutionCommandInput, + StopPipelineExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: StopPipelineExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "StopPipelineExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: StopPipelineExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: StopPipelineExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: StopPipelineExecutionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1StopPipelineExecutionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1StopPipelineExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/StopProcessingJobCommand.ts b/clients/client-sagemaker/commands/StopProcessingJobCommand.ts index 4955ad679857..8d5a405de600 100644 --- a/clients/client-sagemaker/commands/StopProcessingJobCommand.ts +++ b/clients/client-sagemaker/commands/StopProcessingJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopProcessingJobRequest } from "../models/models_1"; +import { StopProcessingJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopProcessingJobCommand, serializeAws_json1_1StopProcessingJobCommand, diff --git a/clients/client-sagemaker/commands/StopTrainingJobCommand.ts b/clients/client-sagemaker/commands/StopTrainingJobCommand.ts index 81c91abe6b80..20e225307abd 100644 --- a/clients/client-sagemaker/commands/StopTrainingJobCommand.ts +++ b/clients/client-sagemaker/commands/StopTrainingJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopTrainingJobRequest } from "../models/models_1"; +import { StopTrainingJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopTrainingJobCommand, serializeAws_json1_1StopTrainingJobCommand, diff --git a/clients/client-sagemaker/commands/StopTransformJobCommand.ts b/clients/client-sagemaker/commands/StopTransformJobCommand.ts index 1f2e3d7f51bd..14c453bc02a1 100644 --- a/clients/client-sagemaker/commands/StopTransformJobCommand.ts +++ b/clients/client-sagemaker/commands/StopTransformJobCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { StopTransformJobRequest } from "../models/models_1"; +import { StopTransformJobRequest } from "../models/models_2"; import { deserializeAws_json1_1StopTransformJobCommand, serializeAws_json1_1StopTransformJobCommand, diff --git a/clients/client-sagemaker/commands/UpdateActionCommand.ts b/clients/client-sagemaker/commands/UpdateActionCommand.ts new file mode 100644 index 000000000000..489e5f81fef7 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdateActionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdateActionRequest, UpdateActionResponse } from "../models/models_2"; +import { + deserializeAws_json1_1UpdateActionCommand, + serializeAws_json1_1UpdateActionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateActionCommandInput = UpdateActionRequest; +export type UpdateActionCommandOutput = UpdateActionResponse & __MetadataBearer; + +/** + *

    Updates an action.

    + */ +export class UpdateActionCommand extends $Command< + UpdateActionCommandInput, + UpdateActionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateActionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdateActionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateActionRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateActionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateActionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdateActionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdateActionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/UpdateAppImageConfigCommand.ts b/clients/client-sagemaker/commands/UpdateAppImageConfigCommand.ts index 0ff758ba9112..5ff0c004cccf 100644 --- a/clients/client-sagemaker/commands/UpdateAppImageConfigCommand.ts +++ b/clients/client-sagemaker/commands/UpdateAppImageConfigCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { UpdateAppImageConfigRequest, UpdateAppImageConfigResponse } from "../models/models_1"; +import { UpdateAppImageConfigRequest, UpdateAppImageConfigResponse } from "../models/models_2"; import { deserializeAws_json1_1UpdateAppImageConfigCommand, serializeAws_json1_1UpdateAppImageConfigCommand, diff --git a/clients/client-sagemaker/commands/UpdateArtifactCommand.ts b/clients/client-sagemaker/commands/UpdateArtifactCommand.ts new file mode 100644 index 000000000000..0764bf4999b8 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdateArtifactCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdateArtifactRequest, UpdateArtifactResponse } from "../models/models_2"; +import { + deserializeAws_json1_1UpdateArtifactCommand, + serializeAws_json1_1UpdateArtifactCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateArtifactCommandInput = UpdateArtifactRequest; +export type UpdateArtifactCommandOutput = UpdateArtifactResponse & __MetadataBearer; + +/** + *

    Updates an artifact.

    + */ +export class UpdateArtifactCommand extends $Command< + UpdateArtifactCommandInput, + UpdateArtifactCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateArtifactCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdateArtifactCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateArtifactRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateArtifactResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateArtifactCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdateArtifactCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdateArtifactCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/UpdateCodeRepositoryCommand.ts b/clients/client-sagemaker/commands/UpdateCodeRepositoryCommand.ts index 7c4909a1f755..e25990748980 100644 --- a/clients/client-sagemaker/commands/UpdateCodeRepositoryCommand.ts +++ b/clients/client-sagemaker/commands/UpdateCodeRepositoryCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { UpdateCodeRepositoryInput, UpdateCodeRepositoryOutput } from "../models/models_1"; +import { UpdateCodeRepositoryInput, UpdateCodeRepositoryOutput } from "../models/models_2"; import { deserializeAws_json1_1UpdateCodeRepositoryCommand, serializeAws_json1_1UpdateCodeRepositoryCommand, diff --git a/clients/client-sagemaker/commands/UpdateContextCommand.ts b/clients/client-sagemaker/commands/UpdateContextCommand.ts new file mode 100644 index 000000000000..ca83df4929b5 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdateContextCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdateContextRequest, UpdateContextResponse } from "../models/models_2"; +import { + deserializeAws_json1_1UpdateContextCommand, + serializeAws_json1_1UpdateContextCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateContextCommandInput = UpdateContextRequest; +export type UpdateContextCommandOutput = UpdateContextResponse & __MetadataBearer; + +/** + *

    Updates a context.

    + */ +export class UpdateContextCommand extends $Command< + UpdateContextCommandInput, + UpdateContextCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateContextCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdateContextCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateContextRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdateContextResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateContextCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdateContextCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdateContextCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/UpdateDomainCommand.ts b/clients/client-sagemaker/commands/UpdateDomainCommand.ts index 1148560b972c..2638c26a7f08 100644 --- a/clients/client-sagemaker/commands/UpdateDomainCommand.ts +++ b/clients/client-sagemaker/commands/UpdateDomainCommand.ts @@ -1,5 +1,5 @@ import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; -import { UpdateDomainRequest, UpdateDomainResponse } from "../models/models_1"; +import { UpdateDomainRequest, UpdateDomainResponse } from "../models/models_2"; import { deserializeAws_json1_1UpdateDomainCommand, serializeAws_json1_1UpdateDomainCommand, diff --git a/clients/client-sagemaker/commands/UpdateModelPackageCommand.ts b/clients/client-sagemaker/commands/UpdateModelPackageCommand.ts new file mode 100644 index 000000000000..d01ba0dc0382 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdateModelPackageCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdateModelPackageInput, UpdateModelPackageOutput } from "../models/models_2"; +import { + deserializeAws_json1_1UpdateModelPackageCommand, + serializeAws_json1_1UpdateModelPackageCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdateModelPackageCommandInput = UpdateModelPackageInput; +export type UpdateModelPackageCommandOutput = UpdateModelPackageOutput & __MetadataBearer; + +/** + *

    Updates a versioned model.

    + */ +export class UpdateModelPackageCommand extends $Command< + UpdateModelPackageCommandInput, + UpdateModelPackageCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdateModelPackageCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdateModelPackageCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdateModelPackageInput.filterSensitiveLog, + outputFilterSensitiveLog: UpdateModelPackageOutput.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdateModelPackageCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdateModelPackageCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdateModelPackageCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/UpdatePipelineCommand.ts b/clients/client-sagemaker/commands/UpdatePipelineCommand.ts new file mode 100644 index 000000000000..af885cc33f52 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdatePipelineCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdatePipelineRequest, UpdatePipelineResponse } from "../models/models_2"; +import { + deserializeAws_json1_1UpdatePipelineCommand, + serializeAws_json1_1UpdatePipelineCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdatePipelineCommandInput = UpdatePipelineRequest; +export type UpdatePipelineCommandOutput = UpdatePipelineResponse & __MetadataBearer; + +/** + *

    Updates a pipeline.

    + */ +export class UpdatePipelineCommand extends $Command< + UpdatePipelineCommandInput, + UpdatePipelineCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdatePipelineCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdatePipelineCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdatePipelineRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdatePipelineResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdatePipelineCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdatePipelineCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdatePipelineCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/commands/UpdatePipelineExecutionCommand.ts b/clients/client-sagemaker/commands/UpdatePipelineExecutionCommand.ts new file mode 100644 index 000000000000..5948517cb2a5 --- /dev/null +++ b/clients/client-sagemaker/commands/UpdatePipelineExecutionCommand.ts @@ -0,0 +1,88 @@ +import { SageMakerClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../SageMakerClient"; +import { UpdatePipelineExecutionRequest, UpdatePipelineExecutionResponse } from "../models/models_2"; +import { + deserializeAws_json1_1UpdatePipelineExecutionCommand, + serializeAws_json1_1UpdatePipelineExecutionCommand, +} from "../protocols/Aws_json1_1"; +import { getSerdePlugin } from "@aws-sdk/middleware-serde"; +import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; +import { Command as $Command } from "@aws-sdk/smithy-client"; +import { + FinalizeHandlerArguments, + Handler, + HandlerExecutionContext, + MiddlewareStack, + HttpHandlerOptions as __HttpHandlerOptions, + MetadataBearer as __MetadataBearer, + SerdeContext as __SerdeContext, +} from "@aws-sdk/types"; + +export type UpdatePipelineExecutionCommandInput = UpdatePipelineExecutionRequest; +export type UpdatePipelineExecutionCommandOutput = UpdatePipelineExecutionResponse & __MetadataBearer; + +/** + *

    Updates a pipeline execution.

    + */ +export class UpdatePipelineExecutionCommand extends $Command< + UpdatePipelineExecutionCommandInput, + UpdatePipelineExecutionCommandOutput, + SageMakerClientResolvedConfig +> { + // Start section: command_properties + // End section: command_properties + + constructor(readonly input: UpdatePipelineExecutionCommandInput) { + // Start section: command_constructor + super(); + // End section: command_constructor + } + + /** + * @internal + */ + resolveMiddleware( + clientStack: MiddlewareStack, + configuration: SageMakerClientResolvedConfig, + options?: __HttpHandlerOptions + ): Handler { + this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); + + const stack = clientStack.concat(this.middlewareStack); + + const { logger } = configuration; + const clientName = "SageMakerClient"; + const commandName = "UpdatePipelineExecutionCommand"; + const handlerExecutionContext: HandlerExecutionContext = { + logger, + clientName, + commandName, + inputFilterSensitiveLog: UpdatePipelineExecutionRequest.filterSensitiveLog, + outputFilterSensitiveLog: UpdatePipelineExecutionResponse.filterSensitiveLog, + }; + + if (typeof logger.info === "function") { + logger.info({ + clientName, + commandName, + }); + } + + const { requestHandler } = configuration; + return stack.resolve( + (request: FinalizeHandlerArguments) => + requestHandler.handle(request.request as __HttpRequest, options || {}), + handlerExecutionContext + ); + } + + private serialize(input: UpdatePipelineExecutionCommandInput, context: __SerdeContext): Promise<__HttpRequest> { + return serializeAws_json1_1UpdatePipelineExecutionCommand(input, context); + } + + private deserialize(output: __HttpResponse, context: __SerdeContext): Promise { + return deserializeAws_json1_1UpdatePipelineExecutionCommand(output, context); + } + + // Start section: command_body_extra + // End section: command_body_extra +} diff --git a/clients/client-sagemaker/index.ts b/clients/client-sagemaker/index.ts index 1d8677aac1d5..6a436516fa36 100644 --- a/clients/client-sagemaker/index.ts +++ b/clients/client-sagemaker/index.ts @@ -1,17 +1,22 @@ export * from "./SageMakerClient"; export * from "./SageMaker"; +export * from "./commands/AddAssociationCommand"; export * from "./commands/AddTagsCommand"; export * from "./commands/AssociateTrialComponentCommand"; +export * from "./commands/CreateActionCommand"; export * from "./commands/CreateAlgorithmCommand"; export * from "./commands/CreateAppCommand"; export * from "./commands/CreateAppImageConfigCommand"; +export * from "./commands/CreateArtifactCommand"; export * from "./commands/CreateAutoMLJobCommand"; export * from "./commands/CreateCodeRepositoryCommand"; export * from "./commands/CreateCompilationJobCommand"; +export * from "./commands/CreateContextCommand"; export * from "./commands/CreateDomainCommand"; export * from "./commands/CreateEndpointCommand"; export * from "./commands/CreateEndpointConfigCommand"; export * from "./commands/CreateExperimentCommand"; +export * from "./commands/CreateFeatureGroupCommand"; export * from "./commands/CreateFlowDefinitionCommand"; export * from "./commands/CreateHumanTaskUiCommand"; export * from "./commands/CreateHyperParameterTuningJobCommand"; @@ -20,12 +25,15 @@ export * from "./commands/CreateImageVersionCommand"; export * from "./commands/CreateLabelingJobCommand"; export * from "./commands/CreateModelCommand"; export * from "./commands/CreateModelPackageCommand"; +export * from "./commands/CreateModelPackageGroupCommand"; export * from "./commands/CreateMonitoringScheduleCommand"; export * from "./commands/CreateNotebookInstanceCommand"; export * from "./commands/CreateNotebookInstanceLifecycleConfigCommand"; +export * from "./commands/CreatePipelineCommand"; export * from "./commands/CreatePresignedDomainUrlCommand"; export * from "./commands/CreatePresignedNotebookInstanceUrlCommand"; export * from "./commands/CreateProcessingJobCommand"; +export * from "./commands/CreateProjectCommand"; export * from "./commands/CreateTrainingJobCommand"; export * from "./commands/CreateTransformJobCommand"; export * from "./commands/CreateTrialCommand"; @@ -33,39 +41,52 @@ export * from "./commands/CreateTrialComponentCommand"; export * from "./commands/CreateUserProfileCommand"; export * from "./commands/CreateWorkforceCommand"; export * from "./commands/CreateWorkteamCommand"; +export * from "./commands/DeleteActionCommand"; export * from "./commands/DeleteAlgorithmCommand"; export * from "./commands/DeleteAppCommand"; export * from "./commands/DeleteAppImageConfigCommand"; +export * from "./commands/DeleteArtifactCommand"; +export * from "./commands/DeleteAssociationCommand"; export * from "./commands/DeleteCodeRepositoryCommand"; +export * from "./commands/DeleteContextCommand"; export * from "./commands/DeleteDomainCommand"; export * from "./commands/DeleteEndpointCommand"; export * from "./commands/DeleteEndpointConfigCommand"; export * from "./commands/DeleteExperimentCommand"; +export * from "./commands/DeleteFeatureGroupCommand"; export * from "./commands/DeleteFlowDefinitionCommand"; export * from "./commands/DeleteHumanTaskUiCommand"; export * from "./commands/DeleteImageCommand"; export * from "./commands/DeleteImageVersionCommand"; export * from "./commands/DeleteModelCommand"; export * from "./commands/DeleteModelPackageCommand"; +export * from "./commands/DeleteModelPackageGroupCommand"; +export * from "./commands/DeleteModelPackageGroupPolicyCommand"; export * from "./commands/DeleteMonitoringScheduleCommand"; export * from "./commands/DeleteNotebookInstanceCommand"; export * from "./commands/DeleteNotebookInstanceLifecycleConfigCommand"; +export * from "./commands/DeletePipelineCommand"; +export * from "./commands/DeleteProjectCommand"; export * from "./commands/DeleteTagsCommand"; export * from "./commands/DeleteTrialCommand"; export * from "./commands/DeleteTrialComponentCommand"; export * from "./commands/DeleteUserProfileCommand"; export * from "./commands/DeleteWorkforceCommand"; export * from "./commands/DeleteWorkteamCommand"; +export * from "./commands/DescribeActionCommand"; export * from "./commands/DescribeAlgorithmCommand"; export * from "./commands/DescribeAppCommand"; export * from "./commands/DescribeAppImageConfigCommand"; +export * from "./commands/DescribeArtifactCommand"; export * from "./commands/DescribeAutoMLJobCommand"; export * from "./commands/DescribeCodeRepositoryCommand"; export * from "./commands/DescribeCompilationJobCommand"; +export * from "./commands/DescribeContextCommand"; export * from "./commands/DescribeDomainCommand"; export * from "./commands/DescribeEndpointCommand"; export * from "./commands/DescribeEndpointConfigCommand"; export * from "./commands/DescribeExperimentCommand"; +export * from "./commands/DescribeFeatureGroupCommand"; export * from "./commands/DescribeFlowDefinitionCommand"; export * from "./commands/DescribeHumanTaskUiCommand"; export * from "./commands/DescribeHyperParameterTuningJobCommand"; @@ -74,10 +95,15 @@ export * from "./commands/DescribeImageVersionCommand"; export * from "./commands/DescribeLabelingJobCommand"; export * from "./commands/DescribeModelCommand"; export * from "./commands/DescribeModelPackageCommand"; +export * from "./commands/DescribeModelPackageGroupCommand"; export * from "./commands/DescribeMonitoringScheduleCommand"; export * from "./commands/DescribeNotebookInstanceCommand"; export * from "./commands/DescribeNotebookInstanceLifecycleConfigCommand"; +export * from "./commands/DescribePipelineCommand"; +export * from "./commands/DescribePipelineDefinitionForExecutionCommand"; +export * from "./commands/DescribePipelineExecutionCommand"; export * from "./commands/DescribeProcessingJobCommand"; +export * from "./commands/DescribeProjectCommand"; export * from "./commands/DescribeSubscribedWorkteamCommand"; export * from "./commands/DescribeTrainingJobCommand"; export * from "./commands/DescribeTransformJobCommand"; @@ -86,13 +112,24 @@ export * from "./commands/DescribeTrialComponentCommand"; export * from "./commands/DescribeUserProfileCommand"; export * from "./commands/DescribeWorkforceCommand"; export * from "./commands/DescribeWorkteamCommand"; +export * from "./commands/DisableSagemakerServicecatalogPortfolioCommand"; export * from "./commands/DisassociateTrialComponentCommand"; +export * from "./commands/EnableSagemakerServicecatalogPortfolioCommand"; +export * from "./commands/GetModelPackageGroupPolicyCommand"; +export * from "./commands/GetSagemakerServicecatalogPortfolioStatusCommand"; export * from "./commands/GetSearchSuggestionsCommand"; +export * from "./commands/ListActionsCommand"; +export * from "./pagination/ListActionsPaginator"; export * from "./commands/ListAlgorithmsCommand"; export * from "./pagination/ListAlgorithmsPaginator"; export * from "./commands/ListAppImageConfigsCommand"; +export * from "./pagination/ListAppImageConfigsPaginator"; export * from "./commands/ListAppsCommand"; export * from "./pagination/ListAppsPaginator"; +export * from "./commands/ListArtifactsCommand"; +export * from "./pagination/ListArtifactsPaginator"; +export * from "./commands/ListAssociationsCommand"; +export * from "./pagination/ListAssociationsPaginator"; export * from "./commands/ListAutoMLJobsCommand"; export * from "./pagination/ListAutoMLJobsPaginator"; export * from "./commands/ListCandidatesForAutoMLJobCommand"; @@ -101,6 +138,8 @@ export * from "./commands/ListCodeRepositoriesCommand"; export * from "./pagination/ListCodeRepositoriesPaginator"; export * from "./commands/ListCompilationJobsCommand"; export * from "./pagination/ListCompilationJobsPaginator"; +export * from "./commands/ListContextsCommand"; +export * from "./pagination/ListContextsPaginator"; export * from "./commands/ListDomainsCommand"; export * from "./pagination/ListDomainsPaginator"; export * from "./commands/ListEndpointConfigsCommand"; @@ -109,6 +148,7 @@ export * from "./commands/ListEndpointsCommand"; export * from "./pagination/ListEndpointsPaginator"; export * from "./commands/ListExperimentsCommand"; export * from "./pagination/ListExperimentsPaginator"; +export * from "./commands/ListFeatureGroupsCommand"; export * from "./commands/ListFlowDefinitionsCommand"; export * from "./pagination/ListFlowDefinitionsPaginator"; export * from "./commands/ListHumanTaskUisCommand"; @@ -123,6 +163,8 @@ export * from "./commands/ListLabelingJobsCommand"; export * from "./pagination/ListLabelingJobsPaginator"; export * from "./commands/ListLabelingJobsForWorkteamCommand"; export * from "./pagination/ListLabelingJobsForWorkteamPaginator"; +export * from "./commands/ListModelPackageGroupsCommand"; +export * from "./pagination/ListModelPackageGroupsPaginator"; export * from "./commands/ListModelPackagesCommand"; export * from "./pagination/ListModelPackagesPaginator"; export * from "./commands/ListModelsCommand"; @@ -135,8 +177,18 @@ export * from "./commands/ListNotebookInstanceLifecycleConfigsCommand"; export * from "./pagination/ListNotebookInstanceLifecycleConfigsPaginator"; export * from "./commands/ListNotebookInstancesCommand"; export * from "./pagination/ListNotebookInstancesPaginator"; +export * from "./commands/ListPipelineExecutionsCommand"; +export * from "./pagination/ListPipelineExecutionsPaginator"; +export * from "./commands/ListPipelineExecutionStepsCommand"; +export * from "./pagination/ListPipelineExecutionStepsPaginator"; +export * from "./commands/ListPipelineParametersForExecutionCommand"; +export * from "./pagination/ListPipelineParametersForExecutionPaginator"; +export * from "./commands/ListPipelinesCommand"; +export * from "./pagination/ListPipelinesPaginator"; export * from "./commands/ListProcessingJobsCommand"; export * from "./pagination/ListProcessingJobsPaginator"; +export * from "./commands/ListProjectsCommand"; +export * from "./pagination/ListProjectsPaginator"; export * from "./commands/ListSubscribedWorkteamsCommand"; export * from "./pagination/ListSubscribedWorkteamsPaginator"; export * from "./commands/ListTagsCommand"; @@ -157,30 +209,39 @@ export * from "./commands/ListWorkforcesCommand"; export * from "./pagination/ListWorkforcesPaginator"; export * from "./commands/ListWorkteamsCommand"; export * from "./pagination/ListWorkteamsPaginator"; +export * from "./commands/PutModelPackageGroupPolicyCommand"; export * from "./commands/RenderUiTemplateCommand"; export * from "./commands/SearchCommand"; export * from "./pagination/SearchPaginator"; export * from "./commands/StartMonitoringScheduleCommand"; export * from "./commands/StartNotebookInstanceCommand"; +export * from "./commands/StartPipelineExecutionCommand"; export * from "./commands/StopAutoMLJobCommand"; export * from "./commands/StopCompilationJobCommand"; export * from "./commands/StopHyperParameterTuningJobCommand"; export * from "./commands/StopLabelingJobCommand"; export * from "./commands/StopMonitoringScheduleCommand"; export * from "./commands/StopNotebookInstanceCommand"; +export * from "./commands/StopPipelineExecutionCommand"; export * from "./commands/StopProcessingJobCommand"; export * from "./commands/StopTrainingJobCommand"; export * from "./commands/StopTransformJobCommand"; +export * from "./commands/UpdateActionCommand"; export * from "./commands/UpdateAppImageConfigCommand"; +export * from "./commands/UpdateArtifactCommand"; export * from "./commands/UpdateCodeRepositoryCommand"; +export * from "./commands/UpdateContextCommand"; export * from "./commands/UpdateDomainCommand"; export * from "./commands/UpdateEndpointCommand"; export * from "./commands/UpdateEndpointWeightsAndCapacitiesCommand"; export * from "./commands/UpdateExperimentCommand"; export * from "./commands/UpdateImageCommand"; +export * from "./commands/UpdateModelPackageCommand"; export * from "./commands/UpdateMonitoringScheduleCommand"; export * from "./commands/UpdateNotebookInstanceCommand"; export * from "./commands/UpdateNotebookInstanceLifecycleConfigCommand"; +export * from "./commands/UpdatePipelineCommand"; +export * from "./commands/UpdatePipelineExecutionCommand"; export * from "./commands/UpdateTrialCommand"; export * from "./commands/UpdateTrialComponentCommand"; export * from "./commands/UpdateUserProfileCommand"; diff --git a/clients/client-sagemaker/models/models_0.ts b/clients/client-sagemaker/models/models_0.ts index 95fe5caa4d8a..3b55a2640048 100644 --- a/clients/client-sagemaker/models/models_0.ts +++ b/clients/client-sagemaker/models/models_0.ts @@ -5,6 +5,188 @@ import { } from "@aws-sdk/smithy-client"; import { MetadataBearer as $MetadataBearer } from "@aws-sdk/types"; +/** + *

    A structure describing the source of an action.

    + */ +export interface ActionSource { + /** + *

    The URI of the source.

    + */ + SourceUri: string | undefined; + + /** + *

    The type of the source.

    + */ + SourceType?: string; + + /** + *

    The ID of the source.

    + */ + SourceId?: string; +} + +export namespace ActionSource { + export const filterSensitiveLog = (obj: ActionSource): any => ({ + ...obj, + }); +} + +export enum ActionStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", + UNKNOWN = "Unknown", +} + +/** + *

    Lists the properties of an action. An action represents an action + * or activity. Some examples are a workflow step and a model deployment. Generally, an + * action involves at least one input artifact or output artifact.

    + */ +export interface ActionSummary { + /** + *

    The Amazon Resource Name (ARN) of the action.

    + */ + ActionArn?: string; + + /** + *

    The name of the action.

    + */ + ActionName?: string; + + /** + *

    The source of the action.

    + */ + Source?: ActionSource; + + /** + *

    The type of the action.

    + */ + ActionType?: string; + + /** + *

    The status of the action.

    + */ + Status?: ActionStatus | string; + + /** + *

    When the action was created.

    + */ + CreationTime?: Date; + + /** + *

    When the action was last modified.

    + */ + LastModifiedTime?: Date; +} + +export namespace ActionSummary { + export const filterSensitiveLog = (obj: ActionSummary): any => ({ + ...obj, + }); +} + +export enum AssociationEdgeType { + ASSOCIATED_WITH = "AssociatedWith", + CONTRIBUTED_TO = "ContributedTo", + DERIVED_FROM = "DerivedFrom", + PRODUCED = "Produced", +} + +export interface AddAssociationRequest { + /** + *

    The ARN of the source.

    + */ + SourceArn: string | undefined; + + /** + *

    The Amazon Resource Name (ARN) of the destination.

    + */ + DestinationArn: string | undefined; + + /** + *

    The type of association. The following are suggested uses for each type. Amazon SageMaker + * places no restrictions on their use.

    + *
      + *
    • + *

      ContributedTo - The source contributed to the destination or had a part in + * enabling the destination. For example, the training data contributed to the training + * job.

      + *
    • + *
    • + *

      AssociatedWith - The source is connected to the destination. For example, an + * approval workflow is associated with a model deployment.

      + *
    • + *
    • + *

      DerivedFrom - The destination is a modification of the source. For example, a digest + * output of a channel input for a processing job is derived from the original inputs.

      + *
    • + *
    • + *

      Produced - The source generated the destination. For example, a training job + * produced a model artifact.

      + *
    • + *
    + */ + AssociationType?: AssociationEdgeType | string; +} + +export namespace AddAssociationRequest { + export const filterSensitiveLog = (obj: AddAssociationRequest): any => ({ + ...obj, + }); +} + +export interface AddAssociationResponse { + /** + *

    The ARN of the source.

    + */ + SourceArn?: string; + + /** + *

    The Amazon Resource Name (ARN) of the destination.

    + */ + DestinationArn?: string; +} + +export namespace AddAssociationResponse { + export const filterSensitiveLog = (obj: AddAssociationResponse): any => ({ + ...obj, + }); +} + +/** + *

    You have exceeded an Amazon SageMaker resource limit. For example, you might have too many + * training jobs created.

    + */ +export interface ResourceLimitExceeded extends __SmithyException, $MetadataBearer { + name: "ResourceLimitExceeded"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceLimitExceeded { + export const filterSensitiveLog = (obj: ResourceLimitExceeded): any => ({ + ...obj, + }); +} + +/** + *

    Resource being access is not found.

    + */ +export interface ResourceNotFound extends __SmithyException, $MetadataBearer { + name: "ResourceNotFound"; + $fault: "client"; + Message?: string; +} + +export namespace ResourceNotFound { + export const filterSensitiveLog = (obj: ResourceNotFound): any => ({ + ...obj, + }); +} + /** *

    Describes a tag.

    */ @@ -33,9 +215,10 @@ export interface AddTagsInput { ResourceArn: string | undefined; /** - *

    An array of Tag objects. Each tag is a key-value pair. Only the - * key parameter is required. If you don't specify a value, Amazon SageMaker sets the - * value to an empty string.

    + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    */ Tags: Tag[] | undefined; } @@ -59,6 +242,22 @@ export namespace AddTagsOutput { }); } +/** + *

    This API is not supported.

    + */ +export interface Alarm { + /** + *

    + */ + AlarmName?: string; +} + +export namespace Alarm { + export const filterSensitiveLog = (obj: Alarm): any => ({ + ...obj, + }); +} + export enum AlgorithmSortBy { CREATION_TIME = "CreationTime", NAME = "Name", @@ -2635,6 +2834,97 @@ export namespace AppSpecification { }); } +export enum ArtifactSourceIdType { + CUSTOM = "Custom", + MD5_HASH = "MD5Hash", + S3_ETAG = "S3ETag", + S3_VERSION = "S3Version", +} + +/** + *

    The ID and ID type of an artifact source.

    + */ +export interface ArtifactSourceType { + /** + *

    The type of ID.

    + */ + SourceIdType: ArtifactSourceIdType | string | undefined; + + /** + *

    The ID.

    + */ + Value: string | undefined; +} + +export namespace ArtifactSourceType { + export const filterSensitiveLog = (obj: ArtifactSourceType): any => ({ + ...obj, + }); +} + +/** + *

    A structure describing the source of an artifact.

    + */ +export interface ArtifactSource { + /** + *

    The URI of the source.

    + */ + SourceUri: string | undefined; + + /** + *

    A list of source types.

    + */ + SourceTypes?: ArtifactSourceType[]; +} + +export namespace ArtifactSource { + export const filterSensitiveLog = (obj: ArtifactSource): any => ({ + ...obj, + }); +} + +/** + *

    Lists a summary of the properties of an artifact. An artifact represents a URI + * addressable object or data. Some examples are a dataset and a model.

    + */ +export interface ArtifactSummary { + /** + *

    The Amazon Resource Name (ARN) of the artifact.

    + */ + ArtifactArn?: string; + + /** + *

    The name of the artifact.

    + */ + ArtifactName?: string; + + /** + *

    The source of the artifact.

    + */ + Source?: ArtifactSource; + + /** + *

    The type of the artifact.

    + */ + ArtifactType?: string; + + /** + *

    When the artifact was created.

    + */ + CreationTime?: Date; + + /** + *

    When the artifact was last modified.

    + */ + LastModifiedTime?: Date; +} + +export namespace ArtifactSummary { + export const filterSensitiveLog = (obj: ArtifactSummary): any => ({ + ...obj, + }); +} + export interface AssociateTrialComponentRequest { /** *

    The name of the component to associated with the trial.

    @@ -2672,71 +2962,192 @@ export namespace AssociateTrialComponentResponse { } /** - *

    You have exceeded an Amazon SageMaker resource limit. For example, you might have too many - * training jobs created.

    + *

    Information about the user who created or modified an experiment, trial, or trial + * component.

    */ -export interface ResourceLimitExceeded extends __SmithyException, $MetadataBearer { - name: "ResourceLimitExceeded"; - $fault: "client"; - Message?: string; +export interface UserContext { + /** + *

    The Amazon Resource Name (ARN) of the user's profile.

    + */ + UserProfileArn?: string; + + /** + *

    The name of the user's profile.

    + */ + UserProfileName?: string; + + /** + *

    The domain associated with the user.

    + */ + DomainId?: string; } -export namespace ResourceLimitExceeded { - export const filterSensitiveLog = (obj: ResourceLimitExceeded): any => ({ +export namespace UserContext { + export const filterSensitiveLog = (obj: UserContext): any => ({ ...obj, }); } /** - *

    Resource being access is not found.

    + *

    Lists a summary of the properties of an association. An association is an entity that + * links other lineage or experiment entities. An example would be an association between a + * training job and a model.

    */ -export interface ResourceNotFound extends __SmithyException, $MetadataBearer { - name: "ResourceNotFound"; - $fault: "client"; - Message?: string; -} +export interface AssociationSummary { + /** + *

    The ARN of the source.

    + */ + SourceArn?: string; -export namespace ResourceNotFound { - export const filterSensitiveLog = (obj: ResourceNotFound): any => ({ - ...obj, - }); -} + /** + *

    The Amazon Resource Name (ARN) of the destination.

    + */ + DestinationArn?: string; -export enum AuthMode { - IAM = "IAM", - SSO = "SSO", -} + /** + *

    The source type.

    + */ + SourceType?: string; -export enum CandidateStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", -} + /** + *

    The destination type.

    + */ + DestinationType?: string; -export enum CandidateStepType { - PROCESSING = "AWS::SageMaker::ProcessingJob", - TRAINING = "AWS::SageMaker::TrainingJob", - TRANSFORM = "AWS::SageMaker::TransformJob", -} + /** + *

    The type of the association.

    + */ + AssociationType?: AssociationEdgeType | string; -/** - *

    Information about the steps for a Candidate, and what step it is working on.

    - */ -export interface AutoMLCandidateStep { /** - *

    Whether the Candidate is at the transform, training, or processing step.

    + *

    The name of the source.

    */ - CandidateStepType: CandidateStepType | string | undefined; + SourceName?: string; /** - *

    The ARN for the Candidate's step.

    + *

    The name of the destination.

    */ - CandidateStepArn: string | undefined; + DestinationName?: string; /** - *

    The name for the Candidate's step.

    + *

    When the association was created.

    + */ + CreationTime?: Date; + + /** + *

    Information about the user who created or modified an experiment, trial, or trial + * component.

    + */ + CreatedBy?: UserContext; +} + +export namespace AssociationSummary { + export const filterSensitiveLog = (obj: AssociationSummary): any => ({ + ...obj, + }); +} + +export enum AthenaResultCompressionType { + GZIP = "GZIP", + SNAPPY = "SNAPPY", + ZLIB = "ZLIB", +} + +export enum AthenaResultFormat { + AVRO = "AVRO", + JSON = "JSON", + ORC = "ORC", + PARQUET = "PARQUET", + TEXTFILE = "TEXTFILE", +} + +/** + *

    Configuration for Athena Dataset Definition input.

    + */ +export interface AthenaDatasetDefinition { + /** + *

    The name of the data catalog used in Athena query execution.

    + */ + Catalog: string | undefined; + + /** + *

    The name of the database used in the Athena query execution.

    + */ + Database: string | undefined; + + /** + *

    The SQL query statements, to be executed.

    + */ + QueryString: string | undefined; + + /** + *

    The name of the workgroup in which the Athena query is being started.

    + */ + WorkGroup?: string; + + /** + *

    The location in Amazon S3 where Athena query results are stored.

    + */ + OutputS3Uri: string | undefined; + + /** + *

    The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt data generated from + * an Athena query execution.

    + */ + KmsKeyId?: string; + + /** + *

    The data storage format for Athena query results.

    + */ + OutputFormat: AthenaResultFormat | string | undefined; + + /** + *

    The compression used for Athena query results.

    + */ + OutputCompression?: AthenaResultCompressionType | string; +} + +export namespace AthenaDatasetDefinition { + export const filterSensitiveLog = (obj: AthenaDatasetDefinition): any => ({ + ...obj, + }); +} + +export enum AuthMode { + IAM = "IAM", + SSO = "SSO", +} + +export enum CandidateStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} + +export enum CandidateStepType { + PROCESSING = "AWS::SageMaker::ProcessingJob", + TRAINING = "AWS::SageMaker::TrainingJob", + TRANSFORM = "AWS::SageMaker::TransformJob", +} + +/** + *

    Information about the steps for a Candidate, and what step it is working on.

    + */ +export interface AutoMLCandidateStep { + /** + *

    Whether the Candidate is at the transform, training, or processing step.

    + */ + CandidateStepType: CandidateStepType | string | undefined; + + /** + *

    The ARN for the Candidate's step.

    + */ + CandidateStepArn: string | undefined; + + /** + *

    The name for the Candidate's step.

    */ CandidateStepName: string | undefined; } @@ -3282,16 +3693,173 @@ export enum AutoMLSortOrder { DESCENDING = "Descending", } +/** + *

    Currently, the AutoRollbackConfig API is not supported.

    + */ +export interface AutoRollbackConfig { + /** + *

    + */ + Alarms?: Alarm[]; +} + +export namespace AutoRollbackConfig { + export const filterSensitiveLog = (obj: AutoRollbackConfig): any => ({ + ...obj, + }); +} + export enum AwsManagedHumanLoopRequestSource { REKOGNITION_DETECT_MODERATION_LABELS_IMAGE_V3 = "AWS/Rekognition/DetectModerationLabels/Image/V3", TEXTRACT_ANALYZE_DOCUMENT_FORMS_V1 = "AWS/Textract/AnalyzeDocument/Forms/V1", } +/** + *

    + */ +export interface MetricsSource { + /** + *

    + */ + ContentType: string | undefined; + + /** + *

    + */ + ContentDigest?: string; + + /** + *

    + */ + S3Uri: string | undefined; +} + +export namespace MetricsSource { + export const filterSensitiveLog = (obj: MetricsSource): any => ({ + ...obj, + }); +} + +/** + *

    Contains bias metrics for a model.

    + */ +export interface Bias { + /** + *

    The bias report for a model

    + */ + Report?: MetricsSource; +} + +export namespace Bias { + export const filterSensitiveLog = (obj: Bias): any => ({ + ...obj, + }); +} + +export enum CapacitySizeType { + CAPACITY_PERCENT = "CAPACITY_PERCENT", + INSTANCE_COUNT = "INSTANCE_COUNT", +} + +/** + *

    Currently, the CapacitySize API is not supported.

    + */ +export interface CapacitySize { + /** + *

    This API is not supported.

    + */ + Type: CapacitySizeType | string | undefined; + + /** + *

    + */ + Value: number | undefined; +} + +export namespace CapacitySize { + export const filterSensitiveLog = (obj: CapacitySize): any => ({ + ...obj, + }); +} + +export enum TrafficRoutingConfigType { + ALL_AT_ONCE = "ALL_AT_ONCE", + CANARY = "CANARY", +} + +/** + *

    Currently, the TrafficRoutingConfig API is not supported.

    + */ +export interface TrafficRoutingConfig { + /** + *

    + */ + Type: TrafficRoutingConfigType | string | undefined; + + /** + *

    + */ + WaitIntervalInSeconds: number | undefined; + + /** + *

    + */ + CanarySize?: CapacitySize; +} + +export namespace TrafficRoutingConfig { + export const filterSensitiveLog = (obj: TrafficRoutingConfig): any => ({ + ...obj, + }); +} + +/** + *

    Currently, the BlueGreenUpdatePolicy API is not supported.

    + */ +export interface BlueGreenUpdatePolicy { + /** + *

    + */ + TrafficRoutingConfiguration: TrafficRoutingConfig | undefined; + + /** + *

    + */ + TerminationWaitInSeconds?: number; + + /** + *

    + */ + MaximumExecutionTimeoutInSeconds?: number; +} + +export namespace BlueGreenUpdatePolicy { + export const filterSensitiveLog = (obj: BlueGreenUpdatePolicy): any => ({ + ...obj, + }); +} + export enum BooleanOperator { AND = "And", OR = "Or", } +/** + *

    Details on the cache hit of a pipeline execution step.

    + */ +export interface CacheHitResult { + /** + *

    The Amazon Resource Name (ARN) of the pipeline execution.

    + */ + SourcePipelineExecutionArn?: string; +} + +export namespace CacheHitResult { + export const filterSensitiveLog = (obj: CacheHitResult): any => ({ + ...obj, + }); +} + export enum CandidateSortBy { CreationTime = "CreationTime", FinalObjectiveMetricValue = "FinalObjectiveMetricValue", @@ -3631,6 +4199,7 @@ export enum TargetDevice { COREML = "coreml", DEEPLENS = "deeplens", IMX8QM = "imx8qm", + JACINTO_TDA4VM = "jacinto_tda4vm", JETSON_NANO = "jetson_nano", JETSON_TX1 = "jetson_tx1", JETSON_TX2 = "jetson_tx2", @@ -3744,6 +4313,27 @@ export namespace CompilationJobSummary { }); } +export enum ConditionOutcome { + FALSE = "False", + TRUE = "True", +} + +/** + *

    Metadata for a Condition step.

    + */ +export interface ConditionStepMetadata { + /** + *

    The outcome of the Condition step evaluation.

    + */ + Outcome?: ConditionOutcome | string; +} + +export namespace ConditionStepMetadata { + export const filterSensitiveLog = (obj: ConditionStepMetadata): any => ({ + ...obj, + }); +} + /** *

    There was a conflict when you attempted to modify an experiment, trial, or trial * component.

    @@ -3896,6 +4486,74 @@ export enum ContentClassifier { FREE_OF_PERSONALLY_IDENTIFIABLE_INFORMATION = "FreeOfPersonallyIdentifiableInformation", } +/** + *

    A structure describing the source of a context.

    + */ +export interface ContextSource { + /** + *

    The URI of the source.

    + */ + SourceUri: string | undefined; + + /** + *

    The type of the source.

    + */ + SourceType?: string; + + /** + *

    The ID of the source.

    + */ + SourceId?: string; +} + +export namespace ContextSource { + export const filterSensitiveLog = (obj: ContextSource): any => ({ + ...obj, + }); +} + +/** + *

    Lists a summary of the properties of a context. A context provides a logical grouping + * of other entities.

    + */ +export interface ContextSummary { + /** + *

    The Amazon Resource Name (ARN) of the context.

    + */ + ContextArn?: string; + + /** + *

    The name of the context.

    + */ + ContextName?: string; + + /** + *

    The source of the context.

    + */ + Source?: ContextSource; + + /** + *

    The type of the context.

    + */ + ContextType?: string; + + /** + *

    When the context was created.

    + */ + CreationTime?: Date; + + /** + *

    When the context was last modified.

    + */ + LastModifiedTime?: Date; +} + +export namespace ContextSummary { + export const filterSensitiveLog = (obj: ContextSummary): any => ({ + ...obj, + }); +} + export enum HyperParameterScalingType { AUTO = "Auto", LINEAR = "Linear", @@ -3987,21 +4645,113 @@ export namespace ContinuousParameterRangeSpecification { } /** - *

    Describes the Docker container for the model package.

    + *

    Metadata properties of the tracking entity, trial, or trial component.

    */ -export interface ModelPackageContainerDefinition { +export interface MetadataProperties { /** - *

    The DNS host name for the Docker container.

    + *

    The commit ID.

    */ - ContainerHostname?: string; + CommitId?: string; /** - *

    The Amazon EC2 Container Registry (Amazon ECR) path where inference code is stored.

    - *

    If you are using your own custom algorithm instead of an algorithm provided by Amazon SageMaker, - * the inference code must meet Amazon SageMaker requirements. Amazon SageMaker supports both - * registry/repository[:tag] and registry/repository[@digest] - * image path formats. For more information, see Using Your Own Algorithms with Amazon - * SageMaker.

    + *

    The repository.

    + */ + Repository?: string; + + /** + *

    The entity this entity was generated by.

    + */ + GeneratedBy?: string; + + /** + *

    The project ID.

    + */ + ProjectId?: string; +} + +export namespace MetadataProperties { + export const filterSensitiveLog = (obj: MetadataProperties): any => ({ + ...obj, + }); +} + +export interface CreateActionRequest { + /** + *

    The name of the action. Must be unique to your account in an AWS Region.

    + */ + ActionName: string | undefined; + + /** + *

    The source type, ID, and URI.

    + */ + Source: ActionSource | undefined; + + /** + *

    The action type.

    + */ + ActionType: string | undefined; + + /** + *

    The description of the action.

    + */ + Description?: string; + + /** + *

    The status of the action.

    + */ + Status?: ActionStatus | string; + + /** + *

    A list of properties to add to the action.

    + */ + Properties?: { [key: string]: string }; + + /** + *

    Metadata properties of the tracking entity, trial, or trial component.

    + */ + MetadataProperties?: MetadataProperties; + + /** + *

    A list of tags to apply to the action.

    + */ + Tags?: Tag[]; +} + +export namespace CreateActionRequest { + export const filterSensitiveLog = (obj: CreateActionRequest): any => ({ + ...obj, + }); +} + +export interface CreateActionResponse { + /** + *

    The Amazon Resource Name (ARN) of the action.

    + */ + ActionArn?: string; +} + +export namespace CreateActionResponse { + export const filterSensitiveLog = (obj: CreateActionResponse): any => ({ + ...obj, + }); +} + +/** + *

    Describes the Docker container for the model package.

    + */ +export interface ModelPackageContainerDefinition { + /** + *

    The DNS host name for the Docker container.

    + */ + ContainerHostname?: string; + + /** + *

    The Amazon EC2 Container Registry (Amazon ECR) path where inference code is stored.

    + *

    If you are using your own custom algorithm instead of an algorithm provided by Amazon SageMaker, + * the inference code must meet Amazon SageMaker requirements. Amazon SageMaker supports both + * registry/repository[:tag] and registry/repository[@digest] + * image path formats. For more information, see Using Your Own Algorithms with Amazon + * SageMaker.

    */ Image: string | undefined; @@ -4115,13 +4865,15 @@ export interface InferenceSpecification { /** *

    A list of the instance types on which a transformation job can be run or on which an * endpoint can be deployed.

    + *

    This parameter is required for unversioned models, and optional for versioned models.

    */ - SupportedTransformInstanceTypes: (TransformInstanceType | string)[] | undefined; + SupportedTransformInstanceTypes?: (TransformInstanceType | string)[]; /** *

    A list of the instance types that are used to generate inferences in real-time.

    + *

    This parameter is required for unversioned models, and optional for versioned models.

    */ - SupportedRealtimeInferenceInstanceTypes: (ProductionVariantInstanceType | string)[] | undefined; + SupportedRealtimeInferenceInstanceTypes?: (ProductionVariantInstanceType | string)[]; /** *

    The supported MIME types for the input data.

    @@ -4415,6 +5167,14 @@ export interface CreateAlgorithmInput { *

    Whether to certify the algorithm so that it can be listed in AWS Marketplace.

    */ CertifyForMarketplace?: boolean; + + /** + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    + */ + Tags?: Tag[]; } export namespace CreateAlgorithmInput { @@ -4566,6 +5326,57 @@ export namespace CreateAppImageConfigResponse { }); } +export interface CreateArtifactRequest { + /** + *

    The name of the artifact. Must be unique to your account in an AWS Region.

    + */ + ArtifactName?: string; + + /** + *

    The ID, ID type, and URI of the source.

    + */ + Source: ArtifactSource | undefined; + + /** + *

    The artifact type.

    + */ + ArtifactType: string | undefined; + + /** + *

    A list of properties to add to the artifact.

    + */ + Properties?: { [key: string]: string }; + + /** + *

    Metadata properties of the tracking entity, trial, or trial component.

    + */ + MetadataProperties?: MetadataProperties; + + /** + *

    A list of tags to apply to the artifact.

    + */ + Tags?: Tag[]; +} + +export namespace CreateArtifactRequest { + export const filterSensitiveLog = (obj: CreateArtifactRequest): any => ({ + ...obj, + }); +} + +export interface CreateArtifactResponse { + /** + *

    The Amazon Resource Name (ARN) of the artifact.

    + */ + ArtifactArn?: string; +} + +export namespace CreateArtifactResponse { + export const filterSensitiveLog = (obj: CreateArtifactResponse): any => ({ + ...obj, + }); +} + export enum ProblemType { BINARY_CLASSIFICATION = "BinaryClassification", MULTICLASS_CLASSIFICATION = "MulticlassClassification", @@ -4656,6 +5467,14 @@ export interface CreateCodeRepositoryInput { * located, the default branch, and credentials to use to access the repository.

    */ GitConfig: GitConfig | undefined; + + /** + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    + */ + Tags?: Tag[]; } export namespace CreateCodeRepositoryInput { @@ -4683,6 +5502,7 @@ export enum Framework { MXNET = "MXNET", ONNX = "ONNX", PYTORCH = "PYTORCH", + SKLEARN = "SKLEARN", TENSORFLOW = "TENSORFLOW", TFLITE = "TFLITE", XGBOOST = "XGBOOST", @@ -5280,6 +6100,33 @@ export interface OutputConfig { * */ CompilerOptions?: string; + + /** + *

    The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt data on the storage volume + * after compilation job. If you don't provide a KMS key ID, Amazon SageMaker uses the default KMS key for Amazon S3 for your role's account

    + *

    The KmsKeyId can be any of the following formats:

    + *
      + *
    • + *

      Key ID: 1234abcd-12ab-34cd-56ef-1234567890ab + *

      + *
    • + *
    • + *

      Key ARN: + * arn:aws:kms:us-west-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab + *

      + *
    • + *
    • + *

      Alias name: alias/ExampleAlias + *

      + *
    • + *
    • + *

      Alias name ARN: + * arn:aws:kms:us-west-2:111122223333:alias/ExampleAlias + *

      + *
    • + *
    + */ + KmsKeyId?: string; } export namespace OutputConfig { @@ -5341,9 +6188,10 @@ export interface CreateCompilationJobRequest { StoppingCondition: StoppingCondition | undefined; /** - *

    An array of key-value pairs that you want to use to organize and track your AWS - * resource costs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management - * User Guide.

    + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    */ Tags?: Tag[]; } @@ -5375,6 +6223,57 @@ export namespace CreateCompilationJobResponse { }); } +export interface CreateContextRequest { + /** + *

    The name of the context. Must be unique to your account in an AWS Region.

    + */ + ContextName: string | undefined; + + /** + *

    The source type, ID, and URI.

    + */ + Source: ContextSource | undefined; + + /** + *

    The context type.

    + */ + ContextType: string | undefined; + + /** + *

    The description of the context.

    + */ + Description?: string; + + /** + *

    A list of properties to add to the context.

    + */ + Properties?: { [key: string]: string }; + + /** + *

    A list of tags to apply to the context.

    + */ + Tags?: Tag[]; +} + +export namespace CreateContextRequest { + export const filterSensitiveLog = (obj: CreateContextRequest): any => ({ + ...obj, + }); +} + +export interface CreateContextResponse { + /** + *

    The Amazon Resource Name (ARN) of the context.

    + */ + ContextArn?: string; +} + +export namespace CreateContextResponse { + export const filterSensitiveLog = (obj: CreateContextResponse): any => ({ + ...obj, + }); +} + /** *

    The JupyterServer app settings.

    */ @@ -5635,11 +6534,10 @@ export interface CreateEndpointInput { EndpointConfigName: string | undefined; /** - *

    An array of key-value pairs. For more information, see Using - * Cost Allocation Tagsin the AWS Billing and Cost Management User - * Guide. - * - *

    + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    */ Tags?: Tag[]; } @@ -5783,9 +6681,10 @@ export interface CreateEndpointConfigInput { DataCaptureConfig?: DataCaptureConfig; /** - *

    A list of key-value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide.

    + *

    An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

    */ Tags?: Tag[]; @@ -5899,93 +6798,478 @@ export namespace CreateExperimentResponse { }); } +export enum FeatureType { + FRACTIONAL = "Fractional", + INTEGRAL = "Integral", + STRING = "String", +} + /** - *

    Defines under what conditions SageMaker creates a human loop. Used within . See for the required - * format of activation conditions.

    + *

    A list of features. You must include FeatureName and + * FeatureType. Valid feature FeatureTypes are + * Integral, Fractional and String.

    */ -export interface HumanLoopActivationConditionsConfig { +export interface FeatureDefinition { /** - *

    JSON expressing use-case specific conditions declaratively. If any condition is matched, atomic tasks are created against the configured work team. - * The set of conditions is different for Rekognition and Textract. For more information about how to structure the JSON, see - * JSON Schema for Human Loop Activation Conditions in Amazon Augmented AI - * in the Amazon SageMaker Developer Guide.

    + *

    The name of a feature. The type must be a string. FeatureName cannot be any + * of the following: is_deleted, write_time, + * api_invocation_time.

    */ - HumanLoopActivationConditions: __LazyJsonString | string | undefined; + FeatureName?: string; + + /** + *

    The value type of a feature. Valid values are Integral, Fractional, or String.

    + */ + FeatureType?: FeatureType | string; } -export namespace HumanLoopActivationConditionsConfig { - export const filterSensitiveLog = (obj: HumanLoopActivationConditionsConfig): any => ({ +export namespace FeatureDefinition { + export const filterSensitiveLog = (obj: FeatureDefinition): any => ({ ...obj, }); } /** - *

    Provides information about how and under what conditions SageMaker creates a human loop. If HumanLoopActivationConfig is not given, then all requests go to humans.

    + *

    The meta data of the Glue table which serves as data catalog for the + * OfflineStore.

    */ -export interface HumanLoopActivationConfig { +export interface DataCatalogConfig { /** - *

    Container structure for defining under what conditions SageMaker creates a human loop.

    + *

    The name of the Glue table.

    */ - HumanLoopActivationConditionsConfig: HumanLoopActivationConditionsConfig | undefined; + TableName: string | undefined; + + /** + *

    The name of the Glue table catalog.

    + */ + Catalog: string | undefined; + + /** + *

    The name of the Glue table database.

    + */ + Database: string | undefined; } -export namespace HumanLoopActivationConfig { - export const filterSensitiveLog = (obj: HumanLoopActivationConfig): any => ({ +export namespace DataCatalogConfig { + export const filterSensitiveLog = (obj: DataCatalogConfig): any => ({ ...obj, }); } /** - *

    Represents an amount of money in United States dollars/

    + *

    The Amazon Simple Storage (Amazon S3) location and and security configuration for OfflineStore.

    */ -export interface USD { +export interface S3StorageConfig { /** - *

    The whole number of dollars in the amount.

    + *

    The S3 URI, or location in Amazon S3, of OfflineStore.

    + *

    S3 URIs have a format similar to the following: s3://example-bucket/prefix/.

    */ - Dollars?: number; + S3Uri: string | undefined; /** - *

    The fractional portion, in cents, of the amount.

    + *

    The AWS Key Management Service (KMS) key ID of the key used to encrypt any objects + * written into the OfflineStore S3 location.

    + *

    The IAM roleARN that is passed as a parameter to + * CreateFeatureGroup must have below permissions to the + * KmsKeyId:

    + *
      + *
    • + *

      + * "kms:GenerateDataKey" + *

      + *
    • + *
    */ - Cents?: number; + KmsKeyId?: string; +} +export namespace S3StorageConfig { + export const filterSensitiveLog = (obj: S3StorageConfig): any => ({ + ...obj, + }); +} + +/** + *

    The configuration of an OfflineStore.

    + *

    Provide an OfflineStoreConfig in a request to + * CreateFeatureGroup to create an OfflineStore.

    + *

    To encrypt an OfflineStore using at rest data encryption, specify AWS Key + * Management Service (KMS) key ID, or KMSKeyId, in + * S3StorageConfig.

    + */ +export interface OfflineStoreConfig { /** - *

    Fractions of a cent, in tenths.

    + *

    The Amazon Simple Storage (Amazon S3) location of OfflineStore.

    */ - TenthFractionsOfACent?: number; + S3StorageConfig: S3StorageConfig | undefined; + + /** + *

    Set to True to disable the automatic creation of an AWS Glue table when + * configuring an OfflineStore.

    + */ + DisableGlueTableCreation?: boolean; + + /** + *

    The meta data of the Glue table that is autogenerated when an OfflineStore + * is created.

    + */ + DataCatalogConfig?: DataCatalogConfig; } -export namespace USD { - export const filterSensitiveLog = (obj: USD): any => ({ +export namespace OfflineStoreConfig { + export const filterSensitiveLog = (obj: OfflineStoreConfig): any => ({ ...obj, }); } /** - *

    Defines the amount of money paid to an Amazon Mechanical Turk worker for each task performed.

    - *

    Use one of the following prices for bounding box tasks. Prices are in US dollars and - * should be based on the complexity of the task; the longer it takes in your initial - * testing, the more you should offer.

    - *
      - *
    • - *

      0.036

      - *
    • - *
    • - *

      0.048

      - *
    • - *
    • - *

      0.060

      - *
    • - *
    • - *

      0.072

      - *
    • - *
    • - *

      0.120

      - *
    • - *
    • - *

      0.240

      - *
    • - *
    • + *

      The security configuration for OnlineStore.

      + */ +export interface OnlineStoreSecurityConfig { + /** + *

      The ID of the AWS Key Management Service (AWS KMS) key that SageMaker Feature Store uses + * to encrypt the Amazon S3 objects at rest using Amazon S3 server-side encryption.

      + *

      The caller (either IAM user or IAM role) of CreateFeatureGroup must have + * below permissions to the OnlineStore + * KmsKeyId:

      + *
        + *
      • + *

        + * "kms:Encrypt" + *

        + *
      • + *
      • + *

        + * "kms:Decrypt" + *

        + *
      • + *
      • + *

        + * "kms:DescribeKey" + *

        + *
      • + *
      • + *

        + * "kms:CreateGrant" + *

        + *
      • + *
      • + *

        + * "kms:RetireGrant" + *

        + *
      • + *
      • + *

        + * "kms:ReEncryptFrom" + *

        + *
      • + *
      • + *

        + * "kms:ReEncryptTo" + *

        + *
      • + *
      • + *

        + * "kms:GenerateDataKey" + *

        + *
      • + *
      • + *

        + * "kms:ListAliases" + *

        + *
      • + *
      • + *

        + * "kms:ListGrants" + *

        + *
      • + *
      • + *

        + * "kms:RevokeGrant" + *

        + *
      • + *
      + *

      The caller (either IAM user or IAM role) to all DataPlane operations + * (PutRecord, GetRecord, DeleteRecord) must have + * the following permissions to the KmsKeyId:

      + *
        + *
      • + *

        + * "kms:Decrypt" + *

        + *
      • + *
      + */ + KmsKeyId?: string; +} + +export namespace OnlineStoreSecurityConfig { + export const filterSensitiveLog = (obj: OnlineStoreSecurityConfig): any => ({ + ...obj, + }); +} + +/** + *

      Use this to specify the AWS Key Management Service (KMS) Key ID, or + * KMSKeyId, for at rest data encryption. You can turn + * OnlineStore on or off by specifying the EnableOnlineStore flag + * at General Assembly; the default value is False.

      + */ +export interface OnlineStoreConfig { + /** + *

      Use to specify KMS Key ID (KMSKeyId) for at-rest encryption of your + * OnlineStore.

      + */ + SecurityConfig?: OnlineStoreSecurityConfig; + + /** + *

      Turn OnlineStore off by specifying False + * for the EnableOnlineStore flag. Turn OnlineStore + * on by specifying True + * for the EnableOnlineStore flag.

      + *

      The default value is False.

      + */ + EnableOnlineStore?: boolean; +} + +export namespace OnlineStoreConfig { + export const filterSensitiveLog = (obj: OnlineStoreConfig): any => ({ + ...obj, + }); +} + +export interface CreateFeatureGroupRequest { + /** + *

      The name of the FeatureGroup. The name must be unique within an AWS Region + * in an AWS account. The name:

      + *
        + *
      • + *

        Must start and end with an alphanumeric character.

        + *
      • + *
      • + *

        Can only contain alphanumeric character and hyphens. Spaces are not allowed. + *

        + *
      • + *
      + */ + FeatureGroupName: string | undefined; + + /** + *

      The name of the Feature whose value uniquely identifies a + * Record defined in the FeatureStore. Only the latest record per + * identifier value will be stored in the OnlineStore. + * RecordIdentifierFeatureName must be one of feature definitions' + * names.

      + *

      You use the RecordIdentifierFeatureName to access data in a + * FeatureStore.

      + *

      This name:

      + *
        + *
      • + *

        Must start and end with an alphanumeric character.

        + *
      • + *
      • + *

        Can only contains alphanumeric characters, hyphens, underscores. Spaces are not + * allowed.

        + *
      • + *
      + */ + RecordIdentifierFeatureName: string | undefined; + + /** + *

      The name of the feature that stores the EventTime of a Record + * in a FeatureGroup.

      + *

      An EventTime is a point in time when a new event occurs that corresponds to + * the creation or update of a Record in a FeatureGroup. All + * Records in the FeatureGroup must have a corresponding + * EventTime.

      + *

      An EventTime can be a String or Fractional.

      + *
        + *
      • + *

        + * Fractional: EventTime feature values must be a Unix + * timestamp in seconds.

        + *
      • + *
      • + *

        + * String: EventTime feature values must be an ISO-8601 + * string in the format. The following formats are supported + * yyyy-MM-dd'T'HH:mm:ssZ and yyyy-MM-dd'T'HH:mm:ss.SSSZ + * where yyyy, MM, and dd represent the year, + * month, and day respectively and HH, mm, ss, + * and if applicable, SSS represent the hour, month, second and + * milliseconds respsectively. 'T' and Z are constants.

        + *
      • + *
      + */ + EventTimeFeatureName: string | undefined; + + /** + *

      A list of Feature names and types. Name and Type + * is compulsory per Feature.

      + *

      Valid feature FeatureTypes are Integral, + * Fractional and String.

      + *

      + * FeatureNames cannot be any of the following: is_deleted, + * write_time, api_invocation_time + *

      + *

      You can create up to 2,500 FeatureDefinitions per + * FeatureGroup.

      + */ + FeatureDefinitions: FeatureDefinition[] | undefined; + + /** + *

      You can turn the OnlineStore on or off by specifying True for + * the EnableOnlineStore flag in OnlineStoreConfig; the default + * value is False.

      + *

      You can also include an AWS KMS key ID (KMSKeyId) for at-rest encryption of + * the OnlineStore.

      + */ + OnlineStoreConfig?: OnlineStoreConfig; + + /** + *

      Use this to configure an OfflineFeatureStore. This parameter allows you to + * specify:

      + *
        + *
      • + *

        The Amazon Simple Storage Service (Amazon S3) location of an + * OfflineStore.

        + *
      • + *
      • + *

        A configuration for an AWS Glue or AWS Hive data cataolgue.

        + *
      • + *
      • + *

        An KMS encryption key to encrypt the Amazon S3 location used for + * OfflineStore.

        + *
      • + *
      + *

      To learn more about this parameter, see OfflineStoreConfig.

      + */ + OfflineStoreConfig?: OfflineStoreConfig; + + /** + *

      The Amazon Resource Name (ARN) of the IAM execution role used to persist data into the + * OfflineStore if an OfflineStoreConfig is provided.

      + */ + RoleArn?: string; + + /** + *

      A free-form description of a FeatureGroup.

      + */ + Description?: string; + + /** + *

      Tags used to identify Features in each FeatureGroup.

      + */ + Tags?: Tag[]; +} + +export namespace CreateFeatureGroupRequest { + export const filterSensitiveLog = (obj: CreateFeatureGroupRequest): any => ({ + ...obj, + }); +} + +export interface CreateFeatureGroupResponse { + /** + *

      The Amazon Resource Name (ARN) of the FeatureGroup. This is a unique + * identifier for the feature group.

      + */ + FeatureGroupArn: string | undefined; +} + +export namespace CreateFeatureGroupResponse { + export const filterSensitiveLog = (obj: CreateFeatureGroupResponse): any => ({ + ...obj, + }); +} + +/** + *

      Defines under what conditions SageMaker creates a human loop. Used within . See for the required + * format of activation conditions.

      + */ +export interface HumanLoopActivationConditionsConfig { + /** + *

      JSON expressing use-case specific conditions declaratively. If any condition is matched, atomic tasks are created against the configured work team. + * The set of conditions is different for Rekognition and Textract. For more information about how to structure the JSON, see + * JSON Schema for Human Loop Activation Conditions in Amazon Augmented AI + * in the Amazon SageMaker Developer Guide.

      + */ + HumanLoopActivationConditions: __LazyJsonString | string | undefined; +} + +export namespace HumanLoopActivationConditionsConfig { + export const filterSensitiveLog = (obj: HumanLoopActivationConditionsConfig): any => ({ + ...obj, + }); +} + +/** + *

      Provides information about how and under what conditions SageMaker creates a human loop. If HumanLoopActivationConfig is not given, then all requests go to humans.

      + */ +export interface HumanLoopActivationConfig { + /** + *

      Container structure for defining under what conditions SageMaker creates a human loop.

      + */ + HumanLoopActivationConditionsConfig: HumanLoopActivationConditionsConfig | undefined; +} + +export namespace HumanLoopActivationConfig { + export const filterSensitiveLog = (obj: HumanLoopActivationConfig): any => ({ + ...obj, + }); +} + +/** + *

      Represents an amount of money in United States dollars/

      + */ +export interface USD { + /** + *

      The whole number of dollars in the amount.

      + */ + Dollars?: number; + + /** + *

      The fractional portion, in cents, of the amount.

      + */ + Cents?: number; + + /** + *

      Fractions of a cent, in tenths.

      + */ + TenthFractionsOfACent?: number; +} + +export namespace USD { + export const filterSensitiveLog = (obj: USD): any => ({ + ...obj, + }); +} + +/** + *

      Defines the amount of money paid to an Amazon Mechanical Turk worker for each task performed.

      + *

      Use one of the following prices for bounding box tasks. Prices are in US dollars and + * should be based on the complexity of the task; the longer it takes in your initial + * testing, the more you should offer.

      + *
        + *
      • + *

        0.036

        + *
      • + *
      • + *

        0.048

        + *
      • + *
      • + *

        0.060

        + *
      • + *
      • + *

        0.072

        + *
      • + *
      • + *

        0.120

        + *
      • + *
      • + *

        0.240

        + *
      • + *
      • *

        0.360

        *
      • *
      • @@ -7350,9 +8634,9 @@ export interface CreateHyperParameterTuningJobRequest { /** *

        An array of key-value pairs. You can use tags to categorize your AWS resources in - * different ways, for example, by purpose, owner, or environment. For more information, - * see AWS - * Tagging Strategies.

        + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

        *

        Tags that you specify for the tuning job are also added to all training jobs that the * tuning job launches.

        */ @@ -9591,10 +10875,10 @@ export interface CreateModelInput { ExecutionRoleArn: string | undefined; /** - *

        An array of key-value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide. - *

        + *

        An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

        */ Tags?: Tag[]; @@ -9633,27 +10917,122 @@ export namespace CreateModelOutput { }); } +export enum ModelApprovalStatus { + APPROVED = "Approved", + PENDING_MANUAL_APPROVAL = "PendingManualApproval", + REJECTED = "Rejected", +} + /** - *

        Specifies an algorithm that was used to create the model package. The algorithm must - * be either an algorithm resource in your Amazon SageMaker account or an algorithm in AWS Marketplace that you - * are subscribed to.

        + *

        Contains explainability metrics for a model.

        */ -export interface SourceAlgorithm { +export interface Explainability { /** - *

        The Amazon S3 path where the model artifacts, which result from model training, are stored. - * This path must point to a single gzip compressed tar archive - * (.tar.gz suffix).

        - * - *

        The model artifacts must be in an S3 bucket that is in the same region as the - * algorithm.

        - *
        + *

        The explainability report for a model.

        */ - ModelDataUrl?: string; + Report?: MetricsSource; +} - /** - *

        The name of an algorithm that was used to create the model package. The algorithm must - * be either an algorithm resource in your Amazon SageMaker account or an algorithm in AWS Marketplace that you - * are subscribed to.

        +export namespace Explainability { + export const filterSensitiveLog = (obj: Explainability): any => ({ + ...obj, + }); +} + +/** + *

        Data quality constraints and statistics for a model.

        + */ +export interface ModelDataQuality { + /** + *

        Data quality statistics for a model.

        + */ + Statistics?: MetricsSource; + + /** + *

        Data quality constraints for a model.

        + */ + Constraints?: MetricsSource; +} + +export namespace ModelDataQuality { + export const filterSensitiveLog = (obj: ModelDataQuality): any => ({ + ...obj, + }); +} + +/** + *

        Model quality statistics and constraints.

        + */ +export interface ModelQuality { + /** + *

        Model quality statistics.

        + */ + Statistics?: MetricsSource; + + /** + *

        Model quality constraints.

        + */ + Constraints?: MetricsSource; +} + +export namespace ModelQuality { + export const filterSensitiveLog = (obj: ModelQuality): any => ({ + ...obj, + }); +} + +/** + *

        Contains metrics captured from a model.

        + */ +export interface ModelMetrics { + /** + *

        Metrics that measure the quality of a model.

        + */ + ModelQuality?: ModelQuality; + + /** + *

        Metrics that measure the quality of the input data for a model.

        + */ + ModelDataQuality?: ModelDataQuality; + + /** + *

        Metrics that measure bais in a model.

        + */ + Bias?: Bias; + + /** + *

        Metrics that help explain a model.

        + */ + Explainability?: Explainability; +} + +export namespace ModelMetrics { + export const filterSensitiveLog = (obj: ModelMetrics): any => ({ + ...obj, + }); +} + +/** + *

        Specifies an algorithm that was used to create the model package. The algorithm must + * be either an algorithm resource in your Amazon SageMaker account or an algorithm in AWS Marketplace that you + * are subscribed to.

        + */ +export interface SourceAlgorithm { + /** + *

        The Amazon S3 path where the model artifacts, which result from model training, are stored. + * This path must point to a single gzip compressed tar archive + * (.tar.gz suffix).

        + * + *

        The model artifacts must be in an S3 bucket that is in the same region as the + * algorithm.

        + *
        + */ + ModelDataUrl?: string; + + /** + *

        The name of an algorithm that was used to create the model package. The algorithm must + * be either an algorithm resource in your Amazon SageMaker account or an algorithm in AWS Marketplace that you + * are subscribed to.

        */ AlgorithmName: string | undefined; } @@ -9731,9 +11110,18 @@ export interface CreateModelPackageInput { /** *

        The name of the model package. The name must have 1 to 63 characters. Valid characters * are a-z, A-Z, 0-9, and - (hyphen).

        + *

        This parameter is required for unversioned models. It is not applicable to versioned + * models.

        */ ModelPackageName?: string; + /** + *

        The name of the model group that this model version belongs to.

        + *

        This parameter is required for versioned models, and does not apply to unversioned + * models.

        + */ + ModelPackageGroupName?: string; + /** *

        A description of the model package.

        */ @@ -9772,8 +11160,40 @@ export interface CreateModelPackageInput { /** *

        Whether to certify the model package for listing on AWS Marketplace.

        + *

        This parameter is optional for unversioned models, and does not apply to versioned + * models.

        */ CertifyForMarketplace?: boolean; + + /** + *

        A list of key value pairs associated with the model. For more information, see Tagging AWS + * resources in the AWS General Reference Guide.

        + */ + Tags?: Tag[]; + + /** + *

        Whether the model is approved for deployment.

        + *

        This parameter is optional for versioned models, and does not apply to unversioned + * models.

        + *

        For versioned models, the value of this parameter must be set to Approved + * to deploy the model.

        + */ + ModelApprovalStatus?: ModelApprovalStatus | string; + + /** + *

        Metadata properties of the tracking entity, trial, or trial component.

        + */ + MetadataProperties?: MetadataProperties; + + /** + *

        A structure that contains model metrics reports.

        + */ + ModelMetrics?: ModelMetrics; + + /** + *

        A unique token that guarantees that the call to this API is idempotent.

        + */ + ClientToken?: string; } export namespace CreateModelPackageInput { @@ -9795,6 +11215,44 @@ export namespace CreateModelPackageOutput { }); } +export interface CreateModelPackageGroupInput { + /** + *

        The name of the model group.

        + */ + ModelPackageGroupName: string | undefined; + + /** + *

        A description for the model group.

        + */ + ModelPackageGroupDescription?: string; + + /** + *

        A list of key value pairs associated with the model group. For more information, see + * Tagging AWS + * resources in the AWS General Reference Guide.

        + */ + Tags?: Tag[]; +} + +export namespace CreateModelPackageGroupInput { + export const filterSensitiveLog = (obj: CreateModelPackageGroupInput): any => ({ + ...obj, + }); +} + +export interface CreateModelPackageGroupOutput { + /** + *

        The Amazon Resource Name (ARN) of the model group.

        + */ + ModelPackageGroupArn: string | undefined; +} + +export namespace CreateModelPackageGroupOutput { + export const filterSensitiveLog = (obj: CreateModelPackageGroupOutput): any => ({ + ...obj, + }); +} + /** *

        The constraints resource for a monitoring job.

        */ @@ -10317,7 +11775,7 @@ export interface MonitoringScheduleConfig { /** *

        Defines the monitoring job.

        */ - MonitoringJobDefinition: MonitoringJobDefinition | undefined; + MonitoringJobDefinition?: MonitoringJobDefinition; } export namespace MonitoringScheduleConfig { @@ -10470,8 +11928,10 @@ export interface CreateNotebookInstanceInput { KmsKeyId?: string; /** - *

        A list of tags to associate with the notebook instance. You can add tags later by - * using the CreateTags API.

        + *

        An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

        */ Tags?: Tag[]; @@ -10624,1688 +12084,82 @@ export namespace CreateNotebookInstanceLifecycleConfigOutput { }); } -export interface CreatePresignedDomainUrlRequest { - /** - *

        The domain ID.

        - */ - DomainId: string | undefined; - - /** - *

        The name of the UserProfile to sign-in as.

        - */ - UserProfileName: string | undefined; - - /** - *

        The session expiration duration in seconds.

        - */ - SessionExpirationDurationInSeconds?: number; -} - -export namespace CreatePresignedDomainUrlRequest { - export const filterSensitiveLog = (obj: CreatePresignedDomainUrlRequest): any => ({ - ...obj, - }); -} - -export interface CreatePresignedDomainUrlResponse { - /** - *

        The presigned URL.

        - */ - AuthorizedUrl?: string; -} - -export namespace CreatePresignedDomainUrlResponse { - export const filterSensitiveLog = (obj: CreatePresignedDomainUrlResponse): any => ({ - ...obj, - }); -} - -export interface CreatePresignedNotebookInstanceUrlInput { - /** - *

        The name of the notebook instance.

        - */ - NotebookInstanceName: string | undefined; - - /** - *

        The duration of the session, in seconds. The default is 12 hours.

        - */ - SessionExpirationDurationInSeconds?: number; -} - -export namespace CreatePresignedNotebookInstanceUrlInput { - export const filterSensitiveLog = (obj: CreatePresignedNotebookInstanceUrlInput): any => ({ - ...obj, - }); -} - -export interface CreatePresignedNotebookInstanceUrlOutput { - /** - *

        A JSON object that contains the URL string.

        - */ - AuthorizedUrl?: string; -} - -export namespace CreatePresignedNotebookInstanceUrlOutput { - export const filterSensitiveLog = (obj: CreatePresignedNotebookInstanceUrlOutput): any => ({ - ...obj, - }); -} - -/** - *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

        - * - */ -export interface ExperimentConfig { - /** - *

        The name of an existing experiment to associate the trial component with.

        - */ - ExperimentName?: string; - - /** - *

        The name of an existing trial to associate the trial component with. If not specified, a - * new trial is created.

        - */ - TrialName?: string; - - /** - *

        The display name for the trial component. If this key isn't specified, the display name is - * the trial component name.

        - */ - TrialComponentDisplayName?: string; -} - -export namespace ExperimentConfig { - export const filterSensitiveLog = (obj: ExperimentConfig): any => ({ - ...obj, - }); -} - -export enum ProcessingS3CompressionType { - GZIP = "Gzip", - NONE = "None", -} - -export enum ProcessingS3DataType { - MANIFEST_FILE = "ManifestFile", - S3_PREFIX = "S3Prefix", -} - -/** - *

        Information about where and how you want to obtain the inputs for an processing - * job.

        - */ -export interface ProcessingS3Input { - /** - *

        The URI for the Amazon S3 storage where you want Amazon SageMaker to download the artifacts needed - * to run a processing job.

        - */ - S3Uri: string | undefined; - +export interface CreatePipelineRequest { /** - *

        The local path to the Amazon S3 bucket where you want Amazon SageMaker to download the inputs to - * run a processing job. LocalPath is an absolute path to the input - * data.

        + *

        The name of the pipeline.

        */ - LocalPath: string | undefined; + PipelineName: string | undefined; /** - *

        Whether you use an S3Prefix or a ManifestFile for - * the data type. If you choose S3Prefix, S3Uri identifies a key - * name prefix. Amazon SageMaker uses all objects with the specified key name prefix for the processing - * job. If you choose ManifestFile, S3Uri identifies an object - * that is a manifest file containing a list of object keys that you want Amazon SageMaker to use for - * the processing job.

        + *

        The display name of the pipeline.

        */ - S3DataType: ProcessingS3DataType | string | undefined; + PipelineDisplayName?: string; /** - *

        Whether to use File or Pipe input mode. In - * File mode, Amazon SageMaker copies the data from the input source onto the local - * Amazon Elastic Block Store (Amazon EBS) volumes before starting your training algorithm. - * This is the most commonly used input mode. In Pipe mode, Amazon SageMaker streams input - * data from the source directly to your algorithm without using the EBS volume.

        + *

        The JSON pipeline definition of the pipeline.

        */ - S3InputMode: ProcessingS3InputMode | string | undefined; + PipelineDefinition: string | undefined; /** - *

        Whether the data stored in Amazon S3 is FullyReplicated or - * ShardedByS3Key.

        + *

        A description of the pipeline.

        */ - S3DataDistributionType?: ProcessingS3DataDistributionType | string; + PipelineDescription?: string; /** - *

        Whether to use Gzip compression for Amazon S3 storage.

        + *

        A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * operation. An idempotent operation completes no more than one time.

        */ - S3CompressionType?: ProcessingS3CompressionType | string; -} - -export namespace ProcessingS3Input { - export const filterSensitiveLog = (obj: ProcessingS3Input): any => ({ - ...obj, - }); -} + ClientRequestToken?: string; -/** - *

        The inputs for a processing job.

        - */ -export interface ProcessingInput { /** - *

        The name of the inputs for the processing job.

        + *

        The Amazon Resource Name (ARN) of the role used by the pipeline to access and create resources.

        */ - InputName: string | undefined; + RoleArn: string | undefined; /** - *

        The S3 inputs for the processing job.

        + *

        A list of tags to apply to the created pipeline.

        */ - S3Input: ProcessingS3Input | undefined; + Tags?: Tag[]; } -export namespace ProcessingInput { - export const filterSensitiveLog = (obj: ProcessingInput): any => ({ +export namespace CreatePipelineRequest { + export const filterSensitiveLog = (obj: CreatePipelineRequest): any => ({ ...obj, }); } -/** - *

        Information about where and how you want to store the results of an - * processing job.

        - */ -export interface ProcessingS3Output { - /** - *

        A URI that identifies the Amazon S3 bucket where you want Amazon SageMaker to save the results of - * a processing job.

        - */ - S3Uri: string | undefined; - - /** - *

        The local path to the Amazon S3 bucket where you want Amazon SageMaker to save the results of an - * processing job. LocalPath is an absolute path to the input data.

        - */ - LocalPath: string | undefined; - +export interface CreatePipelineResponse { /** - *

        Whether to upload the results of the processing job continuously or after the job - * completes.

        + *

        The Amazon Resource Name (ARN) of the created pipeline.

        */ - S3UploadMode: ProcessingS3UploadMode | string | undefined; + PipelineArn?: string; } -export namespace ProcessingS3Output { - export const filterSensitiveLog = (obj: ProcessingS3Output): any => ({ +export namespace CreatePipelineResponse { + export const filterSensitiveLog = (obj: CreatePipelineResponse): any => ({ ...obj, }); } -/** - *

        Describes the results of a processing job.

        - */ -export interface ProcessingOutput { - /** - *

        The name for the processing job output.

        - */ - OutputName: string | undefined; - +export interface CreatePresignedDomainUrlRequest { /** - *

        Configuration for processing job outputs in Amazon S3.

        + *

        The domain ID.

        */ - S3Output: ProcessingS3Output | undefined; -} - -export namespace ProcessingOutput { - export const filterSensitiveLog = (obj: ProcessingOutput): any => ({ - ...obj, - }); -} + DomainId: string | undefined; -/** - *

        The output configuration for the processing job.

        - */ -export interface ProcessingOutputConfig { /** - *

        Output configuration information for a processing job.

        + *

        The name of the UserProfile to sign-in as.

        */ - Outputs: ProcessingOutput[] | undefined; + UserProfileName: string | undefined; /** - *

        The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt the processing - * job output. KmsKeyId can be an ID of a KMS key, ARN of a KMS key, alias of - * a KMS key, or alias of a KMS key. The KmsKeyId is applied to all - * outputs.

        + *

        The session expiration duration in seconds.

        */ - KmsKeyId?: string; -} - -export namespace ProcessingOutputConfig { - export const filterSensitiveLog = (obj: ProcessingOutputConfig): any => ({ - ...obj, - }); + SessionExpirationDurationInSeconds?: number; } -/** - *

        Configuration for the cluster used to run a processing job.

        - */ -export interface ProcessingClusterConfig { - /** - *

        The number of ML compute instances to use in the processing job. For distributed - * processing jobs, specify a value greater than 1. The default value is 1.

        - */ - InstanceCount: number | undefined; - - /** - *

        The ML compute instance type for the processing job.

        - */ - InstanceType: ProcessingInstanceType | string | undefined; - - /** - *

        The size of the ML storage volume in gigabytes that you want to provision. You must - * specify sufficient ML storage for your scenario.

        - */ - VolumeSizeInGB: number | undefined; - - /** - *

        The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt data on the - * storage volume attached to the ML compute instance(s) that run the processing job. - *

        - */ - VolumeKmsKeyId?: string; -} - -export namespace ProcessingClusterConfig { - export const filterSensitiveLog = (obj: ProcessingClusterConfig): any => ({ - ...obj, - }); -} - -/** - *

        Identifies the resources, ML compute instances, and ML storage volumes to deploy for a - * processing job. In distributed training, you specify more than one instance.

        - */ -export interface ProcessingResources { - /** - *

        The configuration for the resources in a cluster used to run the processing - * job.

        - */ - ClusterConfig: ProcessingClusterConfig | undefined; -} - -export namespace ProcessingResources { - export const filterSensitiveLog = (obj: ProcessingResources): any => ({ - ...obj, - }); -} - -/** - *

        Specifies a time limit for how long the processing job is allowed to run.

        - */ -export interface ProcessingStoppingCondition { - /** - *

        Specifies the maximum runtime in seconds.

        - */ - MaxRuntimeInSeconds: number | undefined; -} - -export namespace ProcessingStoppingCondition { - export const filterSensitiveLog = (obj: ProcessingStoppingCondition): any => ({ - ...obj, - }); -} - -export interface CreateProcessingJobRequest { - /** - *

        For each input, data is downloaded from S3 into the processing container before the - * processing job begins running if "S3InputMode" is set to File.

        - */ - ProcessingInputs?: ProcessingInput[]; - - /** - *

        Output configuration for the processing job.

        - */ - ProcessingOutputConfig?: ProcessingOutputConfig; - - /** - *

        The name of the processing job. The name must be unique within an AWS Region in the - * AWS account.

        - */ - ProcessingJobName: string | undefined; - - /** - *

        Identifies the resources, ML compute instances, and ML storage volumes to deploy for a - * processing job. In distributed training, you specify more than one instance.

        - */ - ProcessingResources: ProcessingResources | undefined; - - /** - *

        The time limit for how long the processing job is allowed to run.

        - */ - StoppingCondition?: ProcessingStoppingCondition; - - /** - *

        Configures the processing job to run a specified Docker container image.

        - */ - AppSpecification: AppSpecification | undefined; - - /** - *

        Sets the environment variables in the Docker container.

        - */ - Environment?: { [key: string]: string }; - - /** - *

        Networking options for a processing job.

        - */ - NetworkConfig?: NetworkConfig; - - /** - *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform tasks on - * your behalf.

        - */ - RoleArn: string | undefined; - - /** - *

        (Optional) An array of key-value pairs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management - * User Guide.

        - */ - Tags?: Tag[]; - - /** - *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

        - * - */ - ExperimentConfig?: ExperimentConfig; -} - -export namespace CreateProcessingJobRequest { - export const filterSensitiveLog = (obj: CreateProcessingJobRequest): any => ({ - ...obj, - }); -} - -export interface CreateProcessingJobResponse { - /** - *

        The Amazon Resource Name (ARN) of the processing job.

        - */ - ProcessingJobArn: string | undefined; -} - -export namespace CreateProcessingJobResponse { - export const filterSensitiveLog = (obj: CreateProcessingJobResponse): any => ({ - ...obj, - }); -} - -/** - *

        Configuration information for the debug hook parameters, collection configuration, and - * storage paths.

        - */ -export interface DebugHookConfig { - /** - *

        Path to local storage location for tensors. Defaults to - * /opt/ml/output/tensors/.

        - */ - LocalPath?: string; - - /** - *

        Path to Amazon S3 storage location for tensors.

        - */ - S3OutputPath: string | undefined; - - /** - *

        Configuration information for the debug hook parameters.

        - */ - HookParameters?: { [key: string]: string }; - - /** - *

        Configuration information for tensor collections.

        - */ - CollectionConfigurations?: CollectionConfiguration[]; -} - -export namespace DebugHookConfig { - export const filterSensitiveLog = (obj: DebugHookConfig): any => ({ - ...obj, - }); -} - -/** - *

        Configuration information for debugging rules.

        - */ -export interface DebugRuleConfiguration { - /** - *

        The name of the rule configuration. It must be unique relative to other rule - * configuration names.

        - */ - RuleConfigurationName: string | undefined; - - /** - *

        Path to local storage location for output of rules. Defaults to - * /opt/ml/processing/output/rule/.

        - */ - LocalPath?: string; - - /** - *

        Path to Amazon S3 storage location for rules.

        - */ - S3OutputPath?: string; - - /** - *

        The Amazon Elastic Container (ECR) Image for the managed rule evaluation.

        - */ - RuleEvaluatorImage: string | undefined; - - /** - *

        The instance type to deploy for a training job.

        - */ - InstanceType?: ProcessingInstanceType | string; - - /** - *

        The size, in GB, of the ML storage volume attached to the processing instance.

        - */ - VolumeSizeInGB?: number; - - /** - *

        Runtime configuration for rule container.

        - */ - RuleParameters?: { [key: string]: string }; -} - -export namespace DebugRuleConfiguration { - export const filterSensitiveLog = (obj: DebugRuleConfiguration): any => ({ - ...obj, - }); -} - -/** - *

        Configuration of storage locations for TensorBoard output.

        - */ -export interface TensorBoardOutputConfig { - /** - *

        Path to local storage location for tensorBoard output. Defaults to - * /opt/ml/output/tensorboard.

        - */ - LocalPath?: string; - - /** - *

        Path to Amazon S3 storage location for TensorBoard output.

        - */ - S3OutputPath: string | undefined; -} - -export namespace TensorBoardOutputConfig { - export const filterSensitiveLog = (obj: TensorBoardOutputConfig): any => ({ - ...obj, - }); -} - -export interface CreateTrainingJobRequest { - /** - *

        The name of the training job. The name must be unique within an AWS Region in an - * AWS account.

        - */ - TrainingJobName: string | undefined; - - /** - *

        Algorithm-specific parameters that influence the quality of the model. You set - * hyperparameters before you start the learning process. For a list of hyperparameters for - * each training algorithm provided by Amazon SageMaker, see Algorithms.

        - *

        You can specify a maximum of 100 hyperparameters. Each hyperparameter is a - * key-value pair. Each key and value is limited to 256 characters, as specified by the - * Length Constraint.

        - */ - HyperParameters?: { [key: string]: string }; - - /** - *

        The registry path of the Docker image that contains the training algorithm and - * algorithm-specific metadata, including the input mode. For more information about - * algorithms provided by Amazon SageMaker, see Algorithms. For information about - * providing your own algorithms, see Using Your Own Algorithms with Amazon - * SageMaker.

        - */ - AlgorithmSpecification: AlgorithmSpecification | undefined; - - /** - *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform - * tasks on your behalf.

        - *

        During model training, Amazon SageMaker needs your permission to read input data from an S3 - * bucket, download a Docker image that contains training code, write model artifacts to an - * S3 bucket, write logs to Amazon CloudWatch Logs, and publish metrics to Amazon CloudWatch. You grant - * permissions for all of these tasks to an IAM role. For more information, see Amazon SageMaker - * Roles.

        - * - *

        To be able to pass this role to Amazon SageMaker, the caller of this API must have the - * iam:PassRole permission.

        - *
        - */ - RoleArn: string | undefined; - - /** - *

        An array of Channel objects. Each channel is a named input source. - * InputDataConfig - * - * describes the input data and its location.

        - *

        Algorithms can accept input data from one or more channels. For example, an - * algorithm might have two channels of input data, training_data and - * validation_data. The configuration for each channel provides the S3, - * EFS, or FSx location where the input data is stored. It also provides information about - * the stored data: the MIME type, compression method, and whether the data is wrapped in - * RecordIO format.

        - *

        Depending on the input mode that the algorithm supports, Amazon SageMaker either copies input - * data files from an S3 bucket to a local directory in the Docker container, or makes it - * available as input streams. For example, if you specify an EFS location, input data - * files will be made available as input streams. They do not need to be - * downloaded.

        - */ - InputDataConfig?: Channel[]; - - /** - *

        Specifies the path to the S3 location where you want to store model artifacts. Amazon SageMaker - * creates subfolders for the artifacts.

        - */ - OutputDataConfig: OutputDataConfig | undefined; - - /** - *

        The resources, including the ML compute instances and ML storage volumes, to use - * for model training.

        - *

        ML storage volumes store model artifacts and incremental states. Training - * algorithms might also use ML storage volumes for scratch space. If you want Amazon SageMaker to use - * the ML storage volume to store the training data, choose File as the - * TrainingInputMode in the algorithm specification. For distributed - * training algorithms, specify an instance count greater than 1.

        - */ - ResourceConfig: ResourceConfig | undefined; - - /** - *

        A VpcConfig object that specifies the VPC that you want your - * training job to connect to. Control access to and from your training container by - * configuring the VPC. For more information, see Protect Training Jobs by Using an Amazon - * Virtual Private Cloud.

        - */ - VpcConfig?: VpcConfig; - - /** - *

        Specifies a limit to how long a model training job can run. When the job reaches the - * time limit, Amazon SageMaker ends the training job. Use this API to cap model training costs.

        - *

        To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays - * job termination for 120 seconds. Algorithms can use this 120-second window to save the - * model artifacts, so the results of training are not lost.

        - */ - StoppingCondition: StoppingCondition | undefined; - - /** - *

        An array of key-value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide. - * - *

        - */ - Tags?: Tag[]; - - /** - *

        Isolates the training container. No inbound or outbound network calls can be made, - * except for calls between peers within a training cluster for distributed training. If - * you enable network isolation for training jobs that are configured to use a VPC, Amazon SageMaker - * downloads and uploads customer data and model artifacts through the specified VPC, but - * the training container does not have network access.

        - */ - EnableNetworkIsolation?: boolean; - - /** - *

        To encrypt all communications between ML compute instances in distributed training, - * choose True. Encryption provides greater security for distributed training, - * but training might take longer. How long it takes depends on the amount of communication - * between compute instances, especially if you use a deep learning algorithm in - * distributed training. For more information, see Protect Communications Between ML - * Compute Instances in a Distributed Training Job.

        - */ - EnableInterContainerTrafficEncryption?: boolean; - - /** - *

        To train models using managed spot training, choose True. Managed spot - * training provides a fully managed and scalable infrastructure for training machine - * learning models. this option is useful when training jobs can be interrupted and when - * there is flexibility when the training job is run.

        - *

        The complete and intermediate results of jobs are stored in an Amazon S3 bucket, and can be - * used as a starting point to train models incrementally. Amazon SageMaker provides metrics and - * logs in CloudWatch. They can be used to see when managed spot training jobs are running, - * interrupted, resumed, or completed.

        - */ - EnableManagedSpotTraining?: boolean; - - /** - *

        Contains information about the output location for managed spot training checkpoint - * data.

        - */ - CheckpointConfig?: CheckpointConfig; - - /** - *

        Configuration information for the debug hook parameters, collection configuration, and - * storage paths.

        - */ - DebugHookConfig?: DebugHookConfig; - - /** - *

        Configuration information for debugging rules.

        - */ - DebugRuleConfigurations?: DebugRuleConfiguration[]; - - /** - *

        Configuration of storage locations for TensorBoard output.

        - */ - TensorBoardOutputConfig?: TensorBoardOutputConfig; - - /** - *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

        - * - */ - ExperimentConfig?: ExperimentConfig; -} - -export namespace CreateTrainingJobRequest { - export const filterSensitiveLog = (obj: CreateTrainingJobRequest): any => ({ - ...obj, - }); -} - -export interface CreateTrainingJobResponse { - /** - *

        The Amazon Resource Name (ARN) of the training job.

        - */ - TrainingJobArn: string | undefined; -} - -export namespace CreateTrainingJobResponse { - export const filterSensitiveLog = (obj: CreateTrainingJobResponse): any => ({ - ...obj, - }); -} - -export enum JoinSource { - INPUT = "Input", - NONE = "None", -} - -/** - *

        The data structure used to specify the data to be used for inference in a batch - * transform job and to associate the data that is relevant to the prediction results in - * the output. The input filter provided allows you to exclude input data that is not - * needed for inference in a batch transform job. The output filter provided allows you to - * include input data relevant to interpreting the predictions in the output from the job. - * For more information, see Associate Prediction - * Results with their Corresponding Input Records.

        - */ -export interface DataProcessing { - /** - *

        A JSONPath expression used to select a portion of the input data to pass to - * the algorithm. Use the InputFilter parameter to exclude fields, such as an - * ID column, from the input. If you want Amazon SageMaker to pass the entire input dataset to the - * algorithm, accept the default value $.

        - *

        Examples: "$", "$[1:]", "$.features" - *

        - */ - InputFilter?: string; - - /** - *

        A JSONPath expression used to select a portion of the joined dataset to save - * in the output file for a batch transform job. If you want Amazon SageMaker to store the entire input - * dataset in the output file, leave the default value, $. If you specify - * indexes that aren't within the dimension size of the joined dataset, you get an - * error.

        - *

        Examples: "$", "$[0,5:]", - * "$['id','SageMakerOutput']" - *

        - */ - OutputFilter?: string; - - /** - *

        Specifies the source of the data to join with the transformed data. The valid values - * are None and Input. The default value is None, - * which specifies not to join the input with the transformed data. If you want the batch - * transform job to join the original input data with the transformed data, set - * JoinSource to Input.

        - * - *

        For JSON or JSONLines objects, such as a JSON array, Amazon SageMaker adds the transformed data to - * the input JSON object in an attribute called SageMakerOutput. The joined - * result for JSON must be a key-value pair object. If the input is not a key-value pair - * object, Amazon SageMaker creates a new JSON file. In the new JSON file, and the input data is stored - * under the SageMakerInput key and the results are stored in - * SageMakerOutput.

        - *

        For CSV files, Amazon SageMaker combines the transformed data with the input data at the end of - * the input data and stores it in the output file. The joined data has the joined input - * data followed by the transformed data and the output is a CSV file.

        - */ - JoinSource?: JoinSource | string; -} - -export namespace DataProcessing { - export const filterSensitiveLog = (obj: DataProcessing): any => ({ - ...obj, - }); -} - -/** - *

        Configures the timeout and maximum number of retries for processing a transform job - * invocation.

        - */ -export interface ModelClientConfig { - /** - *

        The timeout value in seconds for an invocation request.

        - */ - InvocationsTimeoutInSeconds?: number; - - /** - *

        The maximum number of retries when invocation requests are failing.

        - */ - InvocationsMaxRetries?: number; -} - -export namespace ModelClientConfig { - export const filterSensitiveLog = (obj: ModelClientConfig): any => ({ - ...obj, - }); -} - -export interface CreateTransformJobRequest { - /** - *

        The name of the transform job. The name must be unique within an AWS Region in an - * AWS account.

        - */ - TransformJobName: string | undefined; - - /** - *

        The name of the model that you want to use for the transform job. - * ModelName must be the name of an existing Amazon SageMaker model within an AWS - * Region in an AWS account.

        - */ - ModelName: string | undefined; - - /** - *

        The maximum number of parallel requests that can be sent to each instance in a - * transform job. If MaxConcurrentTransforms is set to 0 or left - * unset, Amazon SageMaker checks the optional execution-parameters to determine the settings for your - * chosen algorithm. If the execution-parameters endpoint is not enabled, the default value - * is 1. For more information on execution-parameters, see How Containers Serve Requests. For built-in algorithms, you don't need to - * set a value for MaxConcurrentTransforms.

        - */ - MaxConcurrentTransforms?: number; - - /** - *

        Configures the timeout and maximum number of retries for processing a transform job - * invocation.

        - */ - ModelClientConfig?: ModelClientConfig; - - /** - *

        The maximum allowed size of the payload, in MB. A payload is the - * data portion of a record (without metadata). The value in MaxPayloadInMB - * must be greater than, or equal to, the size of a single record. To estimate the size of - * a record in MB, divide the size of your dataset by the number of records. To ensure that - * the records fit within the maximum payload size, we recommend using a slightly larger - * value. The default value is 6 MB. - *

        - *

        For cases where the payload might be arbitrarily large and is transmitted using HTTP - * chunked encoding, set the value to 0. - * This - * feature works only in supported algorithms. Currently, Amazon SageMaker built-in - * algorithms do not support HTTP chunked encoding.

        - */ - MaxPayloadInMB?: number; - - /** - *

        Specifies the number of records to include in a mini-batch for an HTTP inference - * request. A record - * is a single unit of input data that - * inference can be made on. For example, a single line in a CSV file is a record.

        - *

        To enable the batch strategy, you must set the SplitType property to - * Line, RecordIO, or TFRecord.

        - *

        To use only one record when making an HTTP invocation request to a container, set - * BatchStrategy to SingleRecord and SplitType - * to Line.

        - *

        To fit as many records in a mini-batch as can fit within the - * MaxPayloadInMB limit, set BatchStrategy to - * MultiRecord and SplitType to Line.

        - */ - BatchStrategy?: BatchStrategy | string; - - /** - *

        The environment variables to set in the Docker container. We support up to 16 key and - * values entries in the map.

        - */ - Environment?: { [key: string]: string }; - - /** - *

        Describes the input source and - * the - * way the transform job consumes it.

        - */ - TransformInput: TransformInput | undefined; - - /** - *

        Describes the results of the transform job.

        - */ - TransformOutput: TransformOutput | undefined; - - /** - *

        Describes the resources, including - * ML - * instance types and ML instance count, to use for the transform - * job.

        - */ - TransformResources: TransformResources | undefined; - - /** - *

        The data structure used to specify the data to be used for inference in a batch - * transform job and to associate the data that is relevant to the prediction results in - * the output. The input filter provided allows you to exclude input data that is not - * needed for inference in a batch transform job. The output filter provided allows you to - * include input data relevant to interpreting the predictions in the output from the job. - * For more information, see Associate Prediction - * Results with their Corresponding Input Records.

        - */ - DataProcessing?: DataProcessing; - - /** - *

        (Optional) - * An - * array of key-value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide.

        - */ - Tags?: Tag[]; - - /** - *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

        - * - */ - ExperimentConfig?: ExperimentConfig; -} - -export namespace CreateTransformJobRequest { - export const filterSensitiveLog = (obj: CreateTransformJobRequest): any => ({ - ...obj, - }); -} - -export interface CreateTransformJobResponse { - /** - *

        The Amazon Resource Name (ARN) of the transform job.

        - */ - TransformJobArn: string | undefined; -} - -export namespace CreateTransformJobResponse { - export const filterSensitiveLog = (obj: CreateTransformJobResponse): any => ({ - ...obj, - }); -} - -export interface CreateTrialRequest { - /** - *

        The name of the trial. The name must be unique in your AWS account and is not - * case-sensitive.

        - */ - TrialName: string | undefined; - - /** - *

        The name of the trial as displayed. The name doesn't need to be unique. If - * DisplayName isn't specified, TrialName is displayed.

        - */ - DisplayName?: string; - - /** - *

        The name of the experiment to associate the trial with.

        - */ - ExperimentName: string | undefined; - - /** - *

        A list of tags to associate with the trial. You can use Search API to - * search on the tags.

        - */ - Tags?: Tag[]; -} - -export namespace CreateTrialRequest { - export const filterSensitiveLog = (obj: CreateTrialRequest): any => ({ - ...obj, - }); -} - -export interface CreateTrialResponse { - /** - *

        The Amazon Resource Name (ARN) of the trial.

        - */ - TrialArn?: string; -} - -export namespace CreateTrialResponse { - export const filterSensitiveLog = (obj: CreateTrialResponse): any => ({ - ...obj, - }); -} - -/** - *

        Represents an input or output artifact of a trial component. You specify - * TrialComponentArtifact as part of the InputArtifacts and - * OutputArtifacts parameters in the CreateTrialComponent - * request.

        - *

        Examples of input artifacts are datasets, algorithms, hyperparameters, source code, and - * instance types. Examples of output artifacts are metrics, snapshots, logs, and images.

        - */ -export interface TrialComponentArtifact { - /** - *

        The media type of the artifact, which indicates the type of data in the artifact file. The - * media type consists of a type and a subtype - * concatenated with a slash (/) character, for example, text/csv, image/jpeg, and s3/uri. The - * type specifies the category of the media. The subtype specifies the kind of data.

        - */ - MediaType?: string; - - /** - *

        The location of the artifact.

        - */ - Value: string | undefined; -} - -export namespace TrialComponentArtifact { - export const filterSensitiveLog = (obj: TrialComponentArtifact): any => ({ - ...obj, - }); -} - -/** - *

        The value of a hyperparameter. Only one of NumberValue or - * StringValue can be specified.

        - *

        This object is specified in the CreateTrialComponent request.

        - */ -export interface TrialComponentParameterValue { - /** - *

        The string value of a categorical hyperparameter. If you specify a value for this - * parameter, you can't specify the NumberValue parameter.

        - */ - StringValue?: string; - - /** - *

        The numeric value of a numeric hyperparameter. If you specify a value for this parameter, - * you can't specify the StringValue parameter.

        - */ - NumberValue?: number; -} - -export namespace TrialComponentParameterValue { - export const filterSensitiveLog = (obj: TrialComponentParameterValue): any => ({ - ...obj, - }); -} - -export enum TrialComponentPrimaryStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -/** - *

        The status of the trial component.

        - */ -export interface TrialComponentStatus { - /** - *

        The status of the trial component.

        - */ - PrimaryStatus?: TrialComponentPrimaryStatus | string; - - /** - *

        If the component failed, a message describing why.

        - */ - Message?: string; -} - -export namespace TrialComponentStatus { - export const filterSensitiveLog = (obj: TrialComponentStatus): any => ({ - ...obj, - }); -} - -export interface CreateTrialComponentRequest { - /** - *

        The name of the component. The name must be unique in your AWS account and is not - * case-sensitive.

        - */ - TrialComponentName: string | undefined; - - /** - *

        The name of the component as displayed. The name doesn't need to be unique. If - * DisplayName isn't specified, TrialComponentName is - * displayed.

        - */ - DisplayName?: string; - - /** - *

        The status of the component. States include:

        - *
          - *
        • - *

          InProgress

          - *
        • - *
        • - *

          Completed

          - *
        • - *
        • - *

          Failed

          - *
        • - *
        - */ - Status?: TrialComponentStatus; - - /** - *

        When the component started.

        - */ - StartTime?: Date; - - /** - *

        When the component ended.

        - */ - EndTime?: Date; - - /** - *

        The hyperparameters for the component.

        - */ - Parameters?: { [key: string]: TrialComponentParameterValue }; - - /** - *

        The input artifacts for the component. Examples of input artifacts are datasets, - * algorithms, hyperparameters, source code, and instance types.

        - */ - InputArtifacts?: { [key: string]: TrialComponentArtifact }; - - /** - *

        The output artifacts for the component. Examples of output artifacts are metrics, - * snapshots, logs, and images.

        - */ - OutputArtifacts?: { [key: string]: TrialComponentArtifact }; - - /** - *

        A list of tags to associate with the component. You can use Search API - * to search on the tags.

        - */ - Tags?: Tag[]; -} - -export namespace CreateTrialComponentRequest { - export const filterSensitiveLog = (obj: CreateTrialComponentRequest): any => ({ - ...obj, - }); -} - -export interface CreateTrialComponentResponse { - /** - *

        The Amazon Resource Name (ARN) of the trial component.

        - */ - TrialComponentArn?: string; -} - -export namespace CreateTrialComponentResponse { - export const filterSensitiveLog = (obj: CreateTrialComponentResponse): any => ({ - ...obj, - }); -} - -export interface CreateUserProfileRequest { - /** - *

        The ID of the associated Domain.

        - */ - DomainId: string | undefined; - - /** - *

        A name for the UserProfile.

        - */ - UserProfileName: string | undefined; - - /** - *

        A specifier for the type of value specified in SingleSignOnUserValue. Currently, the only supported value is "UserName". - * If the Domain's AuthMode is SSO, this field is required. If the Domain's AuthMode is not SSO, this field cannot be specified. - *

        - */ - SingleSignOnUserIdentifier?: string; - - /** - *

        The username of the associated AWS Single Sign-On User for this UserProfile. If the Domain's AuthMode is SSO, this field is - * required, and must match a valid username of a user in your directory. If the Domain's AuthMode is not SSO, this field cannot be specified. - *

        - */ - SingleSignOnUserValue?: string; - - /** - *

        Each tag consists of a key and an optional value. - * Tag keys must be unique per resource.

        - */ - Tags?: Tag[]; - - /** - *

        A collection of settings.

        - */ - UserSettings?: UserSettings; -} - -export namespace CreateUserProfileRequest { - export const filterSensitiveLog = (obj: CreateUserProfileRequest): any => ({ - ...obj, - }); -} - -export interface CreateUserProfileResponse { - /** - *

        The user profile Amazon Resource Name (ARN).

        - */ - UserProfileArn?: string; -} - -export namespace CreateUserProfileResponse { - export const filterSensitiveLog = (obj: CreateUserProfileResponse): any => ({ - ...obj, - }); -} - -/** - *

        Use this parameter to configure your OIDC Identity Provider (IdP).

        - */ -export interface OidcConfig { - /** - *

        The OIDC IdP client ID used to configure your private workforce.

        - */ - ClientId: string | undefined; - - /** - *

        The OIDC IdP client secret used to configure your private workforce.

        - */ - ClientSecret: string | undefined; - - /** - *

        The OIDC IdP issuer used to configure your private workforce.

        - */ - Issuer: string | undefined; - - /** - *

        The OIDC IdP authorization endpoint used to configure your private workforce.

        - */ - AuthorizationEndpoint: string | undefined; - - /** - *

        The OIDC IdP token endpoint used to configure your private workforce.

        - */ - TokenEndpoint: string | undefined; - - /** - *

        The OIDC IdP user information endpoint used to configure your private workforce.

        - */ - UserInfoEndpoint: string | undefined; - - /** - *

        The OIDC IdP logout endpoint used to configure your private workforce.

        - */ - LogoutEndpoint: string | undefined; - - /** - *

        The OIDC IdP JSON Web Key Set (Jwks) URI used to configure your private workforce.

        - */ - JwksUri: string | undefined; -} - -export namespace OidcConfig { - export const filterSensitiveLog = (obj: OidcConfig): any => ({ - ...obj, - ...(obj.ClientSecret && { ClientSecret: SENSITIVE_STRING }), - }); -} - -/** - *

        A list of IP address ranges (CIDRs). Used to create an allow - * list of IP addresses for a private workforce. Workers will only be able to login to their worker portal from an - * IP address within this range. By default, a workforce isn't restricted to specific IP addresses.

        - */ -export interface SourceIpConfig { - /** - *

        A list of one to ten Classless Inter-Domain Routing (CIDR) values.

        - *

        Maximum: Ten CIDR values

        - * - *

        The following Length Constraints apply to individual CIDR values in - * the CIDR value list.

        - *
        - */ - Cidrs: string[] | undefined; -} - -export namespace SourceIpConfig { - export const filterSensitiveLog = (obj: SourceIpConfig): any => ({ - ...obj, - }); -} - -export interface CreateWorkforceRequest { - /** - *

        Use this parameter to configure an Amazon Cognito private workforce. - * A single Cognito workforce is created using and corresponds to a single - * - * Amazon Cognito user pool.

        - * - *

        Do not use OidcConfig if you specify values for - * CognitoConfig.

        - */ - CognitoConfig?: CognitoConfig; - - /** - *

        Use this parameter to configure a private workforce using your own OIDC Identity Provider.

        - *

        Do not use CognitoConfig if you specify values for - * OidcConfig.

        - */ - OidcConfig?: OidcConfig; - - /** - *

        A list of IP address ranges (CIDRs). Used to create an allow - * list of IP addresses for a private workforce. Workers will only be able to login to their worker portal from an - * IP address within this range. By default, a workforce isn't restricted to specific IP addresses.

        - */ - SourceIpConfig?: SourceIpConfig; - - /** - *

        The name of the private workforce.

        - */ - WorkforceName: string | undefined; - - /** - *

        An array of key-value pairs that contain metadata to help you categorize and - * organize our workforce. Each tag consists of a key and a value, - * both of which you define.

        - */ - Tags?: Tag[]; -} - -export namespace CreateWorkforceRequest { - export const filterSensitiveLog = (obj: CreateWorkforceRequest): any => ({ - ...obj, - ...(obj.OidcConfig && { OidcConfig: OidcConfig.filterSensitiveLog(obj.OidcConfig) }), - }); -} - -export interface CreateWorkforceResponse { - /** - *

        The Amazon Resource Name (ARN) of the workforce.

        - */ - WorkforceArn: string | undefined; -} - -export namespace CreateWorkforceResponse { - export const filterSensitiveLog = (obj: CreateWorkforceResponse): any => ({ - ...obj, - }); -} - -/** - *

        A list of user groups that exist in your OIDC Identity Provider (IdP). - * One to ten groups can be used to create a single private work team. - * When you add a user group to the list of Groups, you can add that user group to one or more - * private work teams. If you add a user group to a private work team, all workers in that user group - * are added to the work team.

        - */ -export interface OidcMemberDefinition { - /** - *

        A list of comma seperated strings that identifies - * user groups in your OIDC IdP. Each user group is - * made up of a group of private workers.

        - */ - Groups: string[] | undefined; -} - -export namespace OidcMemberDefinition { - export const filterSensitiveLog = (obj: OidcMemberDefinition): any => ({ - ...obj, - }); -} - -/** - *

        Defines an Amazon Cognito or your own OIDC IdP user group that is part of a work team.

        - */ -export interface MemberDefinition { - /** - *

        The Amazon Cognito user group that is part of the work team.

        - */ - CognitoMemberDefinition?: CognitoMemberDefinition; - - /** - *

        A list user groups that exist in your OIDC Identity Provider (IdP). - * One to ten groups can be used to create a single private work team. - * When you add a user group to the list of Groups, you can add that user group to one or more - * private work teams. If you add a user group to a private work team, all workers in that user group - * are added to the work team.

        - */ - OidcMemberDefinition?: OidcMemberDefinition; -} - -export namespace MemberDefinition { - export const filterSensitiveLog = (obj: MemberDefinition): any => ({ - ...obj, - }); -} - -/** - *

        Configures SNS notifications of available or expiring work items for work - * teams.

        - */ -export interface NotificationConfiguration { - /** - *

        The ARN for the SNS topic to which notifications should be published.

        - */ - NotificationTopicArn?: string; -} - -export namespace NotificationConfiguration { - export const filterSensitiveLog = (obj: NotificationConfiguration): any => ({ - ...obj, - }); -} - -export interface CreateWorkteamRequest { - /** - *

        The name of the work team. Use this name to identify the work team.

        - */ - WorkteamName: string | undefined; - - /** - *

        The name of the workforce.

        - */ - WorkforceName?: string; - - /** - *

        A list of MemberDefinition objects that contains objects that identify - * the workers that make up the work team.

        - *

        Workforces can be created using Amazon Cognito or your own OIDC Identity Provider (IdP). For - * private workforces created using Amazon Cognito use CognitoMemberDefinition. For - * workforces created using your own OIDC identity provider (IdP) use - * OidcMemberDefinition. Do not provide input for both of these parameters - * in a single request.

        - *

        For workforces created using Amazon Cognito, private work teams correspond to Amazon Cognito - * user groups within the user pool used to create a workforce. All of the - * CognitoMemberDefinition objects that make up the member definition must - * have the same ClientId and UserPool values. To add a Amazon - * Cognito user group to an existing worker pool, see Adding groups to a User - * Pool. For more information about user pools, see Amazon Cognito User - * Pools.

        - *

        For workforces created using your own OIDC IdP, specify the user groups that you want to - * include in your private work team in OidcMemberDefinition by listing those groups - * in Groups.

        - */ - MemberDefinitions: MemberDefinition[] | undefined; - - /** - *

        A description of the work team.

        - */ - Description: string | undefined; - - /** - *

        Configures notification of workers regarding available or expiring work items.

        - */ - NotificationConfiguration?: NotificationConfiguration; - - /** - *

        An array of key-value pairs.

        - *

        For more information, see Resource - * Tag and Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide.

        - */ - Tags?: Tag[]; -} - -export namespace CreateWorkteamRequest { - export const filterSensitiveLog = (obj: CreateWorkteamRequest): any => ({ - ...obj, - }); -} - -export interface CreateWorkteamResponse { - /** - *

        The Amazon Resource Name (ARN) of the work team. You can use this ARN to identify the - * work team.

        - */ - WorkteamArn?: string; -} - -export namespace CreateWorkteamResponse { - export const filterSensitiveLog = (obj: CreateWorkteamResponse): any => ({ - ...obj, - }); -} - -/** - *

        - */ -export interface DataCaptureConfigSummary { - /** - *

        - */ - EnableCapture: boolean | undefined; - - /** - *

        - */ - CaptureStatus: CaptureStatus | string | undefined; - - /** - *

        - */ - CurrentSamplingPercentage: number | undefined; - - /** - *

        - */ - DestinationS3Uri: string | undefined; - - /** - *

        - */ - KmsKeyId: string | undefined; -} - -export namespace DataCaptureConfigSummary { - export const filterSensitiveLog = (obj: DataCaptureConfigSummary): any => ({ - ...obj, - }); -} - -export enum RuleEvaluationStatus { - ERROR = "Error", - IN_PROGRESS = "InProgress", - ISSUES_FOUND = "IssuesFound", - NO_ISSUES_FOUND = "NoIssuesFound", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -/** - *

        Information about the status of the rule evaluation.

        - */ -export interface DebugRuleEvaluationStatus { - /** - *

        The name of the rule configuration

        - */ - RuleConfigurationName?: string; - - /** - *

        The Amazon Resource Name (ARN) of the rule evaluation job.

        - */ - RuleEvaluationJobArn?: string; - - /** - *

        Status of the rule evaluation.

        - */ - RuleEvaluationStatus?: RuleEvaluationStatus | string; - - /** - *

        Details from the rule evaluation.

        - */ - StatusDetails?: string; - - /** - *

        Timestamp when the rule evaluation status was last modified.

        - */ - LastModifiedTime?: Date; -} - -export namespace DebugRuleEvaluationStatus { - export const filterSensitiveLog = (obj: DebugRuleEvaluationStatus): any => ({ - ...obj, - }); -} - -export interface DeleteAlgorithmInput { - /** - *

        The name of the algorithm to delete.

        - */ - AlgorithmName: string | undefined; -} - -export namespace DeleteAlgorithmInput { - export const filterSensitiveLog = (obj: DeleteAlgorithmInput): any => ({ - ...obj, - }); -} - -export interface DeleteAppRequest { - /** - *

        The domain ID.

        - */ - DomainId: string | undefined; - - /** - *

        The user profile name.

        - */ - UserProfileName: string | undefined; - - /** - *

        The type of app.

        - */ - AppType: AppType | string | undefined; - - /** - *

        The name of the app.

        - */ - AppName: string | undefined; -} - -export namespace DeleteAppRequest { - export const filterSensitiveLog = (obj: DeleteAppRequest): any => ({ - ...obj, - }); -} - -export interface DeleteAppImageConfigRequest { - /** - *

        The name of the AppImageConfig to delete.

        - */ - AppImageConfigName: string | undefined; -} - -export namespace DeleteAppImageConfigRequest { - export const filterSensitiveLog = (obj: DeleteAppImageConfigRequest): any => ({ - ...obj, - }); -} - -export interface DeleteCodeRepositoryInput { - /** - *

        The name of the Git repository to delete.

        - */ - CodeRepositoryName: string | undefined; -} - -export namespace DeleteCodeRepositoryInput { - export const filterSensitiveLog = (obj: DeleteCodeRepositoryInput): any => ({ - ...obj, - }); -} - -export enum RetentionType { - Delete = "Delete", - Retain = "Retain", -} - -/** - *

        The retention policy for data stored on an Amazon Elastic File System (EFS) volume.

        - */ -export interface RetentionPolicy { - /** - *

        The default is Retain, which specifies to keep the data stored on the EFS volume.

        - *

        Specify Delete to delete the data stored on the EFS volume.

        - */ - HomeEfsFileSystem?: RetentionType | string; -} - -export namespace RetentionPolicy { - export const filterSensitiveLog = (obj: RetentionPolicy): any => ({ +export namespace CreatePresignedDomainUrlRequest { + export const filterSensitiveLog = (obj: CreatePresignedDomainUrlRequest): any => ({ ...obj, }); } diff --git a/clients/client-sagemaker/models/models_1.ts b/clients/client-sagemaker/models/models_1.ts index 404cabe67724..b4b9ec024344 100644 --- a/clients/client-sagemaker/models/models_1.ts +++ b/clients/client-sagemaker/models/models_1.ts @@ -1,4 +1,7 @@ import { + ActionSource, + ActionStatus, + ActionSummary, AlgorithmSortBy, AlgorithmSpecification, AlgorithmStatus, @@ -13,6 +16,10 @@ import { AppSpecification, AppStatus, AppType, + ArtifactSource, + ArtifactSummary, + AssociationEdgeType, + AthenaDatasetDefinition, AuthMode, AutoMLCandidate, AutoMLChannel, @@ -22,30 +29,22 @@ import { AutoMLJobObjective, AutoMLJobSecondaryStatus, AutoMLJobStatus, - AutoMLJobSummary, AutoMLOutputDataConfig, - AutoMLSortBy, - AutoMLSortOrder, + AutoRollbackConfig, BatchStrategy, - CandidateSortBy, - CandidateStatus, + BlueGreenUpdatePolicy, + CaptureStatus, Channel, CheckpointConfig, - CodeRepositorySortBy, - CodeRepositorySortOrder, - CodeRepositorySummary, CognitoConfig, + CognitoMemberDefinition, + CollectionConfiguration, CompilationJobStatus, - CompilationJobSummary, ContainerDefinition, + ContextSource, DataCaptureConfig, - DataCaptureConfigSummary, - DataProcessing, - DebugHookConfig, - DebugRuleConfiguration, - DebugRuleEvaluationStatus, DirectInternetAccess, - ExperimentConfig, + FeatureDefinition, FlowDefinitionOutputConfig, GitConfig, HumanLoopActivationConfig, @@ -64,10174 +63,9461 @@ import { LabelingJobInputConfig, LabelingJobOutputConfig, LabelingJobStoppingConditions, - MemberDefinition, - ModelClientConfig, + MetadataProperties, + ModelApprovalStatus, + ModelMetrics, ModelPackageValidationSpecification, MonitoringScheduleConfig, NetworkConfig, NotebookInstanceAcceleratorType, NotebookInstanceLifecycleHook, - NotificationConfiguration, ObjectiveStatus, + OfflineStoreConfig, + OnlineStoreConfig, OutputConfig, OutputDataConfig, ProblemType, - ProcessingInput, - ProcessingOutputConfig, - ProcessingResources, - ProcessingStoppingCondition, + ProcessingInstanceType, + ProcessingS3DataDistributionType, + ProcessingS3InputMode, + ProcessingS3UploadMode, ProductionVariant, ResourceConfig, ResourceLimits, ResourceSpec, - RetentionPolicy, RootAccess, SourceAlgorithmSpecification, - SourceIpConfig, StoppingCondition, Tag, - TensorBoardOutputConfig, TrainingSpecification, TransformInput, TransformOutput, TransformResources, - TrialComponentArtifact, - TrialComponentParameterValue, - TrialComponentStatus, - UiTemplate, + UserContext, UserSettings, VpcConfig, _InstanceType, } from "./models_0"; import { SENSITIVE_STRING } from "@aws-sdk/smithy-client"; -export interface DeleteDomainRequest { - /** - *

        The domain ID.

        - */ - DomainId: string | undefined; - +export interface CreatePresignedDomainUrlResponse { /** - *

        The retention policy for this domain, which specifies whether resources will be retained after the Domain is deleted. - * By default, all resources are retained (not automatically deleted). - *

        + *

        The presigned URL.

        */ - RetentionPolicy?: RetentionPolicy; + AuthorizedUrl?: string; } -export namespace DeleteDomainRequest { - export const filterSensitiveLog = (obj: DeleteDomainRequest): any => ({ +export namespace CreatePresignedDomainUrlResponse { + export const filterSensitiveLog = (obj: CreatePresignedDomainUrlResponse): any => ({ ...obj, }); } -export interface DeleteEndpointInput { +export interface CreatePresignedNotebookInstanceUrlInput { /** - *

        The name of the endpoint that you want to delete.

        + *

        The name of the notebook instance.

        */ - EndpointName: string | undefined; -} - -export namespace DeleteEndpointInput { - export const filterSensitiveLog = (obj: DeleteEndpointInput): any => ({ - ...obj, - }); -} + NotebookInstanceName: string | undefined; -export interface DeleteEndpointConfigInput { /** - *

        The name of the endpoint configuration that you want to delete.

        + *

        The duration of the session, in seconds. The default is 12 hours.

        */ - EndpointConfigName: string | undefined; + SessionExpirationDurationInSeconds?: number; } -export namespace DeleteEndpointConfigInput { - export const filterSensitiveLog = (obj: DeleteEndpointConfigInput): any => ({ +export namespace CreatePresignedNotebookInstanceUrlInput { + export const filterSensitiveLog = (obj: CreatePresignedNotebookInstanceUrlInput): any => ({ ...obj, }); } -export interface DeleteExperimentRequest { +export interface CreatePresignedNotebookInstanceUrlOutput { /** - *

        The name of the experiment to delete.

        + *

        A JSON object that contains the URL string.

        */ - ExperimentName: string | undefined; + AuthorizedUrl?: string; } -export namespace DeleteExperimentRequest { - export const filterSensitiveLog = (obj: DeleteExperimentRequest): any => ({ +export namespace CreatePresignedNotebookInstanceUrlOutput { + export const filterSensitiveLog = (obj: CreatePresignedNotebookInstanceUrlOutput): any => ({ ...obj, }); } -export interface DeleteExperimentResponse { +/** + *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

        + * + */ +export interface ExperimentConfig { /** - *

        The Amazon Resource Name (ARN) of the experiment that is being deleted.

        + *

        The name of an existing experiment to associate the trial component with.

        */ - ExperimentArn?: string; -} + ExperimentName?: string; -export namespace DeleteExperimentResponse { - export const filterSensitiveLog = (obj: DeleteExperimentResponse): any => ({ - ...obj, - }); -} + /** + *

        The name of an existing trial to associate the trial component with. If not specified, a + * new trial is created.

        + */ + TrialName?: string; -export interface DeleteFlowDefinitionRequest { /** - *

        The name of the flow definition you are deleting.

        + *

        The display name for the trial component. If this key isn't specified, the display name is + * the trial component name.

        */ - FlowDefinitionName: string | undefined; + TrialComponentDisplayName?: string; } -export namespace DeleteFlowDefinitionRequest { - export const filterSensitiveLog = (obj: DeleteFlowDefinitionRequest): any => ({ +export namespace ExperimentConfig { + export const filterSensitiveLog = (obj: ExperimentConfig): any => ({ ...obj, }); } -export interface DeleteFlowDefinitionResponse {} +export enum DataDistributionType { + FULLYREPLICATED = "FullyReplicated", + SHARDEDBYS3KEY = "ShardedByS3Key", +} -export namespace DeleteFlowDefinitionResponse { - export const filterSensitiveLog = (obj: DeleteFlowDefinitionResponse): any => ({ - ...obj, - }); +export enum InputMode { + FILE = "File", + PIPE = "Pipe", } -export interface DeleteHumanTaskUiRequest { - /** - *

        The name of the human task user interface (work task template) you want to delete.

        - */ - HumanTaskUiName: string | undefined; +export enum RedshiftResultCompressionType { + BZIP2 = "BZIP2", + GZIP = "GZIP", + NONE = "None", + SNAPPY = "SNAPPY", + ZSTD = "ZSTD", } -export namespace DeleteHumanTaskUiRequest { - export const filterSensitiveLog = (obj: DeleteHumanTaskUiRequest): any => ({ - ...obj, - }); +export enum RedshiftResultFormat { + CSV = "CSV", + PARQUET = "PARQUET", } -export interface DeleteHumanTaskUiResponse {} +/** + *

        Configuration for Redshift Dataset Definition input.

        + */ +export interface RedshiftDatasetDefinition { + /** + *

        The Redshift cluster Identifier.

        + */ + ClusterId: string | undefined; -export namespace DeleteHumanTaskUiResponse { - export const filterSensitiveLog = (obj: DeleteHumanTaskUiResponse): any => ({ - ...obj, - }); -} + /** + *

        The name of the Redshift database used in Redshift query execution.

        + */ + Database: string | undefined; -export interface DeleteImageRequest { /** - *

        The name of the image to delete.

        + *

        The database user name used in Redshift query execution.

        */ - ImageName: string | undefined; -} + DbUser: string | undefined; -export namespace DeleteImageRequest { - export const filterSensitiveLog = (obj: DeleteImageRequest): any => ({ - ...obj, - }); -} + /** + *

        The SQL query statements to be executed.

        + */ + QueryString: string | undefined; -export interface DeleteImageResponse {} + /** + *

        The IAM role attached to your Redshift cluster that Amazon SageMaker uses to generate datasets.

        + */ + ClusterRoleArn: string | undefined; -export namespace DeleteImageResponse { - export const filterSensitiveLog = (obj: DeleteImageResponse): any => ({ - ...obj, - }); -} + /** + *

        The location in Amazon S3 where the Redshift query results are stored.

        + */ + OutputS3Uri: string | undefined; -export interface DeleteImageVersionRequest { /** - *

        The name of the image.

        + *

        The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt data from a + * Redshift execution.

        */ - ImageName: string | undefined; + KmsKeyId?: string; /** - *

        The version to delete.

        + *

        The data storage format for Redshift query results.

        */ - Version: number | undefined; + OutputFormat: RedshiftResultFormat | string | undefined; + + /** + *

        The compression used for Redshift query results.

        + */ + OutputCompression?: RedshiftResultCompressionType | string; } -export namespace DeleteImageVersionRequest { - export const filterSensitiveLog = (obj: DeleteImageVersionRequest): any => ({ +export namespace RedshiftDatasetDefinition { + export const filterSensitiveLog = (obj: RedshiftDatasetDefinition): any => ({ ...obj, }); } -export interface DeleteImageVersionResponse {} +/** + *

        Configuration for Dataset Definition inputs. The Dataset Definition input must specify + * exactly one of either AthenaDatasetDefinition or RedshiftDatasetDefinition + * types.

        + */ +export interface DatasetDefinition { + /** + *

        Configuration for Athena Dataset Definition input.

        + */ + AthenaDatasetDefinition?: AthenaDatasetDefinition; -export namespace DeleteImageVersionResponse { - export const filterSensitiveLog = (obj: DeleteImageVersionResponse): any => ({ - ...obj, - }); -} + /** + *

        Configuration for Redshift Dataset Definition input.

        + */ + RedshiftDatasetDefinition?: RedshiftDatasetDefinition; -export interface DeleteModelInput { /** - *

        The name of the model to delete.

        + *

        The local path where you want Amazon SageMaker to download the Dataset Definition inputs to run a + * processing job. LocalPath is an absolute path to the input data. This is a required + * parameter when AppManaged is False (default).

        */ - ModelName: string | undefined; -} + LocalPath?: string; -export namespace DeleteModelInput { - export const filterSensitiveLog = (obj: DeleteModelInput): any => ({ - ...obj, - }); -} + /** + *

        Whether the generated dataset is FullyReplicated or + * ShardedByS3Key (default).

        + */ + DataDistributionType?: DataDistributionType | string; -export interface DeleteModelPackageInput { /** - *

        The name of the model package. The name must have 1 to 63 characters. Valid characters - * are a-z, A-Z, 0-9, and - (hyphen).

        + *

        Whether to use File or Pipe input mode. In File (default) mode, + * Amazon SageMaker copies the data from the input source onto the local Amazon Elastic Block Store + * (Amazon EBS) volumes before starting your training algorithm. This is the most commonly used + * input mode. In Pipe mode, Amazon SageMaker streams input data from the source directly to your + * algorithm without using the EBS volume.

        */ - ModelPackageName: string | undefined; + InputMode?: InputMode | string; } -export namespace DeleteModelPackageInput { - export const filterSensitiveLog = (obj: DeleteModelPackageInput): any => ({ +export namespace DatasetDefinition { + export const filterSensitiveLog = (obj: DatasetDefinition): any => ({ ...obj, }); } -export interface DeleteMonitoringScheduleRequest { - /** - *

        The name of the monitoring schedule to delete.

        - */ - MonitoringScheduleName: string | undefined; +export enum ProcessingS3CompressionType { + GZIP = "Gzip", + NONE = "None", } -export namespace DeleteMonitoringScheduleRequest { - export const filterSensitiveLog = (obj: DeleteMonitoringScheduleRequest): any => ({ - ...obj, - }); +export enum ProcessingS3DataType { + MANIFEST_FILE = "ManifestFile", + S3_PREFIX = "S3Prefix", } -export interface DeleteNotebookInstanceInput { +/** + *

        Configuration for processing job inputs in Amazon S3.

        + */ +export interface ProcessingS3Input { /** - *

        The name of the Amazon SageMaker notebook instance to delete.

        + *

        The URI for the Amazon S3 storage where you want Amazon SageMaker to download the artifacts needed + * to run a processing job.

        */ - NotebookInstanceName: string | undefined; -} + S3Uri: string | undefined; -export namespace DeleteNotebookInstanceInput { - export const filterSensitiveLog = (obj: DeleteNotebookInstanceInput): any => ({ - ...obj, - }); -} + /** + *

        The local path to the Amazon S3 bucket where you want Amazon SageMaker to download the inputs to + * run a processing job. LocalPath is an absolute path to the input + * data. This is a required parameter when AppManaged is False + * (default).

        + */ + LocalPath?: string; -export interface DeleteNotebookInstanceLifecycleConfigInput { /** - *

        The name of the lifecycle configuration to delete.

        + *

        Whether you use an S3Prefix or a ManifestFile for + * the data type. If you choose S3Prefix, S3Uri identifies a key + * name prefix. Amazon SageMaker uses all objects with the specified key name prefix for the processing + * job. If you choose ManifestFile, S3Uri identifies an object + * that is a manifest file containing a list of object keys that you want Amazon SageMaker to use for + * the processing job.

        */ - NotebookInstanceLifecycleConfigName: string | undefined; -} + S3DataType: ProcessingS3DataType | string | undefined; -export namespace DeleteNotebookInstanceLifecycleConfigInput { - export const filterSensitiveLog = (obj: DeleteNotebookInstanceLifecycleConfigInput): any => ({ - ...obj, - }); -} + /** + *

        Whether to use File or Pipe input mode. In + * File mode, Amazon SageMaker copies the data from the input source onto the local + * Amazon Elastic Block Store (Amazon EBS) volumes before starting your training algorithm. + * This is the most commonly used input mode. In Pipe mode, Amazon SageMaker streams input + * data from the source directly to your algorithm without using the EBS volume.This is a + * required parameter when AppManaged is False (default).

        + */ + S3InputMode?: ProcessingS3InputMode | string; -export interface DeleteTagsInput { /** - *

        The Amazon Resource Name (ARN) of the resource whose tags you want to - * delete.

        + *

        Whether the data stored in Amazon S3 is FullyReplicated or + * ShardedByS3Key.

        */ - ResourceArn: string | undefined; + S3DataDistributionType?: ProcessingS3DataDistributionType | string; /** - *

        An array or one or more tag keys to delete.

        + *

        Whether to use Gzip compression for Amazon S3 storage.

        */ - TagKeys: string[] | undefined; + S3CompressionType?: ProcessingS3CompressionType | string; } -export namespace DeleteTagsInput { - export const filterSensitiveLog = (obj: DeleteTagsInput): any => ({ +export namespace ProcessingS3Input { + export const filterSensitiveLog = (obj: ProcessingS3Input): any => ({ ...obj, }); } -export interface DeleteTagsOutput {} +/** + *

        The inputs for a processing job. The processing input must specify exactly one of either + * S3Input or DatasetDefinition types.

        + */ +export interface ProcessingInput { + /** + *

        The name of the inputs for the processing job.

        + */ + InputName: string | undefined; -export namespace DeleteTagsOutput { - export const filterSensitiveLog = (obj: DeleteTagsOutput): any => ({ - ...obj, - }); -} + /** + *

        When True, input operations such as data download are managed natively by the + * processing job application. When False (default), input operations are managed by Amazon SageMaker.

        + */ + AppManaged?: boolean; -export interface DeleteTrialRequest { /** - *

        The name of the trial to delete.

        + *

        Configuration for processing job inputs in Amazon S3.

        */ - TrialName: string | undefined; + S3Input?: ProcessingS3Input; + + /** + *

        Configuration for a Dataset Definition input.

        + */ + DatasetDefinition?: DatasetDefinition; } -export namespace DeleteTrialRequest { - export const filterSensitiveLog = (obj: DeleteTrialRequest): any => ({ +export namespace ProcessingInput { + export const filterSensitiveLog = (obj: ProcessingInput): any => ({ ...obj, }); } -export interface DeleteTrialResponse { +/** + *

        Configuration for processing job outputs in Amazon SageMaker Feature Store.

        + */ +export interface ProcessingFeatureStoreOutput { /** - *

        The Amazon Resource Name (ARN) of the trial that is being deleted.

        + *

        The name of the Amazon SageMaker FeatureGroup to use as the destination for processing job output.

        */ - TrialArn?: string; + FeatureGroupName: string | undefined; } -export namespace DeleteTrialResponse { - export const filterSensitiveLog = (obj: DeleteTrialResponse): any => ({ +export namespace ProcessingFeatureStoreOutput { + export const filterSensitiveLog = (obj: ProcessingFeatureStoreOutput): any => ({ ...obj, }); } -export interface DeleteTrialComponentRequest { +/** + *

        Configuration for processing job outputs in Amazon S3.

        + */ +export interface ProcessingS3Output { /** - *

        The name of the component to delete.

        + *

        A URI that identifies the Amazon S3 bucket where you want Amazon SageMaker to save the results of + * a processing job.

        */ - TrialComponentName: string | undefined; -} + S3Uri: string | undefined; -export namespace DeleteTrialComponentRequest { - export const filterSensitiveLog = (obj: DeleteTrialComponentRequest): any => ({ - ...obj, - }); -} + /** + *

        The local path to the Amazon S3 bucket where you want Amazon SageMaker to save the results of an + * processing job. LocalPath is an absolute path to the input data.

        + */ + LocalPath: string | undefined; -export interface DeleteTrialComponentResponse { /** - *

        The Amazon Resource Name (ARN) of the component is being deleted.

        + *

        Whether to upload the results of the processing job continuously or after the job + * completes.

        */ - TrialComponentArn?: string; + S3UploadMode: ProcessingS3UploadMode | string | undefined; } -export namespace DeleteTrialComponentResponse { - export const filterSensitiveLog = (obj: DeleteTrialComponentResponse): any => ({ +export namespace ProcessingS3Output { + export const filterSensitiveLog = (obj: ProcessingS3Output): any => ({ ...obj, }); } -export interface DeleteUserProfileRequest { +/** + *

        Describes the results of a processing job. The processing output must specify exactly one of + * either S3Output or FeatureStoreOutput types.

        + */ +export interface ProcessingOutput { /** - *

        The domain ID.

        + *

        The name for the processing job output.

        */ - DomainId: string | undefined; + OutputName: string | undefined; /** - *

        The user profile name.

        + *

        Configuration for processing job outputs in Amazon S3.

        */ - UserProfileName: string | undefined; + S3Output?: ProcessingS3Output; + + /** + *

        Configuration for processing job outputs in Amazon SageMaker Feature Store. This processing output + * type is only supported when AppManaged is specified.

        + */ + FeatureStoreOutput?: ProcessingFeatureStoreOutput; + + /** + *

        When True, output operations such as data upload are managed natively by the + * processing job application. When False (default), output operations are managed by + * Amazon SageMaker.

        + */ + AppManaged?: boolean; } -export namespace DeleteUserProfileRequest { - export const filterSensitiveLog = (obj: DeleteUserProfileRequest): any => ({ +export namespace ProcessingOutput { + export const filterSensitiveLog = (obj: ProcessingOutput): any => ({ ...obj, }); } -export interface DeleteWorkforceRequest { +/** + *

        The output configuration for the processing job.

        + */ +export interface ProcessingOutputConfig { /** - *

        The name of the workforce.

        + *

        List of output configurations for the processing job.

        */ - WorkforceName: string | undefined; -} + Outputs: ProcessingOutput[] | undefined; -export namespace DeleteWorkforceRequest { - export const filterSensitiveLog = (obj: DeleteWorkforceRequest): any => ({ - ...obj, - }); + /** + *

        The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt the processing + * job output. KmsKeyId can be an ID of a KMS key, ARN of a KMS key, alias of + * a KMS key, or alias of a KMS key. The KmsKeyId is applied to all + * outputs.

        + */ + KmsKeyId?: string; } -export interface DeleteWorkforceResponse {} - -export namespace DeleteWorkforceResponse { - export const filterSensitiveLog = (obj: DeleteWorkforceResponse): any => ({ +export namespace ProcessingOutputConfig { + export const filterSensitiveLog = (obj: ProcessingOutputConfig): any => ({ ...obj, }); } -export interface DeleteWorkteamRequest { +/** + *

        Configuration for the cluster used to run a processing job.

        + */ +export interface ProcessingClusterConfig { /** - *

        The name of the work team to delete.

        + *

        The number of ML compute instances to use in the processing job. For distributed + * processing jobs, specify a value greater than 1. The default value is 1.

        */ - WorkteamName: string | undefined; -} + InstanceCount: number | undefined; -export namespace DeleteWorkteamRequest { - export const filterSensitiveLog = (obj: DeleteWorkteamRequest): any => ({ - ...obj, - }); -} + /** + *

        The ML compute instance type for the processing job.

        + */ + InstanceType: ProcessingInstanceType | string | undefined; -export interface DeleteWorkteamResponse { /** - *

        Returns true if the work team was successfully deleted; otherwise, - * returns false.

        + *

        The size of the ML storage volume in gigabytes that you want to provision. You must + * specify sufficient ML storage for your scenario.

        */ - Success: boolean | undefined; + VolumeSizeInGB: number | undefined; + + /** + *

        The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to encrypt data on the + * storage volume attached to the ML compute instance(s) that run the processing job. + *

        + */ + VolumeKmsKeyId?: string; } -export namespace DeleteWorkteamResponse { - export const filterSensitiveLog = (obj: DeleteWorkteamResponse): any => ({ +export namespace ProcessingClusterConfig { + export const filterSensitiveLog = (obj: ProcessingClusterConfig): any => ({ ...obj, }); } /** - *

        Gets the Amazon EC2 Container Registry path of the docker image of the model that is hosted in this ProductionVariant.

        - *

        If you used the registry/repository[:tag] form to specify the image path - * of the primary container when you created the model hosted in this - * ProductionVariant, the path resolves to a path of the form - * registry/repository[@digest]. A digest is a hash value that identifies - * a specific version of an image. For information about Amazon ECR paths, see Pulling an Image in the Amazon ECR User Guide.

        + *

        Identifies the resources, ML compute instances, and ML storage volumes to deploy for a + * processing job. In distributed training, you specify more than one instance.

        */ -export interface DeployedImage { - /** - *

        The image path you specified when you created the model.

        - */ - SpecifiedImage?: string; - - /** - *

        The specific digest path of the image hosted in this - * ProductionVariant.

        - */ - ResolvedImage?: string; - +export interface ProcessingResources { /** - *

        The date and time when the image path for the model resolved to the - * ResolvedImage - *

        + *

        The configuration for the resources in a cluster used to run the processing + * job.

        */ - ResolutionTime?: Date; + ClusterConfig: ProcessingClusterConfig | undefined; } -export namespace DeployedImage { - export const filterSensitiveLog = (obj: DeployedImage): any => ({ +export namespace ProcessingResources { + export const filterSensitiveLog = (obj: ProcessingResources): any => ({ ...obj, }); } -export interface DescribeAlgorithmInput { +/** + *

        Specifies a time limit for how long the processing job is allowed to run.

        + */ +export interface ProcessingStoppingCondition { /** - *

        The name of the algorithm to describe.

        + *

        Specifies the maximum runtime in seconds.

        */ - AlgorithmName: string | undefined; + MaxRuntimeInSeconds: number | undefined; } -export namespace DescribeAlgorithmInput { - export const filterSensitiveLog = (obj: DescribeAlgorithmInput): any => ({ +export namespace ProcessingStoppingCondition { + export const filterSensitiveLog = (obj: ProcessingStoppingCondition): any => ({ ...obj, }); } -export interface DescribeAlgorithmOutput { +export interface CreateProcessingJobRequest { /** - *

        The name of the algorithm being described.

        + *

        List of input configurations for the processing job.

        */ - AlgorithmName: string | undefined; + ProcessingInputs?: ProcessingInput[]; /** - *

        The Amazon Resource Name (ARN) of the algorithm.

        + *

        Output configuration for the processing job.

        */ - AlgorithmArn: string | undefined; + ProcessingOutputConfig?: ProcessingOutputConfig; /** - *

        A brief summary about the algorithm.

        + *

        The name of the processing job. The name must be unique within an AWS Region in the + * AWS account.

        */ - AlgorithmDescription?: string; + ProcessingJobName: string | undefined; /** - *

        A timestamp specifying when the algorithm was created.

        + *

        Identifies the resources, ML compute instances, and ML storage volumes to deploy for a + * processing job. In distributed training, you specify more than one instance.

        */ - CreationTime: Date | undefined; + ProcessingResources: ProcessingResources | undefined; /** - *

        Details about training jobs run by this algorithm.

        + *

        The time limit for how long the processing job is allowed to run.

        */ - TrainingSpecification: TrainingSpecification | undefined; + StoppingCondition?: ProcessingStoppingCondition; /** - *

        Details about inference jobs that the algorithm runs.

        + *

        Configures the processing job to run a specified Docker container image.

        */ - InferenceSpecification?: InferenceSpecification; + AppSpecification: AppSpecification | undefined; /** - *

        Details about configurations for one or more training jobs that Amazon SageMaker runs to test the - * algorithm.

        + *

        Sets the environment variables in the Docker container.

        */ - ValidationSpecification?: AlgorithmValidationSpecification; + Environment?: { [key: string]: string }; /** - *

        The current status of the algorithm.

        + *

        Networking options for a processing job.

        */ - AlgorithmStatus: AlgorithmStatus | string | undefined; + NetworkConfig?: NetworkConfig; /** - *

        Details about the current status of the algorithm.

        + *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform tasks on + * your behalf.

        */ - AlgorithmStatusDetails: AlgorithmStatusDetails | undefined; + RoleArn: string | undefined; /** - *

        The product identifier of the algorithm.

        + *

        (Optional) An array of key-value pairs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management + * User Guide.

        */ - ProductId?: string; + Tags?: Tag[]; /** - *

        Whether the algorithm is certified to be listed in AWS Marketplace.

        + *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

        + * */ - CertifyForMarketplace?: boolean; + ExperimentConfig?: ExperimentConfig; } -export namespace DescribeAlgorithmOutput { - export const filterSensitiveLog = (obj: DescribeAlgorithmOutput): any => ({ +export namespace CreateProcessingJobRequest { + export const filterSensitiveLog = (obj: CreateProcessingJobRequest): any => ({ ...obj, }); } -export interface DescribeAppRequest { +export interface CreateProcessingJobResponse { /** - *

        The domain ID.

        + *

        The Amazon Resource Name (ARN) of the processing job.

        */ - DomainId: string | undefined; + ProcessingJobArn: string | undefined; +} - /** - *

        The user profile name.

        - */ - UserProfileName: string | undefined; +export namespace CreateProcessingJobResponse { + export const filterSensitiveLog = (obj: CreateProcessingJobResponse): any => ({ + ...obj, + }); +} +/** + *

        A key value pair used when you provision a project as a service catalog product. For + * information, see What is AWS Service + * Catalog.

        + */ +export interface ProvisioningParameter { /** - *

        The type of app.

        + *

        The key that identifies a provisioning parameter.

        */ - AppType: AppType | string | undefined; + Key?: string; /** - *

        The name of the app.

        + *

        The value of the provisioning parameter.

        */ - AppName: string | undefined; + Value?: string; } -export namespace DescribeAppRequest { - export const filterSensitiveLog = (obj: DescribeAppRequest): any => ({ +export namespace ProvisioningParameter { + export const filterSensitiveLog = (obj: ProvisioningParameter): any => ({ ...obj, }); } -export interface DescribeAppResponse { +/** + *

        Details that you specify to provision a service catalog product. For information about + * service catalog, see .What is AWS Service + * Catalog.

        + */ +export interface ServiceCatalogProvisioningDetails { /** - *

        The Amazon Resource Name (ARN) of the app.

        + *

        The ID of the product to provision.

        */ - AppArn?: string; + ProductId: string | undefined; /** - *

        The type of app.

        + *

        The ID of the provisioning artifact.

        */ - AppType?: AppType | string; + ProvisioningArtifactId: string | undefined; /** - *

        The name of the app.

        + *

        The path identifier of the product. This value is optional if the product has a default path, and required if the product has more than one path.

        */ - AppName?: string; + PathId?: string; /** - *

        The domain ID.

        + *

        A list of key value pairs that you specify when you provision a product.

        */ - DomainId?: string; + ProvisioningParameters?: ProvisioningParameter[]; +} - /** - *

        The user profile name.

        - */ - UserProfileName?: string; +export namespace ServiceCatalogProvisioningDetails { + export const filterSensitiveLog = (obj: ServiceCatalogProvisioningDetails): any => ({ + ...obj, + }); +} +export interface CreateProjectInput { /** - *

        The status.

        + *

        The name of the project.

        */ - Status?: AppStatus | string; + ProjectName: string | undefined; /** - *

        The timestamp of the last health check.

        + *

        A description for the project.

        */ - LastHealthCheckTimestamp?: Date; + ProjectDescription?: string; /** - *

        The timestamp of the last user's activity.

        + *

        The product ID and provisioning artifact ID to provision a service catalog. For + * information, see What is AWS Service + * Catalog.

        */ - LastUserActivityTimestamp?: Date; + ServiceCatalogProvisioningDetails: ServiceCatalogProvisioningDetails | undefined; /** - *

        The creation time.

        + *

        An array of key-value pairs that you want to use to organize and track your AWS + * resource costs. For more information, see Tagging AWS resources in the AWS General Reference Guide.

        */ - CreationTime?: Date; + Tags?: Tag[]; +} + +export namespace CreateProjectInput { + export const filterSensitiveLog = (obj: CreateProjectInput): any => ({ + ...obj, + }); +} +export interface CreateProjectOutput { /** - *

        The failure reason.

        + *

        The Amazon Resource Name (ARN) of the project.

        */ - FailureReason?: string; + ProjectArn: string | undefined; /** - *

        The instance type and the Amazon Resource Name (ARN) of the SageMaker image created on the instance.

        + *

        The ID of the new project.

        */ - ResourceSpec?: ResourceSpec; + ProjectId: string | undefined; } -export namespace DescribeAppResponse { - export const filterSensitiveLog = (obj: DescribeAppResponse): any => ({ +export namespace CreateProjectOutput { + export const filterSensitiveLog = (obj: CreateProjectOutput): any => ({ ...obj, }); } -export interface DescribeAppImageConfigRequest { +/** + *

        Configuration information for the debug hook parameters, collection configuration, and + * storage paths.

        + */ +export interface DebugHookConfig { /** - *

        The name of the AppImageConfig to describe.

        + *

        Path to local storage location for tensors. Defaults to + * /opt/ml/output/tensors/.

        */ - AppImageConfigName: string | undefined; + LocalPath?: string; + + /** + *

        Path to Amazon S3 storage location for tensors.

        + */ + S3OutputPath: string | undefined; + + /** + *

        Configuration information for the debug hook parameters.

        + */ + HookParameters?: { [key: string]: string }; + + /** + *

        Configuration information for tensor collections.

        + */ + CollectionConfigurations?: CollectionConfiguration[]; } -export namespace DescribeAppImageConfigRequest { - export const filterSensitiveLog = (obj: DescribeAppImageConfigRequest): any => ({ +export namespace DebugHookConfig { + export const filterSensitiveLog = (obj: DebugHookConfig): any => ({ ...obj, }); } -export interface DescribeAppImageConfigResponse { +/** + *

        Configuration information for debugging rules.

        + */ +export interface DebugRuleConfiguration { /** - *

        The Amazon Resource Name (ARN) of the AppImageConfig.

        + *

        The name of the rule configuration. It must be unique relative to other rule + * configuration names.

        */ - AppImageConfigArn?: string; + RuleConfigurationName: string | undefined; /** - *

        The name of the AppImageConfig.

        + *

        Path to local storage location for output of rules. Defaults to + * /opt/ml/processing/output/rule/.

        */ - AppImageConfigName?: string; + LocalPath?: string; /** - *

        When the AppImageConfig was created.

        + *

        Path to Amazon S3 storage location for rules.

        */ - CreationTime?: Date; + S3OutputPath?: string; /** - *

        When the AppImageConfig was last modified.

        + *

        The Amazon Elastic Container (ECR) Image for the managed rule evaluation.

        */ - LastModifiedTime?: Date; + RuleEvaluatorImage: string | undefined; /** - *

        The configuration of a KernelGateway app.

        + *

        The instance type to deploy for a training job.

        */ - KernelGatewayImageConfig?: KernelGatewayImageConfig; -} + InstanceType?: ProcessingInstanceType | string; -export namespace DescribeAppImageConfigResponse { - export const filterSensitiveLog = (obj: DescribeAppImageConfigResponse): any => ({ - ...obj, - }); -} + /** + *

        The size, in GB, of the ML storage volume attached to the processing instance.

        + */ + VolumeSizeInGB?: number; -export interface DescribeAutoMLJobRequest { /** - *

        Request information about a job using that job's unique name.

        + *

        Runtime configuration for rule container.

        */ - AutoMLJobName: string | undefined; + RuleParameters?: { [key: string]: string }; } -export namespace DescribeAutoMLJobRequest { - export const filterSensitiveLog = (obj: DescribeAutoMLJobRequest): any => ({ +export namespace DebugRuleConfiguration { + export const filterSensitiveLog = (obj: DebugRuleConfiguration): any => ({ ...obj, }); } /** - *

        The resolved attributes.

        + *

        Configuration of storage locations for TensorBoard output.

        */ -export interface ResolvedAttributes { - /** - *

        Specifies a metric to minimize or maximize as the objective of a job.

        - */ - AutoMLJobObjective?: AutoMLJobObjective; - +export interface TensorBoardOutputConfig { /** - *

        The problem type.

        + *

        Path to local storage location for tensorBoard output. Defaults to + * /opt/ml/output/tensorboard.

        */ - ProblemType?: ProblemType | string; + LocalPath?: string; /** - *

        How long a job is allowed to run, or how many candidates a job is allowed to - * generate.

        + *

        Path to Amazon S3 storage location for TensorBoard output.

        */ - CompletionCriteria?: AutoMLJobCompletionCriteria; + S3OutputPath: string | undefined; } -export namespace ResolvedAttributes { - export const filterSensitiveLog = (obj: ResolvedAttributes): any => ({ +export namespace TensorBoardOutputConfig { + export const filterSensitiveLog = (obj: TensorBoardOutputConfig): any => ({ ...obj, }); } -export interface DescribeAutoMLJobResponse { +export interface CreateTrainingJobRequest { /** - *

        Returns the name of a job.

        + *

        The name of the training job. The name must be unique within an AWS Region in an + * AWS account.

        */ - AutoMLJobName: string | undefined; + TrainingJobName: string | undefined; /** - *

        Returns the job's ARN.

        + *

        Algorithm-specific parameters that influence the quality of the model. You set + * hyperparameters before you start the learning process. For a list of hyperparameters for + * each training algorithm provided by Amazon SageMaker, see Algorithms.

        + *

        You can specify a maximum of 100 hyperparameters. Each hyperparameter is a + * key-value pair. Each key and value is limited to 256 characters, as specified by the + * Length Constraint.

        */ - AutoMLJobArn: string | undefined; + HyperParameters?: { [key: string]: string }; /** - *

        Returns the job's input data config.

        + *

        The registry path of the Docker image that contains the training algorithm and + * algorithm-specific metadata, including the input mode. For more information about + * algorithms provided by Amazon SageMaker, see Algorithms. For information about + * providing your own algorithms, see Using Your Own Algorithms with Amazon + * SageMaker.

        */ - InputDataConfig: AutoMLChannel[] | undefined; + AlgorithmSpecification: AlgorithmSpecification | undefined; /** - *

        Returns the job's output data config.

        + *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform + * tasks on your behalf.

        + *

        During model training, Amazon SageMaker needs your permission to read input data from an S3 + * bucket, download a Docker image that contains training code, write model artifacts to an + * S3 bucket, write logs to Amazon CloudWatch Logs, and publish metrics to Amazon CloudWatch. You grant + * permissions for all of these tasks to an IAM role. For more information, see Amazon SageMaker + * Roles.

        + * + *

        To be able to pass this role to Amazon SageMaker, the caller of this API must have the + * iam:PassRole permission.

        + *
        */ - OutputDataConfig: AutoMLOutputDataConfig | undefined; + RoleArn: string | undefined; /** - *

        The Amazon Resource Name (ARN) of the AWS Identity and Access Management (IAM) role that has read permission to - * the input data location and write permission to the output data location in Amazon S3.

        + *

        An array of Channel objects. Each channel is a named input source. + * InputDataConfig + * + * describes the input data and its location.

        + *

        Algorithms can accept input data from one or more channels. For example, an + * algorithm might have two channels of input data, training_data and + * validation_data. The configuration for each channel provides the S3, + * EFS, or FSx location where the input data is stored. It also provides information about + * the stored data: the MIME type, compression method, and whether the data is wrapped in + * RecordIO format.

        + *

        Depending on the input mode that the algorithm supports, Amazon SageMaker either copies input + * data files from an S3 bucket to a local directory in the Docker container, or makes it + * available as input streams. For example, if you specify an EFS location, input data + * files will be made available as input streams. They do not need to be + * downloaded.

        */ - RoleArn: string | undefined; + InputDataConfig?: Channel[]; /** - *

        Returns the job's objective.

        + *

        Specifies the path to the S3 location where you want to store model artifacts. Amazon SageMaker + * creates subfolders for the artifacts.

        */ - AutoMLJobObjective?: AutoMLJobObjective; + OutputDataConfig: OutputDataConfig | undefined; /** - *

        Returns the job's problem type.

        + *

        The resources, including the ML compute instances and ML storage volumes, to use + * for model training.

        + *

        ML storage volumes store model artifacts and incremental states. Training + * algorithms might also use ML storage volumes for scratch space. If you want Amazon SageMaker to use + * the ML storage volume to store the training data, choose File as the + * TrainingInputMode in the algorithm specification. For distributed + * training algorithms, specify an instance count greater than 1.

        */ - ProblemType?: ProblemType | string; + ResourceConfig: ResourceConfig | undefined; /** - *

        Returns the job's config.

        + *

        A VpcConfig object that specifies the VPC that you want your + * training job to connect to. Control access to and from your training container by + * configuring the VPC. For more information, see Protect Training Jobs by Using an Amazon + * Virtual Private Cloud.

        */ - AutoMLJobConfig?: AutoMLJobConfig; + VpcConfig?: VpcConfig; /** - *

        Returns the job's creation time.

        + *

        Specifies a limit to how long a model training job can run. When the job reaches the + * time limit, Amazon SageMaker ends the training job. Use this API to cap model training costs.

        + *

        To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays + * job termination for 120 seconds. Algorithms can use this 120-second window to save the + * model artifacts, so the results of training are not lost.

        */ - CreationTime: Date | undefined; + StoppingCondition: StoppingCondition | undefined; /** - *

        Returns the job's end time.

        + *

        An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

        */ - EndTime?: Date; + Tags?: Tag[]; /** - *

        Returns the job's last modified time.

        + *

        Isolates the training container. No inbound or outbound network calls can be made, + * except for calls between peers within a training cluster for distributed training. If + * you enable network isolation for training jobs that are configured to use a VPC, Amazon SageMaker + * downloads and uploads customer data and model artifacts through the specified VPC, but + * the training container does not have network access.

        */ - LastModifiedTime: Date | undefined; + EnableNetworkIsolation?: boolean; /** - *

        Returns the job's FailureReason.

        + *

        To encrypt all communications between ML compute instances in distributed training, + * choose True. Encryption provides greater security for distributed training, + * but training might take longer. How long it takes depends on the amount of communication + * between compute instances, especially if you use a deep learning algorithm in + * distributed training. For more information, see Protect Communications Between ML + * Compute Instances in a Distributed Training Job.

        */ - FailureReason?: string; + EnableInterContainerTrafficEncryption?: boolean; /** - *

        Returns the job's BestCandidate.

        + *

        To train models using managed spot training, choose True. Managed spot + * training provides a fully managed and scalable infrastructure for training machine + * learning models. this option is useful when training jobs can be interrupted and when + * there is flexibility when the training job is run.

        + *

        The complete and intermediate results of jobs are stored in an Amazon S3 bucket, and can be + * used as a starting point to train models incrementally. Amazon SageMaker provides metrics and + * logs in CloudWatch. They can be used to see when managed spot training jobs are running, + * interrupted, resumed, or completed.

        */ - BestCandidate?: AutoMLCandidate; + EnableManagedSpotTraining?: boolean; /** - *

        Returns the job's AutoMLJobStatus.

        + *

        Contains information about the output location for managed spot training checkpoint + * data.

        */ - AutoMLJobStatus: AutoMLJobStatus | string | undefined; + CheckpointConfig?: CheckpointConfig; /** - *

        Returns the job's AutoMLJobSecondaryStatus.

        + *

        Configuration information for the debug hook parameters, collection configuration, and + * storage paths.

        */ - AutoMLJobSecondaryStatus: AutoMLJobSecondaryStatus | string | undefined; + DebugHookConfig?: DebugHookConfig; /** - *

        Returns the job's output from GenerateCandidateDefinitionsOnly.

        + *

        Configuration information for debugging rules.

        */ - GenerateCandidateDefinitionsOnly?: boolean; + DebugRuleConfigurations?: DebugRuleConfiguration[]; /** - *

        Returns information on the job's artifacts found in AutoMLJobArtifacts.

        + *

        Configuration of storage locations for TensorBoard output.

        */ - AutoMLJobArtifacts?: AutoMLJobArtifacts; + TensorBoardOutputConfig?: TensorBoardOutputConfig; /** - *

        This contains ProblemType, AutoMLJobObjective and CompletionCriteria. They're - * auto-inferred values, if not provided by you. If you do provide them, then they'll be the - * same as provided.

        + *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

        + * */ - ResolvedAttributes?: ResolvedAttributes; + ExperimentConfig?: ExperimentConfig; } -export namespace DescribeAutoMLJobResponse { - export const filterSensitiveLog = (obj: DescribeAutoMLJobResponse): any => ({ +export namespace CreateTrainingJobRequest { + export const filterSensitiveLog = (obj: CreateTrainingJobRequest): any => ({ ...obj, }); } -export interface DescribeCodeRepositoryInput { +export interface CreateTrainingJobResponse { /** - *

        The name of the Git repository to describe.

        + *

        The Amazon Resource Name (ARN) of the training job.

        */ - CodeRepositoryName: string | undefined; + TrainingJobArn: string | undefined; } -export namespace DescribeCodeRepositoryInput { - export const filterSensitiveLog = (obj: DescribeCodeRepositoryInput): any => ({ +export namespace CreateTrainingJobResponse { + export const filterSensitiveLog = (obj: CreateTrainingJobResponse): any => ({ ...obj, }); } -export interface DescribeCodeRepositoryOutput { - /** - *

        The name of the Git repository.

        - */ - CodeRepositoryName: string | undefined; - - /** - *

        The Amazon Resource Name (ARN) of the Git repository.

        - */ - CodeRepositoryArn: string | undefined; +export enum JoinSource { + INPUT = "Input", + NONE = "None", +} +/** + *

        The data structure used to specify the data to be used for inference in a batch + * transform job and to associate the data that is relevant to the prediction results in + * the output. The input filter provided allows you to exclude input data that is not + * needed for inference in a batch transform job. The output filter provided allows you to + * include input data relevant to interpreting the predictions in the output from the job. + * For more information, see Associate Prediction + * Results with their Corresponding Input Records.

        + */ +export interface DataProcessing { /** - *

        The date and time that the repository was created.

        + *

        A JSONPath expression used to select a portion of the input data to pass to + * the algorithm. Use the InputFilter parameter to exclude fields, such as an + * ID column, from the input. If you want Amazon SageMaker to pass the entire input dataset to the + * algorithm, accept the default value $.

        + *

        Examples: "$", "$[1:]", "$.features" + *

        */ - CreationTime: Date | undefined; + InputFilter?: string; /** - *

        The date and time that the repository was last changed.

        + *

        A JSONPath expression used to select a portion of the joined dataset to save + * in the output file for a batch transform job. If you want Amazon SageMaker to store the entire input + * dataset in the output file, leave the default value, $. If you specify + * indexes that aren't within the dimension size of the joined dataset, you get an + * error.

        + *

        Examples: "$", "$[0,5:]", + * "$['id','SageMakerOutput']" + *

        */ - LastModifiedTime: Date | undefined; + OutputFilter?: string; /** - *

        Configuration details about the repository, including the URL where the repository is - * located, the default branch, and the Amazon Resource Name (ARN) of the AWS Secrets - * Manager secret that contains the credentials used to access the repository.

        + *

        Specifies the source of the data to join with the transformed data. The valid values + * are None and Input. The default value is None, + * which specifies not to join the input with the transformed data. If you want the batch + * transform job to join the original input data with the transformed data, set + * JoinSource to Input.

        + * + *

        For JSON or JSONLines objects, such as a JSON array, Amazon SageMaker adds the transformed data to + * the input JSON object in an attribute called SageMakerOutput. The joined + * result for JSON must be a key-value pair object. If the input is not a key-value pair + * object, Amazon SageMaker creates a new JSON file. In the new JSON file, and the input data is stored + * under the SageMakerInput key and the results are stored in + * SageMakerOutput.

        + *

        For CSV files, Amazon SageMaker combines the transformed data with the input data at the end of + * the input data and stores it in the output file. The joined data has the joined input + * data followed by the transformed data and the output is a CSV file.

        */ - GitConfig?: GitConfig; + JoinSource?: JoinSource | string; } -export namespace DescribeCodeRepositoryOutput { - export const filterSensitiveLog = (obj: DescribeCodeRepositoryOutput): any => ({ +export namespace DataProcessing { + export const filterSensitiveLog = (obj: DataProcessing): any => ({ ...obj, }); } -export interface DescribeCompilationJobRequest { +/** + *

        Configures the timeout and maximum number of retries for processing a transform job + * invocation.

        + */ +export interface ModelClientConfig { /** - *

        The name of the model compilation job that you want information about.

        + *

        The timeout value in seconds for an invocation request.

        */ - CompilationJobName: string | undefined; -} - -export namespace DescribeCompilationJobRequest { - export const filterSensitiveLog = (obj: DescribeCompilationJobRequest): any => ({ - ...obj, - }); -} + InvocationsTimeoutInSeconds?: number; -/** - *

        Provides information about the location that is configured for storing model - * artifacts.

        - *

        Model artifacts are the output that results from training a model, and typically - * consist of trained parameters, a model defintion that desribes how to compute - * inferences, and other metadata.

        - */ -export interface ModelArtifacts { /** - *

        The path of the S3 object that contains the model artifacts. For example, - * s3://bucket-name/keynameprefix/model.tar.gz.

        + *

        The maximum number of retries when invocation requests are failing.

        */ - S3ModelArtifacts: string | undefined; + InvocationsMaxRetries?: number; } -export namespace ModelArtifacts { - export const filterSensitiveLog = (obj: ModelArtifacts): any => ({ +export namespace ModelClientConfig { + export const filterSensitiveLog = (obj: ModelClientConfig): any => ({ ...obj, }); } -export interface DescribeCompilationJobResponse { +export interface CreateTransformJobRequest { /** - *

        The name of the model compilation job.

        + *

        The name of the transform job. The name must be unique within an AWS Region in an + * AWS account.

        */ - CompilationJobName: string | undefined; + TransformJobName: string | undefined; /** - *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker assumes to perform the model - * compilation job.

        + *

        The name of the model that you want to use for the transform job. + * ModelName must be the name of an existing Amazon SageMaker model within an AWS + * Region in an AWS account.

        */ - CompilationJobArn: string | undefined; + ModelName: string | undefined; /** - *

        The status of the model compilation job.

        + *

        The maximum number of parallel requests that can be sent to each instance in a + * transform job. If MaxConcurrentTransforms is set to 0 or left + * unset, Amazon SageMaker checks the optional execution-parameters to determine the settings for your + * chosen algorithm. If the execution-parameters endpoint is not enabled, the default value + * is 1. For more information on execution-parameters, see How Containers Serve Requests. For built-in algorithms, you don't need to + * set a value for MaxConcurrentTransforms.

        */ - CompilationJobStatus: CompilationJobStatus | string | undefined; + MaxConcurrentTransforms?: number; /** - *

        The time when the model compilation job started the CompilationJob - * instances.

        - *

        You are billed for the time between this timestamp and the timestamp in the DescribeCompilationJobResponse$CompilationEndTime field. In Amazon CloudWatch Logs, - * the start time might be later than this time. That's because it takes time to download - * the compilation job, which depends on the size of the compilation job container.

        + *

        Configures the timeout and maximum number of retries for processing a transform job + * invocation.

        */ - CompilationStartTime?: Date; + ModelClientConfig?: ModelClientConfig; /** - *

        The time when the model compilation job on a compilation job instance ended. For a - * successful or stopped job, this is when the job's model artifacts have finished - * uploading. For a failed job, this is when Amazon SageMaker detected that the job failed.

        + *

        The maximum allowed size of the payload, in MB. A payload is the + * data portion of a record (without metadata). The value in MaxPayloadInMB + * must be greater than, or equal to, the size of a single record. To estimate the size of + * a record in MB, divide the size of your dataset by the number of records. To ensure that + * the records fit within the maximum payload size, we recommend using a slightly larger + * value. The default value is 6 MB. + *

        + *

        For cases where the payload might be arbitrarily large and is transmitted using HTTP + * chunked encoding, set the value to 0. + * This + * feature works only in supported algorithms. Currently, Amazon SageMaker built-in + * algorithms do not support HTTP chunked encoding.

        */ - CompilationEndTime?: Date; + MaxPayloadInMB?: number; /** - *

        Specifies a limit to how long a model compilation job can run. When the job reaches - * the time limit, Amazon SageMaker ends the compilation job. Use this API to cap model training - * costs.

        + *

        Specifies the number of records to include in a mini-batch for an HTTP inference + * request. A record + * is a single unit of input data that + * inference can be made on. For example, a single line in a CSV file is a record.

        + *

        To enable the batch strategy, you must set the SplitType property to + * Line, RecordIO, or TFRecord.

        + *

        To use only one record when making an HTTP invocation request to a container, set + * BatchStrategy to SingleRecord and SplitType + * to Line.

        + *

        To fit as many records in a mini-batch as can fit within the + * MaxPayloadInMB limit, set BatchStrategy to + * MultiRecord and SplitType to Line.

        */ - StoppingCondition: StoppingCondition | undefined; + BatchStrategy?: BatchStrategy | string; /** - *

        The time that the model compilation job was created.

        + *

        The environment variables to set in the Docker container. We support up to 16 key and + * values entries in the map.

        */ - CreationTime: Date | undefined; + Environment?: { [key: string]: string }; /** - *

        The time that the status - * of - * the model compilation job was last modified.

        + *

        Describes the input source and + * the + * way the transform job consumes it.

        */ - LastModifiedTime: Date | undefined; + TransformInput: TransformInput | undefined; /** - *

        If a model compilation job failed, the reason it failed.

        + *

        Describes the results of the transform job.

        */ - FailureReason: string | undefined; + TransformOutput: TransformOutput | undefined; /** - *

        Information about the location in Amazon S3 that has been configured for storing the model - * artifacts used in the compilation job.

        + *

        Describes the resources, including + * ML + * instance types and ML instance count, to use for the transform + * job.

        */ - ModelArtifacts: ModelArtifacts | undefined; + TransformResources: TransformResources | undefined; /** - *

        The Amazon Resource Name (ARN) of the model compilation job.

        + *

        The data structure used to specify the data to be used for inference in a batch + * transform job and to associate the data that is relevant to the prediction results in + * the output. The input filter provided allows you to exclude input data that is not + * needed for inference in a batch transform job. The output filter provided allows you to + * include input data relevant to interpreting the predictions in the output from the job. + * For more information, see Associate Prediction + * Results with their Corresponding Input Records.

        */ - RoleArn: string | undefined; + DataProcessing?: DataProcessing; /** - *

        Information about the location in Amazon S3 of the input model artifacts, the name and - * shape of the expected data inputs, and the framework in which the model was - * trained.

        + *

        (Optional) + * An + * array of key-value pairs. For more information, see Using + * Cost Allocation Tags in the AWS Billing and Cost Management User + * Guide.

        */ - InputConfig: InputConfig | undefined; + Tags?: Tag[]; /** - *

        Information about the output location for the compiled model and the target device - * that the model runs on.

        + *

        Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

        + * */ - OutputConfig: OutputConfig | undefined; + ExperimentConfig?: ExperimentConfig; } -export namespace DescribeCompilationJobResponse { - export const filterSensitiveLog = (obj: DescribeCompilationJobResponse): any => ({ +export namespace CreateTransformJobRequest { + export const filterSensitiveLog = (obj: CreateTransformJobRequest): any => ({ ...obj, }); } -export interface DescribeDomainRequest { +export interface CreateTransformJobResponse { /** - *

        The domain ID.

        + *

        The Amazon Resource Name (ARN) of the transform job.

        */ - DomainId: string | undefined; + TransformJobArn: string | undefined; } -export namespace DescribeDomainRequest { - export const filterSensitiveLog = (obj: DescribeDomainRequest): any => ({ +export namespace CreateTransformJobResponse { + export const filterSensitiveLog = (obj: CreateTransformJobResponse): any => ({ ...obj, }); } -export enum DomainStatus { - Delete_Failed = "Delete_Failed", - Deleting = "Deleting", - Failed = "Failed", - InService = "InService", - Pending = "Pending", - Update_Failed = "Update_Failed", - Updating = "Updating", -} +export interface CreateTrialRequest { + /** + *

        The name of the trial. The name must be unique in your AWS account and is not + * case-sensitive.

        + */ + TrialName: string | undefined; -export interface DescribeDomainResponse { /** - *

        The domain's Amazon Resource Name (ARN).

        + *

        The name of the trial as displayed. The name doesn't need to be unique. If + * DisplayName isn't specified, TrialName is displayed.

        */ - DomainArn?: string; + DisplayName?: string; /** - *

        The domain ID.

        + *

        The name of the experiment to associate the trial with.

        */ - DomainId?: string; + ExperimentName: string | undefined; /** - *

        The domain name.

        + *

        Metadata properties of the tracking entity, trial, or trial component.

        */ - DomainName?: string; + MetadataProperties?: MetadataProperties; /** - *

        The ID of the Amazon Elastic File System (EFS) managed by this Domain.

        + *

        A list of tags to associate with the trial. You can use Search API to + * search on the tags.

        */ - HomeEfsFileSystemId?: string; + Tags?: Tag[]; +} + +export namespace CreateTrialRequest { + export const filterSensitiveLog = (obj: CreateTrialRequest): any => ({ + ...obj, + }); +} +export interface CreateTrialResponse { /** - *

        The SSO managed application instance ID.

        + *

        The Amazon Resource Name (ARN) of the trial.

        */ - SingleSignOnManagedApplicationInstanceId?: string; + TrialArn?: string; +} +export namespace CreateTrialResponse { + export const filterSensitiveLog = (obj: CreateTrialResponse): any => ({ + ...obj, + }); +} + +/** + *

        Represents an input or output artifact of a trial component. You specify + * TrialComponentArtifact as part of the InputArtifacts and + * OutputArtifacts parameters in the CreateTrialComponent + * request.

        + *

        Examples of input artifacts are datasets, algorithms, hyperparameters, source code, and + * instance types. Examples of output artifacts are metrics, snapshots, logs, and images.

        + */ +export interface TrialComponentArtifact { /** - *

        The status.

        + *

        The media type of the artifact, which indicates the type of data in the artifact file. The + * media type consists of a type and a subtype + * concatenated with a slash (/) character, for example, text/csv, image/jpeg, and s3/uri. The + * type specifies the category of the media. The subtype specifies the kind of data.

        */ - Status?: DomainStatus | string; + MediaType?: string; /** - *

        The creation time.

        + *

        The location of the artifact.

        */ - CreationTime?: Date; + Value: string | undefined; +} + +export namespace TrialComponentArtifact { + export const filterSensitiveLog = (obj: TrialComponentArtifact): any => ({ + ...obj, + }); +} + +/** + *

        The value of a hyperparameter. Only one of NumberValue or + * StringValue can be specified.

        + *

        This object is specified in the CreateTrialComponent request.

        + */ +export type TrialComponentParameterValue = + | TrialComponentParameterValue.NumberValueMember + | TrialComponentParameterValue.StringValueMember + | TrialComponentParameterValue.$UnknownMember; + +export namespace TrialComponentParameterValue { + /** + *

        The string value of a categorical hyperparameter. If you specify a value for this + * parameter, you can't specify the NumberValue parameter.

        + */ + export interface StringValueMember { + StringValue: string; + NumberValue?: never; + $unknown?: never; + } + + /** + *

        The numeric value of a numeric hyperparameter. If you specify a value for this parameter, + * you can't specify the StringValue parameter.

        + */ + export interface NumberValueMember { + StringValue?: never; + NumberValue: number; + $unknown?: never; + } + + export interface $UnknownMember { + StringValue?: never; + NumberValue?: never; + $unknown: [string, any]; + } + + export interface Visitor { + StringValue: (value: string) => T; + NumberValue: (value: number) => T; + _: (name: string, value: any) => T; + } + + export const visit = (value: TrialComponentParameterValue, visitor: Visitor): T => { + if (value.StringValue !== undefined) return visitor.StringValue(value.StringValue); + if (value.NumberValue !== undefined) return visitor.NumberValue(value.NumberValue); + return visitor._(value.$unknown[0], value.$unknown[1]); + }; + + export const filterSensitiveLog = (obj: TrialComponentParameterValue): any => { + if (obj.StringValue !== undefined) return { StringValue: obj.StringValue }; + if (obj.NumberValue !== undefined) return { NumberValue: obj.NumberValue }; + if (obj.$unknown !== undefined) return { [obj.$unknown[0]]: "UNKNOWN" }; + }; +} + +export enum TrialComponentPrimaryStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} +/** + *

        The status of the trial component.

        + */ +export interface TrialComponentStatus { /** - *

        The last modified time.

        + *

        The status of the trial component.

        */ - LastModifiedTime?: Date; + PrimaryStatus?: TrialComponentPrimaryStatus | string; /** - *

        The failure reason.

        + *

        If the component failed, a message describing why.

        */ - FailureReason?: string; + Message?: string; +} +export namespace TrialComponentStatus { + export const filterSensitiveLog = (obj: TrialComponentStatus): any => ({ + ...obj, + }); +} + +export interface CreateTrialComponentRequest { /** - *

        The domain's authentication mode.

        + *

        The name of the component. The name must be unique in your AWS account and is not + * case-sensitive.

        */ - AuthMode?: AuthMode | string; + TrialComponentName: string | undefined; /** - *

        Settings which are applied to all UserProfiles in this domain, if settings are not explicitly specified - * in a given UserProfile. - *

        + *

        The name of the component as displayed. The name doesn't need to be unique. If + * DisplayName isn't specified, TrialComponentName is + * displayed.

        */ - DefaultUserSettings?: UserSettings; + DisplayName?: string; /** - *

        Specifies the VPC used for non-EFS traffic. The default value is - * PublicInternetOnly.

        + *

        The status of the component. States include:

        *
          *
        • - *

          - * PublicInternetOnly - Non-EFS traffic is through a VPC managed by - * Amazon SageMaker, which allows direct internet access

          + *

          InProgress

          *
        • *
        • - *

          - * VpcOnly - All Studio traffic is through the specified VPC and subnets

          + *

          Completed

          + *
        • + *
        • + *

          Failed

          *
        • *
        */ - AppNetworkAccessType?: AppNetworkAccessType | string; + Status?: TrialComponentStatus; /** - *

        This member is deprecated and replaced with KmsKeyId.

        + *

        When the component started.

        */ - HomeEfsFileSystemKmsKeyId?: string; + StartTime?: Date; /** - *

        The VPC subnets that Studio uses for communication.

        + *

        When the component ended.

        */ - SubnetIds?: string[]; + EndTime?: Date; /** - *

        The domain's URL.

        + *

        The hyperparameters for the component.

        */ - Url?: string; + Parameters?: { [key: string]: TrialComponentParameterValue }; /** - *

        The ID of the Amazon Virtual Private Cloud (VPC) that Studio uses for communication.

        + *

        The input artifacts for the component. Examples of input artifacts are datasets, + * algorithms, hyperparameters, source code, and instance types.

        */ - VpcId?: string; + InputArtifacts?: { [key: string]: TrialComponentArtifact }; /** - *

        The AWS KMS customer managed CMK used to encrypt - * the EFS volume attached to the domain.

        + *

        The output artifacts for the component. Examples of output artifacts are metrics, + * snapshots, logs, and images.

        */ - KmsKeyId?: string; + OutputArtifacts?: { [key: string]: TrialComponentArtifact }; + + /** + *

        Metadata properties of the tracking entity, trial, or trial component.

        + */ + MetadataProperties?: MetadataProperties; + + /** + *

        A list of tags to associate with the component. You can use Search API + * to search on the tags.

        + */ + Tags?: Tag[]; } -export namespace DescribeDomainResponse { - export const filterSensitiveLog = (obj: DescribeDomainResponse): any => ({ +export namespace CreateTrialComponentRequest { + export const filterSensitiveLog = (obj: CreateTrialComponentRequest): any => ({ ...obj, + ...(obj.Parameters && { + Parameters: Object.entries(obj.Parameters).reduce( + (acc: any, [key, value]: [string, TrialComponentParameterValue]) => ({ + ...acc, + [key]: TrialComponentParameterValue.filterSensitiveLog(value), + }), + {} + ), + }), }); } -export interface DescribeEndpointInput { +export interface CreateTrialComponentResponse { /** - *

        The name of the endpoint.

        + *

        The Amazon Resource Name (ARN) of the trial component.

        */ - EndpointName: string | undefined; + TrialComponentArn?: string; } -export namespace DescribeEndpointInput { - export const filterSensitiveLog = (obj: DescribeEndpointInput): any => ({ +export namespace CreateTrialComponentResponse { + export const filterSensitiveLog = (obj: CreateTrialComponentResponse): any => ({ ...obj, }); } -export enum EndpointStatus { - CREATING = "Creating", - DELETING = "Deleting", - FAILED = "Failed", - IN_SERVICE = "InService", - OUT_OF_SERVICE = "OutOfService", - ROLLING_BACK = "RollingBack", - SYSTEM_UPDATING = "SystemUpdating", - UPDATING = "Updating", -} - -/** - *

        Describes weight and capacities for a production variant associated with an - * endpoint. If you sent a request to the UpdateEndpointWeightsAndCapacities - * API and the endpoint status is Updating, you get different desired and - * current values.

        - */ -export interface ProductionVariantSummary { +export interface CreateUserProfileRequest { /** - *

        The name of the variant.

        + *

        The ID of the associated Domain.

        */ - VariantName: string | undefined; + DomainId: string | undefined; /** - *

        An array of DeployedImage objects that specify the Amazon EC2 Container Registry paths of the - * inference images deployed on instances of this ProductionVariant.

        + *

        A name for the UserProfile.

        */ - DeployedImages?: DeployedImage[]; + UserProfileName: string | undefined; /** - *

        The weight associated with the variant.

        + *

        A specifier for the type of value specified in SingleSignOnUserValue. Currently, the only supported value is "UserName". + * If the Domain's AuthMode is SSO, this field is required. If the Domain's AuthMode is not SSO, this field cannot be specified. + *

        */ - CurrentWeight?: number; + SingleSignOnUserIdentifier?: string; /** - *

        The requested weight, as specified in the - * UpdateEndpointWeightsAndCapacities request.

        + *

        The username of the associated AWS Single Sign-On User for this UserProfile. If the Domain's AuthMode is SSO, this field is + * required, and must match a valid username of a user in your directory. If the Domain's AuthMode is not SSO, this field cannot be specified. + *

        */ - DesiredWeight?: number; + SingleSignOnUserValue?: string; /** - *

        The number of instances associated with the variant.

        + *

        Each tag consists of a key and an optional value. + * Tag keys must be unique per resource.

        */ - CurrentInstanceCount?: number; + Tags?: Tag[]; /** - *

        The number of instances requested in the - * UpdateEndpointWeightsAndCapacities request.

        + *

        A collection of settings.

        */ - DesiredInstanceCount?: number; + UserSettings?: UserSettings; } -export namespace ProductionVariantSummary { - export const filterSensitiveLog = (obj: ProductionVariantSummary): any => ({ +export namespace CreateUserProfileRequest { + export const filterSensitiveLog = (obj: CreateUserProfileRequest): any => ({ ...obj, }); } -export interface DescribeEndpointOutput { +export interface CreateUserProfileResponse { /** - *

        Name of the endpoint.

        + *

        The user profile Amazon Resource Name (ARN).

        */ - EndpointName: string | undefined; + UserProfileArn?: string; +} + +export namespace CreateUserProfileResponse { + export const filterSensitiveLog = (obj: CreateUserProfileResponse): any => ({ + ...obj, + }); +} +/** + *

        Use this parameter to configure your OIDC Identity Provider (IdP).

        + */ +export interface OidcConfig { /** - *

        The Amazon Resource Name (ARN) of the endpoint.

        + *

        The OIDC IdP client ID used to configure your private workforce.

        */ - EndpointArn: string | undefined; + ClientId: string | undefined; /** - *

        The name of the endpoint configuration associated with this endpoint.

        + *

        The OIDC IdP client secret used to configure your private workforce.

        */ - EndpointConfigName: string | undefined; + ClientSecret: string | undefined; /** - *

        An array of ProductionVariantSummary objects, one for each model - * hosted behind this endpoint.

        + *

        The OIDC IdP issuer used to configure your private workforce.

        */ - ProductionVariants?: ProductionVariantSummary[]; + Issuer: string | undefined; /** - *

        + *

        The OIDC IdP authorization endpoint used to configure your private workforce.

        */ - DataCaptureConfig?: DataCaptureConfigSummary; + AuthorizationEndpoint: string | undefined; /** - *

        The status of the endpoint.

        - *
          - *
        • - *

          - * OutOfService: Endpoint is not available to take incoming - * requests.

          - *
        • - *
        • - *

          - * Creating: CreateEndpoint is executing.

          - *
        • - *
        • - *

          - * Updating: UpdateEndpoint or UpdateEndpointWeightsAndCapacities is executing.

          - *
        • - *
        • - *

          - * SystemUpdating: Endpoint is undergoing maintenance and cannot be - * updated or deleted or re-scaled until it has completed. This maintenance - * operation does not change any customer-specified values such as VPC config, KMS - * encryption, model, instance type, or instance count.

          - *
        • - *
        • - *

          - * RollingBack: Endpoint fails to scale up or down or change its - * variant weight and is in the process of rolling back to its previous - * configuration. Once the rollback completes, endpoint returns to an - * InService status. This transitional status only applies to an - * endpoint that has autoscaling enabled and is undergoing variant weight or - * capacity changes as part of an UpdateEndpointWeightsAndCapacities call or when the UpdateEndpointWeightsAndCapacities operation is called - * explicitly.

          - *
        • - *
        • - *

          - * InService: Endpoint is available to process incoming - * requests.

          - *
        • - *
        • - *

          - * Deleting: DeleteEndpoint is executing.

          - *
        • - *
        • - *

          - * Failed: Endpoint could not be created, updated, or re-scaled. Use - * DescribeEndpointOutput$FailureReason for information about - * the failure. DeleteEndpoint is the only operation that can be - * performed on a failed endpoint.

          - *
        • - *
        + *

        The OIDC IdP token endpoint used to configure your private workforce.

        */ - EndpointStatus: EndpointStatus | string | undefined; + TokenEndpoint: string | undefined; /** - *

        If the status of the endpoint is Failed, the reason why it failed. - *

        + *

        The OIDC IdP user information endpoint used to configure your private workforce.

        */ - FailureReason?: string; + UserInfoEndpoint: string | undefined; /** - *

        A timestamp that shows when the endpoint was created.

        + *

        The OIDC IdP logout endpoint used to configure your private workforce.

        */ - CreationTime: Date | undefined; + LogoutEndpoint: string | undefined; /** - *

        A timestamp that shows when the endpoint was last modified.

        + *

        The OIDC IdP JSON Web Key Set (Jwks) URI used to configure your private workforce.

        */ - LastModifiedTime: Date | undefined; + JwksUri: string | undefined; } -export namespace DescribeEndpointOutput { - export const filterSensitiveLog = (obj: DescribeEndpointOutput): any => ({ +export namespace OidcConfig { + export const filterSensitiveLog = (obj: OidcConfig): any => ({ ...obj, + ...(obj.ClientSecret && { ClientSecret: SENSITIVE_STRING }), }); } -export interface DescribeEndpointConfigInput { +/** + *

        A list of IP address ranges (CIDRs). Used to create an allow + * list of IP addresses for a private workforce. Workers will only be able to login to their worker portal from an + * IP address within this range. By default, a workforce isn't restricted to specific IP addresses.

        + */ +export interface SourceIpConfig { /** - *

        The name of the endpoint configuration.

        + *

        A list of one to ten Classless Inter-Domain Routing (CIDR) values.

        + *

        Maximum: Ten CIDR values

        + * + *

        The following Length Constraints apply to individual CIDR values in + * the CIDR value list.

        + *
        */ - EndpointConfigName: string | undefined; + Cidrs: string[] | undefined; } -export namespace DescribeEndpointConfigInput { - export const filterSensitiveLog = (obj: DescribeEndpointConfigInput): any => ({ +export namespace SourceIpConfig { + export const filterSensitiveLog = (obj: SourceIpConfig): any => ({ ...obj, }); } -export interface DescribeEndpointConfigOutput { - /** - *

        Name of the Amazon SageMaker endpoint configuration.

        - */ - EndpointConfigName: string | undefined; - +export interface CreateWorkforceRequest { /** - *

        The Amazon Resource Name (ARN) of the endpoint configuration.

        + *

        Use this parameter to configure an Amazon Cognito private workforce. + * A single Cognito workforce is created using and corresponds to a single + * + * Amazon Cognito user pool.

        + * + *

        Do not use OidcConfig if you specify values for + * CognitoConfig.

        */ - EndpointConfigArn: string | undefined; + CognitoConfig?: CognitoConfig; /** - *

        An array of ProductionVariant objects, one for each model that you - * want to host at this endpoint.

        + *

        Use this parameter to configure a private workforce using your own OIDC Identity Provider.

        + *

        Do not use CognitoConfig if you specify values for + * OidcConfig.

        */ - ProductionVariants: ProductionVariant[] | undefined; + OidcConfig?: OidcConfig; /** - *

        + *

        A list of IP address ranges (CIDRs). Used to create an allow + * list of IP addresses for a private workforce. Workers will only be able to login to their worker portal from an + * IP address within this range. By default, a workforce isn't restricted to specific IP addresses.

        */ - DataCaptureConfig?: DataCaptureConfig; + SourceIpConfig?: SourceIpConfig; /** - *

        AWS KMS key ID Amazon SageMaker uses to encrypt data when storing it on the ML storage - * volume attached to the instance.

        + *

        The name of the private workforce.

        */ - KmsKeyId?: string; + WorkforceName: string | undefined; /** - *

        A timestamp that shows when the endpoint configuration was created.

        + *

        An array of key-value pairs that contain metadata to help you categorize and + * organize our workforce. Each tag consists of a key and a value, + * both of which you define.

        */ - CreationTime: Date | undefined; + Tags?: Tag[]; } -export namespace DescribeEndpointConfigOutput { - export const filterSensitiveLog = (obj: DescribeEndpointConfigOutput): any => ({ +export namespace CreateWorkforceRequest { + export const filterSensitiveLog = (obj: CreateWorkforceRequest): any => ({ ...obj, + ...(obj.OidcConfig && { OidcConfig: OidcConfig.filterSensitiveLog(obj.OidcConfig) }), }); } -export interface DescribeExperimentRequest { +export interface CreateWorkforceResponse { /** - *

        The name of the experiment to describe.

        + *

        The Amazon Resource Name (ARN) of the workforce.

        */ - ExperimentName: string | undefined; + WorkforceArn: string | undefined; } -export namespace DescribeExperimentRequest { - export const filterSensitiveLog = (obj: DescribeExperimentRequest): any => ({ +export namespace CreateWorkforceResponse { + export const filterSensitiveLog = (obj: CreateWorkforceResponse): any => ({ ...obj, }); } /** - *

        Information about the user who created or modified an experiment, trial, or trial - * component.

        + *

        A list of user groups that exist in your OIDC Identity Provider (IdP). + * One to ten groups can be used to create a single private work team. + * When you add a user group to the list of Groups, you can add that user group to one or more + * private work teams. If you add a user group to a private work team, all workers in that user group + * are added to the work team.

        */ -export interface UserContext { - /** - *

        The Amazon Resource Name (ARN) of the user's profile.

        - */ - UserProfileArn?: string; - - /** - *

        The name of the user's profile.

        - */ - UserProfileName?: string; - +export interface OidcMemberDefinition { /** - *

        The domain associated with the user.

        + *

        A list of comma seperated strings that identifies + * user groups in your OIDC IdP. Each user group is + * made up of a group of private workers.

        */ - DomainId?: string; + Groups: string[] | undefined; } -export namespace UserContext { - export const filterSensitiveLog = (obj: UserContext): any => ({ +export namespace OidcMemberDefinition { + export const filterSensitiveLog = (obj: OidcMemberDefinition): any => ({ ...obj, }); } /** - *

        The source of the experiment.

        + *

        Defines an Amazon Cognito or your own OIDC IdP user group that is part of a work team.

        */ -export interface ExperimentSource { +export interface MemberDefinition { /** - *

        The Amazon Resource Name (ARN) of the source.

        + *

        The Amazon Cognito user group that is part of the work team.

        */ - SourceArn: string | undefined; + CognitoMemberDefinition?: CognitoMemberDefinition; /** - *

        The source type.

        + *

        A list user groups that exist in your OIDC Identity Provider (IdP). + * One to ten groups can be used to create a single private work team. + * When you add a user group to the list of Groups, you can add that user group to one or more + * private work teams. If you add a user group to a private work team, all workers in that user group + * are added to the work team.

        */ - SourceType?: string; + OidcMemberDefinition?: OidcMemberDefinition; } -export namespace ExperimentSource { - export const filterSensitiveLog = (obj: ExperimentSource): any => ({ +export namespace MemberDefinition { + export const filterSensitiveLog = (obj: MemberDefinition): any => ({ ...obj, }); } -export interface DescribeExperimentResponse { - /** - *

        The name of the experiment.

        - */ - ExperimentName?: string; - +/** + *

        Configures SNS notifications of available or expiring work items for work + * teams.

        + */ +export interface NotificationConfiguration { /** - *

        The Amazon Resource Name (ARN) of the experiment.

        + *

        The ARN for the SNS topic to which notifications should be published.

        */ - ExperimentArn?: string; + NotificationTopicArn?: string; +} - /** - *

        The name of the experiment as displayed. If DisplayName isn't specified, - * ExperimentName is displayed.

        - */ - DisplayName?: string; +export namespace NotificationConfiguration { + export const filterSensitiveLog = (obj: NotificationConfiguration): any => ({ + ...obj, + }); +} +export interface CreateWorkteamRequest { /** - *

        The ARN of the source and, optionally, the type.

        + *

        The name of the work team. Use this name to identify the work team.

        */ - Source?: ExperimentSource; + WorkteamName: string | undefined; /** - *

        The description of the experiment.

        + *

        The name of the workforce.

        */ - Description?: string; + WorkforceName?: string; /** - *

        When the experiment was created.

        + *

        A list of MemberDefinition objects that contains objects that identify + * the workers that make up the work team.

        + *

        Workforces can be created using Amazon Cognito or your own OIDC Identity Provider (IdP). For + * private workforces created using Amazon Cognito use CognitoMemberDefinition. For + * workforces created using your own OIDC identity provider (IdP) use + * OidcMemberDefinition. Do not provide input for both of these parameters + * in a single request.

        + *

        For workforces created using Amazon Cognito, private work teams correspond to Amazon Cognito + * user groups within the user pool used to create a workforce. All of the + * CognitoMemberDefinition objects that make up the member definition must + * have the same ClientId and UserPool values. To add a Amazon + * Cognito user group to an existing worker pool, see Adding groups to a User + * Pool. For more information about user pools, see Amazon Cognito User + * Pools.

        + *

        For workforces created using your own OIDC IdP, specify the user groups that you want to + * include in your private work team in OidcMemberDefinition by listing those groups + * in Groups.

        */ - CreationTime?: Date; + MemberDefinitions: MemberDefinition[] | undefined; /** - *

        Who created the experiment.

        + *

        A description of the work team.

        */ - CreatedBy?: UserContext; + Description: string | undefined; /** - *

        When the experiment was last modified.

        + *

        Configures notification of workers regarding available or expiring work items.

        */ - LastModifiedTime?: Date; + NotificationConfiguration?: NotificationConfiguration; /** - *

        Who last modified the experiment.

        + *

        An array of key-value pairs.

        + *

        For more information, see Resource + * Tag and Using + * Cost Allocation Tags in the AWS Billing and Cost Management User + * Guide.

        */ - LastModifiedBy?: UserContext; + Tags?: Tag[]; } -export namespace DescribeExperimentResponse { - export const filterSensitiveLog = (obj: DescribeExperimentResponse): any => ({ +export namespace CreateWorkteamRequest { + export const filterSensitiveLog = (obj: CreateWorkteamRequest): any => ({ ...obj, }); } -export interface DescribeFlowDefinitionRequest { +export interface CreateWorkteamResponse { /** - *

        The name of the flow definition.

        + *

        The Amazon Resource Name (ARN) of the work team. You can use this ARN to identify the + * work team.

        */ - FlowDefinitionName: string | undefined; + WorkteamArn?: string; } -export namespace DescribeFlowDefinitionRequest { - export const filterSensitiveLog = (obj: DescribeFlowDefinitionRequest): any => ({ +export namespace CreateWorkteamResponse { + export const filterSensitiveLog = (obj: CreateWorkteamResponse): any => ({ ...obj, }); } -export enum FlowDefinitionStatus { - ACTIVE = "Active", - DELETING = "Deleting", - FAILED = "Failed", - INITIALIZING = "Initializing", -} - -export interface DescribeFlowDefinitionResponse { +/** + *

        + */ +export interface DataCaptureConfigSummary { /** - *

        The Amazon Resource Name (ARN) of the flow defintion.

        + *

        */ - FlowDefinitionArn: string | undefined; + EnableCapture: boolean | undefined; /** - *

        The Amazon Resource Name (ARN) of the flow definition.

        + *

        */ - FlowDefinitionName: string | undefined; + CaptureStatus: CaptureStatus | string | undefined; /** - *

        The status of the flow definition. Valid values are listed below.

        + *

        */ - FlowDefinitionStatus: FlowDefinitionStatus | string | undefined; + CurrentSamplingPercentage: number | undefined; /** - *

        The timestamp when the flow definition was created.

        + *

        */ - CreationTime: Date | undefined; + DestinationS3Uri: string | undefined; /** - *

        Container for configuring the source of human task requests. Used to specify if - * Amazon Rekognition or Amazon Textract is used as an integration source.

        + *

        */ - HumanLoopRequestSource?: HumanLoopRequestSource; + KmsKeyId: string | undefined; +} + +export namespace DataCaptureConfigSummary { + export const filterSensitiveLog = (obj: DataCaptureConfigSummary): any => ({ + ...obj, + }); +} + +export enum RuleEvaluationStatus { + ERROR = "Error", + IN_PROGRESS = "InProgress", + ISSUES_FOUND = "IssuesFound", + NO_ISSUES_FOUND = "NoIssuesFound", + STOPPED = "Stopped", + STOPPING = "Stopping", +} +/** + *

        Information about the status of the rule evaluation.

        + */ +export interface DebugRuleEvaluationStatus { /** - *

        An object containing information about what triggers a human review workflow.

        + *

        The name of the rule configuration

        */ - HumanLoopActivationConfig?: HumanLoopActivationConfig; + RuleConfigurationName?: string; /** - *

        An object containing information about who works on the task, the workforce task price, and other task details.

        + *

        The Amazon Resource Name (ARN) of the rule evaluation job.

        */ - HumanLoopConfig: HumanLoopConfig | undefined; + RuleEvaluationJobArn?: string; /** - *

        An object containing information about the output file.

        + *

        Status of the rule evaluation.

        */ - OutputConfig: FlowDefinitionOutputConfig | undefined; + RuleEvaluationStatus?: RuleEvaluationStatus | string; /** - *

        The Amazon Resource Name (ARN) of the AWS Identity and Access Management (IAM) execution role for the flow definition.

        + *

        Details from the rule evaluation.

        */ - RoleArn: string | undefined; + StatusDetails?: string; /** - *

        The reason your flow definition failed.

        + *

        Timestamp when the rule evaluation status was last modified.

        */ - FailureReason?: string; + LastModifiedTime?: Date; } -export namespace DescribeFlowDefinitionResponse { - export const filterSensitiveLog = (obj: DescribeFlowDefinitionResponse): any => ({ +export namespace DebugRuleEvaluationStatus { + export const filterSensitiveLog = (obj: DebugRuleEvaluationStatus): any => ({ ...obj, }); } -export interface DescribeHumanTaskUiRequest { +export interface DeleteActionRequest { /** - *

        The name of the human task user interface - * (worker task template) you want information about.

        + *

        The name of the action to delete.

        */ - HumanTaskUiName: string | undefined; + ActionName: string | undefined; } -export namespace DescribeHumanTaskUiRequest { - export const filterSensitiveLog = (obj: DescribeHumanTaskUiRequest): any => ({ +export namespace DeleteActionRequest { + export const filterSensitiveLog = (obj: DeleteActionRequest): any => ({ ...obj, }); } -export enum HumanTaskUiStatus { - ACTIVE = "Active", - DELETING = "Deleting", -} - -/** - *

        Container for user interface template information.

        - */ -export interface UiTemplateInfo { +export interface DeleteActionResponse { /** - *

        The URL for the user interface template.

        + *

        The Amazon Resource Name (ARN) of the action.

        */ - Url?: string; + ActionArn?: string; +} + +export namespace DeleteActionResponse { + export const filterSensitiveLog = (obj: DeleteActionResponse): any => ({ + ...obj, + }); +} +export interface DeleteAlgorithmInput { /** - *

        The SHA-256 digest of the contents of the template.

        + *

        The name of the algorithm to delete.

        */ - ContentSha256?: string; + AlgorithmName: string | undefined; } -export namespace UiTemplateInfo { - export const filterSensitiveLog = (obj: UiTemplateInfo): any => ({ +export namespace DeleteAlgorithmInput { + export const filterSensitiveLog = (obj: DeleteAlgorithmInput): any => ({ ...obj, }); } -export interface DescribeHumanTaskUiResponse { +export interface DeleteAppRequest { /** - *

        The Amazon Resource Name (ARN) of the human task user interface (worker task template).

        + *

        The domain ID.

        */ - HumanTaskUiArn: string | undefined; + DomainId: string | undefined; /** - *

        The name of the human task user interface (worker task template).

        + *

        The user profile name.

        */ - HumanTaskUiName: string | undefined; + UserProfileName: string | undefined; /** - *

        The status of the human task user interface (worker task template). Valid values are listed below.

        + *

        The type of app.

        */ - HumanTaskUiStatus?: HumanTaskUiStatus | string; + AppType: AppType | string | undefined; /** - *

        The timestamp when the human task user interface was created.

        + *

        The name of the app.

        */ - CreationTime: Date | undefined; + AppName: string | undefined; +} + +export namespace DeleteAppRequest { + export const filterSensitiveLog = (obj: DeleteAppRequest): any => ({ + ...obj, + }); +} +export interface DeleteAppImageConfigRequest { /** - *

        Container for user interface template information.

        + *

        The name of the AppImageConfig to delete.

        */ - UiTemplate: UiTemplateInfo | undefined; + AppImageConfigName: string | undefined; } -export namespace DescribeHumanTaskUiResponse { - export const filterSensitiveLog = (obj: DescribeHumanTaskUiResponse): any => ({ +export namespace DeleteAppImageConfigRequest { + export const filterSensitiveLog = (obj: DeleteAppImageConfigRequest): any => ({ ...obj, }); } -export interface DescribeHyperParameterTuningJobRequest { +export interface DeleteArtifactRequest { /** - *

        The name of the tuning job.

        + *

        The Amazon Resource Name (ARN) of the artifact to delete.

        */ - HyperParameterTuningJobName: string | undefined; + ArtifactArn?: string; + + /** + *

        The URI of the source.

        + */ + Source?: ArtifactSource; } -export namespace DescribeHyperParameterTuningJobRequest { - export const filterSensitiveLog = (obj: DescribeHyperParameterTuningJobRequest): any => ({ +export namespace DeleteArtifactRequest { + export const filterSensitiveLog = (obj: DeleteArtifactRequest): any => ({ ...obj, }); } -/** - *

        Shows the final value for the - * objective - * metric for a training job that was launched by a hyperparameter - * tuning job. You define the objective metric in the - * HyperParameterTuningJobObjective parameter of HyperParameterTuningJobConfig.

        - */ -export interface FinalHyperParameterTuningJobObjectiveMetric { +export interface DeleteArtifactResponse { /** - *

        Whether to - * minimize - * or maximize the objective metric. Valid values are Minimize and - * Maximize.

        + *

        The Amazon Resource Name (ARN) of the artifact.

        */ - Type?: HyperParameterTuningJobObjectiveType | string; + ArtifactArn?: string; +} + +export namespace DeleteArtifactResponse { + export const filterSensitiveLog = (obj: DeleteArtifactResponse): any => ({ + ...obj, + }); +} +export interface DeleteAssociationRequest { /** - *

        The name of the - * objective - * metric.

        + *

        The ARN of the source.

        */ - MetricName: string | undefined; + SourceArn: string | undefined; /** - *

        The value of the objective metric.

        + *

        The Amazon Resource Name (ARN) of the destination.

        */ - Value: number | undefined; + DestinationArn: string | undefined; } -export namespace FinalHyperParameterTuningJobObjectiveMetric { - export const filterSensitiveLog = (obj: FinalHyperParameterTuningJobObjectiveMetric): any => ({ +export namespace DeleteAssociationRequest { + export const filterSensitiveLog = (obj: DeleteAssociationRequest): any => ({ ...obj, }); } -export enum TrainingJobStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -/** - *

        Specifies - * summary information about a training job.

        - */ -export interface HyperParameterTrainingJobSummary { - /** - *

        The training job definition name.

        - */ - TrainingJobDefinitionName?: string; - - /** - *

        The name of the training job.

        - */ - TrainingJobName: string | undefined; - - /** - *

        The - * Amazon - * Resource Name (ARN) of the training job.

        - */ - TrainingJobArn: string | undefined; - +export interface DeleteAssociationResponse { /** - *

        The HyperParameter tuning job that launched the training job.

        - */ - TuningJobName?: string; - - /** - *

        The date and time that the training job was created.

        + *

        The ARN of the source.

        */ - CreationTime: Date | undefined; + SourceArn?: string; /** - *

        The date and time that the training job started.

        + *

        The Amazon Resource Name (ARN) of the destination.

        */ - TrainingStartTime?: Date; + DestinationArn?: string; +} - /** - *

        Specifies the time when the training job ends on training instances. You are billed - * for the time interval between the value of TrainingStartTime and this time. - * For successful jobs and stopped jobs, this is the time after model artifacts are - * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

        - */ - TrainingEndTime?: Date; +export namespace DeleteAssociationResponse { + export const filterSensitiveLog = (obj: DeleteAssociationResponse): any => ({ + ...obj, + }); +} +export interface DeleteCodeRepositoryInput { /** - *

        The - * status - * of the training job.

        + *

        The name of the Git repository to delete.

        */ - TrainingJobStatus: TrainingJobStatus | string | undefined; + CodeRepositoryName: string | undefined; +} - /** - *

        A - * list of the hyperparameters for which you specified ranges to - * search.

        - */ - TunedHyperParameters: { [key: string]: string } | undefined; +export namespace DeleteCodeRepositoryInput { + export const filterSensitiveLog = (obj: DeleteCodeRepositoryInput): any => ({ + ...obj, + }); +} +export interface DeleteContextRequest { /** - *

        The - * reason that the training job failed. - *

        + *

        The name of the context to delete.

        */ - FailureReason?: string; + ContextName: string | undefined; +} - /** - *

        The FinalHyperParameterTuningJobObjectiveMetric object that - * specifies the - * value - * of the - * objective - * metric of the tuning job that launched this training job.

        - */ - FinalHyperParameterTuningJobObjectiveMetric?: FinalHyperParameterTuningJobObjectiveMetric; +export namespace DeleteContextRequest { + export const filterSensitiveLog = (obj: DeleteContextRequest): any => ({ + ...obj, + }); +} +export interface DeleteContextResponse { /** - *

        The status of the objective metric for the training job:

        - *
          - *
        • - *

          Succeeded: The - * final - * objective metric for the training job was evaluated by the - * hyperparameter tuning job and - * used - * in the hyperparameter tuning process.

          - *
        • - *
        - *
          - *
        • - *

          Pending: The training job is in progress and evaluation of its final objective - * metric is pending.

          - *
        • - *
        - *
          - *
        • - *

          Failed: - * The final objective metric for the training job was not evaluated, and was not - * used in the hyperparameter tuning process. This typically occurs when the - * training job failed or did not emit an objective - * metric.

          - *
        • - *
        + *

        The Amazon Resource Name (ARN) of the context.

        */ - ObjectiveStatus?: ObjectiveStatus | string; + ContextArn?: string; } -export namespace HyperParameterTrainingJobSummary { - export const filterSensitiveLog = (obj: HyperParameterTrainingJobSummary): any => ({ +export namespace DeleteContextResponse { + export const filterSensitiveLog = (obj: DeleteContextResponse): any => ({ ...obj, }); } -export enum HyperParameterTuningJobStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", +export enum RetentionType { + Delete = "Delete", + Retain = "Retain", } /** - *

        Specifies the number of training jobs that this hyperparameter tuning job launched, - * categorized by the status of their objective metric. The objective metric status shows - * whether the - * final - * objective metric for the training job has been evaluated by the - * tuning job and used in the hyperparameter tuning process.

        + *

        The retention policy for data stored on an Amazon Elastic File System (EFS) volume.

        */ -export interface ObjectiveStatusCounters { +export interface RetentionPolicy { /** - *

        The number of training jobs whose final objective metric was evaluated by the - * hyperparameter tuning job and used in the hyperparameter tuning process.

        + *

        The default is Retain, which specifies to keep the data stored on the EFS volume.

        + *

        Specify Delete to delete the data stored on the EFS volume.

        */ - Succeeded?: number; + HomeEfsFileSystem?: RetentionType | string; +} + +export namespace RetentionPolicy { + export const filterSensitiveLog = (obj: RetentionPolicy): any => ({ + ...obj, + }); +} +export interface DeleteDomainRequest { /** - *

        The number of training jobs that are in progress and pending evaluation of their final - * objective metric.

        + *

        The domain ID.

        */ - Pending?: number; + DomainId: string | undefined; /** - *

        The number of training jobs whose final objective metric was not evaluated and used in - * the hyperparameter tuning process. This typically occurs when the training job failed or - * did not emit an objective metric.

        + *

        The retention policy for this domain, which specifies whether resources will be retained after the Domain is deleted. + * By default, all resources are retained (not automatically deleted). + *

        */ - Failed?: number; + RetentionPolicy?: RetentionPolicy; } -export namespace ObjectiveStatusCounters { - export const filterSensitiveLog = (obj: ObjectiveStatusCounters): any => ({ +export namespace DeleteDomainRequest { + export const filterSensitiveLog = (obj: DeleteDomainRequest): any => ({ ...obj, }); } -/** - *

        The numbers of training jobs launched by a hyperparameter tuning job, categorized by - * status.

        - */ -export interface TrainingJobStatusCounters { +export interface DeleteEndpointInput { /** - *

        The number of completed training jobs launched by the hyperparameter tuning - * job.

        + *

        The name of the endpoint that you want to delete.

        */ - Completed?: number; + EndpointName: string | undefined; +} - /** - *

        The number of in-progress training jobs launched by a hyperparameter tuning - * job.

        - */ - InProgress?: number; +export namespace DeleteEndpointInput { + export const filterSensitiveLog = (obj: DeleteEndpointInput): any => ({ + ...obj, + }); +} +export interface DeleteEndpointConfigInput { /** - *

        The number of training jobs that failed, but can be retried. A failed training job can - * be retried only if it failed because an internal service error occurred.

        + *

        The name of the endpoint configuration that you want to delete.

        */ - RetryableError?: number; + EndpointConfigName: string | undefined; +} - /** - *

        The number of training jobs that failed and can't be retried. A failed training job - * can't be retried if it failed because a client error occurred.

        - */ - NonRetryableError?: number; +export namespace DeleteEndpointConfigInput { + export const filterSensitiveLog = (obj: DeleteEndpointConfigInput): any => ({ + ...obj, + }); +} +export interface DeleteExperimentRequest { /** - *

        The number of training jobs launched by a hyperparameter tuning job that were - * manually - * stopped.

        + *

        The name of the experiment to delete.

        */ - Stopped?: number; + ExperimentName: string | undefined; } -export namespace TrainingJobStatusCounters { - export const filterSensitiveLog = (obj: TrainingJobStatusCounters): any => ({ +export namespace DeleteExperimentRequest { + export const filterSensitiveLog = (obj: DeleteExperimentRequest): any => ({ ...obj, }); } -export interface DescribeHyperParameterTuningJobResponse { +export interface DeleteExperimentResponse { /** - *

        The name of the tuning job.

        + *

        The Amazon Resource Name (ARN) of the experiment that is being deleted.

        */ - HyperParameterTuningJobName: string | undefined; + ExperimentArn?: string; +} - /** - *

        The - * Amazon Resource Name (ARN) of the tuning job.

        - */ - HyperParameterTuningJobArn: string | undefined; +export namespace DeleteExperimentResponse { + export const filterSensitiveLog = (obj: DeleteExperimentResponse): any => ({ + ...obj, + }); +} +export interface DeleteFeatureGroupRequest { /** - *

        The HyperParameterTuningJobConfig object that specifies the - * configuration of the tuning job.

        + *

        The name of the FeatureGroup you want to delete. The name must be unique + * within an AWS Region in an AWS account.

        */ - HyperParameterTuningJobConfig: HyperParameterTuningJobConfig | undefined; + FeatureGroupName: string | undefined; +} - /** - *

        The HyperParameterTrainingJobDefinition object that specifies the - * definition of the training jobs that this tuning job launches.

        - */ - TrainingJobDefinition?: HyperParameterTrainingJobDefinition; +export namespace DeleteFeatureGroupRequest { + export const filterSensitiveLog = (obj: DeleteFeatureGroupRequest): any => ({ + ...obj, + }); +} +export interface DeleteFlowDefinitionRequest { /** - *

        A list of the HyperParameterTrainingJobDefinition objects launched - * for this tuning job.

        + *

        The name of the flow definition you are deleting.

        */ - TrainingJobDefinitions?: HyperParameterTrainingJobDefinition[]; + FlowDefinitionName: string | undefined; +} - /** - *

        The status of the tuning job: InProgress, Completed, Failed, Stopping, or - * Stopped.

        - */ - HyperParameterTuningJobStatus: HyperParameterTuningJobStatus | string | undefined; +export namespace DeleteFlowDefinitionRequest { + export const filterSensitiveLog = (obj: DeleteFlowDefinitionRequest): any => ({ + ...obj, + }); +} - /** - *

        The date and time that the tuning job started.

        - */ - CreationTime: Date | undefined; +export interface DeleteFlowDefinitionResponse {} - /** - *

        The date and time that the tuning job ended.

        - */ - HyperParameterTuningEndTime?: Date; +export namespace DeleteFlowDefinitionResponse { + export const filterSensitiveLog = (obj: DeleteFlowDefinitionResponse): any => ({ + ...obj, + }); +} +export interface DeleteHumanTaskUiRequest { /** - *

        The date and time that the status of the tuning job was modified.

        - */ - LastModifiedTime?: Date; - - /** - *

        The TrainingJobStatusCounters object that specifies the number of - * training jobs, categorized by status, that this tuning job launched.

        - */ - TrainingJobStatusCounters: TrainingJobStatusCounters | undefined; - - /** - *

        The ObjectiveStatusCounters object that specifies the number of - * training jobs, categorized by the status of their final objective metric, that this - * tuning job launched.

        - */ - ObjectiveStatusCounters: ObjectiveStatusCounters | undefined; - - /** - *

        A TrainingJobSummary object that describes the training job that - * completed with the best current HyperParameterTuningJobObjective.

        - */ - BestTrainingJob?: HyperParameterTrainingJobSummary; - - /** - *

        If the hyperparameter tuning job is an warm start tuning job with a - * WarmStartType of IDENTICAL_DATA_AND_ALGORITHM, this is the - * TrainingJobSummary for the training job with the best objective - * metric value of all training jobs launched by this tuning job and all parent jobs - * specified for the warm start tuning job.

        - */ - OverallBestTrainingJob?: HyperParameterTrainingJobSummary; - - /** - *

        The configuration for starting the hyperparameter parameter tuning job using one or - * more previous tuning jobs as a starting point. The results of previous tuning jobs are - * used to inform which combinations of hyperparameters to search over in the new tuning - * job.

        + *

        The name of the human task user interface (work task template) you want to delete.

        */ - WarmStartConfig?: HyperParameterTuningJobWarmStartConfig; + HumanTaskUiName: string | undefined; +} - /** - *

        If the tuning job failed, the reason it failed.

        - */ - FailureReason?: string; +export namespace DeleteHumanTaskUiRequest { + export const filterSensitiveLog = (obj: DeleteHumanTaskUiRequest): any => ({ + ...obj, + }); } -export namespace DescribeHyperParameterTuningJobResponse { - export const filterSensitiveLog = (obj: DescribeHyperParameterTuningJobResponse): any => ({ +export interface DeleteHumanTaskUiResponse {} + +export namespace DeleteHumanTaskUiResponse { + export const filterSensitiveLog = (obj: DeleteHumanTaskUiResponse): any => ({ ...obj, }); } -export interface DescribeImageRequest { +export interface DeleteImageRequest { /** - *

        The name of the image to describe.

        + *

        The name of the image to delete.

        */ ImageName: string | undefined; } -export namespace DescribeImageRequest { - export const filterSensitiveLog = (obj: DescribeImageRequest): any => ({ +export namespace DeleteImageRequest { + export const filterSensitiveLog = (obj: DeleteImageRequest): any => ({ ...obj, }); } -export enum ImageStatus { - CREATED = "CREATED", - CREATE_FAILED = "CREATE_FAILED", - CREATING = "CREATING", - DELETE_FAILED = "DELETE_FAILED", - DELETING = "DELETING", - UPDATE_FAILED = "UPDATE_FAILED", - UPDATING = "UPDATING", -} +export interface DeleteImageResponse {} -export interface DescribeImageResponse { - /** - *

        When the image was created.

        - */ - CreationTime?: Date; +export namespace DeleteImageResponse { + export const filterSensitiveLog = (obj: DeleteImageResponse): any => ({ + ...obj, + }); +} +export interface DeleteImageVersionRequest { /** - *

        The description of the image.

        + *

        The name of the image.

        */ - Description?: string; + ImageName: string | undefined; /** - *

        The name of the image as displayed.

        + *

        The version to delete.

        */ - DisplayName?: string; + Version: number | undefined; +} - /** - *

        When a create, update, or delete operation fails, the reason for the failure.

        - */ - FailureReason?: string; +export namespace DeleteImageVersionRequest { + export const filterSensitiveLog = (obj: DeleteImageVersionRequest): any => ({ + ...obj, + }); +} - /** - *

        The Amazon Resource Name (ARN) of the image.

        - */ - ImageArn?: string; +export interface DeleteImageVersionResponse {} - /** - *

        The name of the image.

        - */ - ImageName?: string; +export namespace DeleteImageVersionResponse { + export const filterSensitiveLog = (obj: DeleteImageVersionResponse): any => ({ + ...obj, + }); +} +export interface DeleteModelInput { /** - *

        The status of the image.

        + *

        The name of the model to delete.

        */ - ImageStatus?: ImageStatus | string; + ModelName: string | undefined; +} - /** - *

        When the image was last modified.

        - */ - LastModifiedTime?: Date; +export namespace DeleteModelInput { + export const filterSensitiveLog = (obj: DeleteModelInput): any => ({ + ...obj, + }); +} +export interface DeleteModelPackageInput { /** - *

        The Amazon Resource Name (ARN) of the IAM role that enables Amazon SageMaker to perform tasks on your behalf.

        + *

        The name of the model package. The name must have 1 to 63 characters. Valid characters + * are a-z, A-Z, 0-9, and - (hyphen).

        */ - RoleArn?: string; + ModelPackageName: string | undefined; } -export namespace DescribeImageResponse { - export const filterSensitiveLog = (obj: DescribeImageResponse): any => ({ +export namespace DeleteModelPackageInput { + export const filterSensitiveLog = (obj: DeleteModelPackageInput): any => ({ ...obj, }); } -export interface DescribeImageVersionRequest { - /** - *

        The name of the image.

        - */ - ImageName: string | undefined; - +export interface DeleteModelPackageGroupInput { /** - *

        The version of the image. If not specified, the latest version is described.

        + *

        The name of the model group to delete.

        */ - Version?: number; + ModelPackageGroupName: string | undefined; } -export namespace DescribeImageVersionRequest { - export const filterSensitiveLog = (obj: DescribeImageVersionRequest): any => ({ +export namespace DeleteModelPackageGroupInput { + export const filterSensitiveLog = (obj: DeleteModelPackageGroupInput): any => ({ ...obj, }); } -export enum ImageVersionStatus { - CREATED = "CREATED", - CREATE_FAILED = "CREATE_FAILED", - CREATING = "CREATING", - DELETE_FAILED = "DELETE_FAILED", - DELETING = "DELETING", -} - -export interface DescribeImageVersionResponse { +export interface DeleteModelPackageGroupPolicyInput { /** - *

        The registry path of the container image on which this image version is based.

        + *

        The name of the model group for which to delete the policy.

        */ - BaseImage?: string; + ModelPackageGroupName: string | undefined; +} - /** - *

        The registry path of the container image that contains this image version.

        - */ - ContainerImage?: string; +export namespace DeleteModelPackageGroupPolicyInput { + export const filterSensitiveLog = (obj: DeleteModelPackageGroupPolicyInput): any => ({ + ...obj, + }); +} +export interface DeleteMonitoringScheduleRequest { /** - *

        When the version was created.

        + *

        The name of the monitoring schedule to delete.

        */ - CreationTime?: Date; + MonitoringScheduleName: string | undefined; +} - /** - *

        When a create or delete operation fails, the reason for the failure.

        - */ - FailureReason?: string; +export namespace DeleteMonitoringScheduleRequest { + export const filterSensitiveLog = (obj: DeleteMonitoringScheduleRequest): any => ({ + ...obj, + }); +} +export interface DeleteNotebookInstanceInput { /** - *

        The Amazon Resource Name (ARN) of the image the version is based on.

        + *

        The name of the Amazon SageMaker notebook instance to delete.

        */ - ImageArn?: string; + NotebookInstanceName: string | undefined; +} - /** - *

        The ARN of the version.

        - */ - ImageVersionArn?: string; +export namespace DeleteNotebookInstanceInput { + export const filterSensitiveLog = (obj: DeleteNotebookInstanceInput): any => ({ + ...obj, + }); +} +export interface DeleteNotebookInstanceLifecycleConfigInput { /** - *

        The status of the version.

        + *

        The name of the lifecycle configuration to delete.

        */ - ImageVersionStatus?: ImageVersionStatus | string; + NotebookInstanceLifecycleConfigName: string | undefined; +} + +export namespace DeleteNotebookInstanceLifecycleConfigInput { + export const filterSensitiveLog = (obj: DeleteNotebookInstanceLifecycleConfigInput): any => ({ + ...obj, + }); +} +export interface DeletePipelineRequest { /** - *

        When the version was last modified.

        + *

        The name of the pipeline to delete.

        */ - LastModifiedTime?: Date; + PipelineName: string | undefined; /** - *

        The version number.

        + *

        A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * operation. An idempotent operation completes no more than one time.

        */ - Version?: number; + ClientRequestToken?: string; } -export namespace DescribeImageVersionResponse { - export const filterSensitiveLog = (obj: DescribeImageVersionResponse): any => ({ +export namespace DeletePipelineRequest { + export const filterSensitiveLog = (obj: DeletePipelineRequest): any => ({ ...obj, }); } -export interface DescribeLabelingJobRequest { +export interface DeletePipelineResponse { /** - *

        The name of the labeling job to return information for.

        + *

        The Amazon Resource Name (ARN) of the pipeline to delete.

        */ - LabelingJobName: string | undefined; + PipelineArn?: string; } -export namespace DescribeLabelingJobRequest { - export const filterSensitiveLog = (obj: DescribeLabelingJobRequest): any => ({ +export namespace DeletePipelineResponse { + export const filterSensitiveLog = (obj: DeletePipelineResponse): any => ({ ...obj, }); } -/** - *

        Provides a breakdown of the number of objects labeled.

        - */ -export interface LabelCounters { - /** - *

        The total number of objects labeled.

        - */ - TotalLabeled?: number; - +export interface DeleteProjectInput { /** - *

        The total number of objects labeled by a human worker.

        + *

        The name of the project to delete.

        */ - HumanLabeled?: number; + ProjectName: string | undefined; +} - /** - *

        The total number of objects labeled by automated data labeling.

        - */ - MachineLabeled?: number; +export namespace DeleteProjectInput { + export const filterSensitiveLog = (obj: DeleteProjectInput): any => ({ + ...obj, + }); +} +export interface DeleteTagsInput { /** - *

        The total number of objects that could not be labeled due to an error.

        + *

        The Amazon Resource Name (ARN) of the resource whose tags you want to + * delete.

        */ - FailedNonRetryableError?: number; + ResourceArn: string | undefined; /** - *

        The total number of objects not yet labeled.

        + *

        An array or one or more tag keys to delete.

        */ - Unlabeled?: number; + TagKeys: string[] | undefined; } -export namespace LabelCounters { - export const filterSensitiveLog = (obj: LabelCounters): any => ({ +export namespace DeleteTagsInput { + export const filterSensitiveLog = (obj: DeleteTagsInput): any => ({ ...obj, }); } -/** - *

        Specifies the location of the output produced by the labeling job.

        - */ -export interface LabelingJobOutput { +export interface DeleteTagsOutput {} + +export namespace DeleteTagsOutput { + export const filterSensitiveLog = (obj: DeleteTagsOutput): any => ({ + ...obj, + }); +} + +export interface DeleteTrialRequest { /** - *

        The Amazon S3 bucket location of the manifest file for labeled data.

        + *

        The name of the trial to delete.

        */ - OutputDatasetS3Uri: string | undefined; + TrialName: string | undefined; +} + +export namespace DeleteTrialRequest { + export const filterSensitiveLog = (obj: DeleteTrialRequest): any => ({ + ...obj, + }); +} +export interface DeleteTrialResponse { /** - *

        The Amazon Resource Name (ARN) for the most recent Amazon SageMaker model trained as part of - * automated data labeling.

        + *

        The Amazon Resource Name (ARN) of the trial that is being deleted.

        */ - FinalActiveLearningModelArn?: string; + TrialArn?: string; } -export namespace LabelingJobOutput { - export const filterSensitiveLog = (obj: LabelingJobOutput): any => ({ +export namespace DeleteTrialResponse { + export const filterSensitiveLog = (obj: DeleteTrialResponse): any => ({ ...obj, }); } -export enum LabelingJobStatus { - COMPLETED = "Completed", - FAILED = "Failed", - INITIALIZING = "Initializing", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", +export interface DeleteTrialComponentRequest { + /** + *

        The name of the component to delete.

        + */ + TrialComponentName: string | undefined; } -export interface DescribeLabelingJobResponse { +export namespace DeleteTrialComponentRequest { + export const filterSensitiveLog = (obj: DeleteTrialComponentRequest): any => ({ + ...obj, + }); +} + +export interface DeleteTrialComponentResponse { /** - *

        The processing status of the labeling job.

        + *

        The Amazon Resource Name (ARN) of the component is being deleted.

        */ - LabelingJobStatus: LabelingJobStatus | string | undefined; + TrialComponentArn?: string; +} + +export namespace DeleteTrialComponentResponse { + export const filterSensitiveLog = (obj: DeleteTrialComponentResponse): any => ({ + ...obj, + }); +} +export interface DeleteUserProfileRequest { /** - *

        Provides a breakdown of the number of data objects labeled by humans, the number of - * objects labeled by machine, the number of objects than couldn't be labeled, and the - * total number of objects labeled.

        + *

        The domain ID.

        */ - LabelCounters: LabelCounters | undefined; + DomainId: string | undefined; /** - *

        If the job failed, the reason that it failed.

        + *

        The user profile name.

        */ - FailureReason?: string; + UserProfileName: string | undefined; +} + +export namespace DeleteUserProfileRequest { + export const filterSensitiveLog = (obj: DeleteUserProfileRequest): any => ({ + ...obj, + }); +} +export interface DeleteWorkforceRequest { /** - *

        The date and time that the labeling job was created.

        + *

        The name of the workforce.

        */ - CreationTime: Date | undefined; + WorkforceName: string | undefined; +} + +export namespace DeleteWorkforceRequest { + export const filterSensitiveLog = (obj: DeleteWorkforceRequest): any => ({ + ...obj, + }); +} + +export interface DeleteWorkforceResponse {} + +export namespace DeleteWorkforceResponse { + export const filterSensitiveLog = (obj: DeleteWorkforceResponse): any => ({ + ...obj, + }); +} +export interface DeleteWorkteamRequest { /** - *

        The date and time that the labeling job was last updated.

        + *

        The name of the work team to delete.

        */ - LastModifiedTime: Date | undefined; + WorkteamName: string | undefined; +} + +export namespace DeleteWorkteamRequest { + export const filterSensitiveLog = (obj: DeleteWorkteamRequest): any => ({ + ...obj, + }); +} +export interface DeleteWorkteamResponse { /** - *

        A unique identifier for work done as part of a labeling job.

        + *

        Returns true if the work team was successfully deleted; otherwise, + * returns false.

        */ - JobReferenceCode: string | undefined; + Success: boolean | undefined; +} + +export namespace DeleteWorkteamResponse { + export const filterSensitiveLog = (obj: DeleteWorkteamResponse): any => ({ + ...obj, + }); +} +/** + *

        Gets the Amazon EC2 Container Registry path of the docker image of the model that is hosted in this ProductionVariant.

        + *

        If you used the registry/repository[:tag] form to specify the image path + * of the primary container when you created the model hosted in this + * ProductionVariant, the path resolves to a path of the form + * registry/repository[@digest]. A digest is a hash value that identifies + * a specific version of an image. For information about Amazon ECR paths, see Pulling an Image in the Amazon ECR User Guide.

        + */ +export interface DeployedImage { /** - *

        The name assigned to the labeling job when it was created.

        + *

        The image path you specified when you created the model.

        */ - LabelingJobName: string | undefined; + SpecifiedImage?: string; /** - *

        The Amazon Resource Name (ARN) of the labeling job.

        + *

        The specific digest path of the image hosted in this + * ProductionVariant.

        */ - LabelingJobArn: string | undefined; + ResolvedImage?: string; /** - *

        The attribute used as the label in the output manifest file.

        + *

        The date and time when the image path for the model resolved to the + * ResolvedImage + *

        */ - LabelAttributeName?: string; + ResolutionTime?: Date; +} + +export namespace DeployedImage { + export const filterSensitiveLog = (obj: DeployedImage): any => ({ + ...obj, + }); +} +/** + *

        Currently, the DeploymentConfig API is not supported.

        + */ +export interface DeploymentConfig { /** - *

        Input configuration information for the labeling job, such as the Amazon S3 location of the - * data objects and the location of the manifest file that describes the data - * objects.

        + *

        */ - InputConfig: LabelingJobInputConfig | undefined; + BlueGreenUpdatePolicy: BlueGreenUpdatePolicy | undefined; /** - *

        The location of the job's output data and the AWS Key Management Service key ID for the key used to - * encrypt the output data, if any.

        + *

        */ - OutputConfig: LabelingJobOutputConfig | undefined; + AutoRollbackConfiguration?: AutoRollbackConfig; +} + +export namespace DeploymentConfig { + export const filterSensitiveLog = (obj: DeploymentConfig): any => ({ + ...obj, + }); +} +export interface DescribeActionRequest { /** - *

        The Amazon Resource Name (ARN) that Amazon SageMaker assumes to perform tasks on your behalf - * during data labeling.

        + *

        The name of the action to describe.

        */ - RoleArn: string | undefined; + ActionName: string | undefined; +} + +export namespace DescribeActionRequest { + export const filterSensitiveLog = (obj: DescribeActionRequest): any => ({ + ...obj, + }); +} +export interface DescribeActionResponse { /** - *

        The S3 location of the JSON file that defines the categories used to label data - * objects. Please note the following label-category limits:

        - *
          - *
        • - *

          Semantic segmentation labeling jobs using automated labeling: 20 labels

          - *
        • - *
        • - *

          Box bounding labeling jobs (all): 10 labels

          - *
        • - *
        - *

        The file is a JSON structure in the following format:

        - *

        - * { - *

        - *

        - * "document-version": "2018-11-28" - *

        - *

        - * "labels": [ - *

        - *

        - * { - *

        - *

        - * "label": "label 1" - *

        - *

        - * }, - *

        - *

        - * { - *

        - *

        - * "label": "label 2" - *

        - *

        - * }, - *

        - *

        - * ... - *

        - *

        - * { - *

        - *

        - * "label": "label n" - *

        - *

        - * } - *

        - *

        - * ] - *

        - *

        - * } - *

        + *

        The name of the action.

        */ - LabelCategoryConfigS3Uri?: string; + ActionName?: string; /** - *

        A set of conditions for stopping a labeling job. If any of the conditions are met, the - * job is automatically stopped.

        + *

        The Amazon Resource Name (ARN) of the action.

        */ - StoppingConditions?: LabelingJobStoppingConditions; + ActionArn?: string; /** - *

        Configuration information for automated data labeling.

        + *

        The source of the action.

        */ - LabelingJobAlgorithmsConfig?: LabelingJobAlgorithmsConfig; + Source?: ActionSource; /** - *

        Configuration information required for human workers to complete a labeling - * task.

        + *

        The type of the action.

        */ - HumanTaskConfig: HumanTaskConfig | undefined; + ActionType?: string; /** - *

        An array of key/value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide.

        + *

        The description of the action.

        */ - Tags?: Tag[]; + Description?: string; /** - *

        The location of the output produced by the labeling job.

        + *

        The status of the action.

        */ - LabelingJobOutput?: LabelingJobOutput; -} + Status?: ActionStatus | string; -export namespace DescribeLabelingJobResponse { - export const filterSensitiveLog = (obj: DescribeLabelingJobResponse): any => ({ + /** + *

        A list of the action's properties.

        + */ + Properties?: { [key: string]: string }; + + /** + *

        When the action was created.

        + */ + CreationTime?: Date; + + /** + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        + */ + CreatedBy?: UserContext; + + /** + *

        When the action was last modified.

        + */ + LastModifiedTime?: Date; + + /** + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        + */ + LastModifiedBy?: UserContext; + + /** + *

        Metadata properties of the tracking entity, trial, or trial component.

        + */ + MetadataProperties?: MetadataProperties; +} + +export namespace DescribeActionResponse { + export const filterSensitiveLog = (obj: DescribeActionResponse): any => ({ ...obj, }); } -export interface DescribeModelInput { +export interface DescribeAlgorithmInput { /** - *

        The name of the model.

        + *

        The name of the algorithm to describe.

        */ - ModelName: string | undefined; + AlgorithmName: string | undefined; } -export namespace DescribeModelInput { - export const filterSensitiveLog = (obj: DescribeModelInput): any => ({ +export namespace DescribeAlgorithmInput { + export const filterSensitiveLog = (obj: DescribeAlgorithmInput): any => ({ ...obj, }); } -export interface DescribeModelOutput { +export interface DescribeAlgorithmOutput { /** - *

        Name of the Amazon SageMaker model.

        + *

        The name of the algorithm being described.

        */ - ModelName: string | undefined; + AlgorithmName: string | undefined; /** - *

        The location of the primary inference code, associated artifacts, and custom - * environment map that the inference code uses when it is deployed in production. - *

        + *

        The Amazon Resource Name (ARN) of the algorithm.

        */ - PrimaryContainer?: ContainerDefinition; + AlgorithmArn: string | undefined; /** - *

        The containers in the inference pipeline.

        + *

        A brief summary about the algorithm.

        */ - Containers?: ContainerDefinition[]; + AlgorithmDescription?: string; /** - *

        The Amazon Resource Name (ARN) of the IAM role that you specified for the - * model.

        + *

        A timestamp specifying when the algorithm was created.

        */ - ExecutionRoleArn: string | undefined; + CreationTime: Date | undefined; /** - *

        A VpcConfig object that specifies the VPC that this model has access - * to. For more information, see Protect Endpoints by Using an Amazon Virtual - * Private Cloud - *

        + *

        Details about training jobs run by this algorithm.

        */ - VpcConfig?: VpcConfig; + TrainingSpecification: TrainingSpecification | undefined; /** - *

        A timestamp that shows when the model was created.

        + *

        Details about inference jobs that the algorithm runs.

        */ - CreationTime: Date | undefined; + InferenceSpecification?: InferenceSpecification; /** - *

        The Amazon Resource Name (ARN) of the model.

        + *

        Details about configurations for one or more training jobs that Amazon SageMaker runs to test the + * algorithm.

        */ - ModelArn: string | undefined; + ValidationSpecification?: AlgorithmValidationSpecification; /** - *

        If True, no inbound or outbound network calls can be made to or from the - * model container.

        + *

        The current status of the algorithm.

        */ - EnableNetworkIsolation?: boolean; -} + AlgorithmStatus: AlgorithmStatus | string | undefined; -export namespace DescribeModelOutput { - export const filterSensitiveLog = (obj: DescribeModelOutput): any => ({ - ...obj, - }); -} + /** + *

        Details about the current status of the algorithm.

        + */ + AlgorithmStatusDetails: AlgorithmStatusDetails | undefined; -export interface DescribeModelPackageInput { /** - *

        The name of the model package to describe.

        + *

        The product identifier of the algorithm.

        */ - ModelPackageName: string | undefined; + ProductId?: string; + + /** + *

        Whether the algorithm is certified to be listed in AWS Marketplace.

        + */ + CertifyForMarketplace?: boolean; } -export namespace DescribeModelPackageInput { - export const filterSensitiveLog = (obj: DescribeModelPackageInput): any => ({ +export namespace DescribeAlgorithmOutput { + export const filterSensitiveLog = (obj: DescribeAlgorithmOutput): any => ({ ...obj, }); } -export enum ModelPackageStatus { - COMPLETED = "Completed", - DELETING = "Deleting", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - PENDING = "Pending", -} - -export enum DetailedModelPackageStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - NOT_STARTED = "NotStarted", -} +export interface DescribeAppRequest { + /** + *

        The domain ID.

        + */ + DomainId: string | undefined; -/** - *

        Represents the overall status of a model package.

        - */ -export interface ModelPackageStatusItem { /** - *

        The name of the model package for which the overall status is being reported.

        + *

        The user profile name.

        */ - Name: string | undefined; + UserProfileName: string | undefined; /** - *

        The current status.

        + *

        The type of app.

        */ - Status: DetailedModelPackageStatus | string | undefined; + AppType: AppType | string | undefined; /** - *

        if the overall status is Failed, the reason for the failure.

        + *

        The name of the app.

        */ - FailureReason?: string; + AppName: string | undefined; } -export namespace ModelPackageStatusItem { - export const filterSensitiveLog = (obj: ModelPackageStatusItem): any => ({ +export namespace DescribeAppRequest { + export const filterSensitiveLog = (obj: DescribeAppRequest): any => ({ ...obj, }); } -/** - *

        Specifies the validation and image scan statuses of the model package.

        - */ -export interface ModelPackageStatusDetails { - /** - *

        The validation status of the model package.

        - */ - ValidationStatuses: ModelPackageStatusItem[] | undefined; - +export interface DescribeAppResponse { /** - *

        The status of the scan of the Docker image container for the model package.

        + *

        The Amazon Resource Name (ARN) of the app.

        */ - ImageScanStatuses?: ModelPackageStatusItem[]; -} - -export namespace ModelPackageStatusDetails { - export const filterSensitiveLog = (obj: ModelPackageStatusDetails): any => ({ - ...obj, - }); -} + AppArn?: string; -export interface DescribeModelPackageOutput { /** - *

        The name of the model package being described.

        + *

        The type of app.

        */ - ModelPackageName: string | undefined; + AppType?: AppType | string; /** - *

        The Amazon Resource Name (ARN) of the model package.

        + *

        The name of the app.

        */ - ModelPackageArn: string | undefined; + AppName?: string; /** - *

        A brief summary of the model package.

        + *

        The domain ID.

        */ - ModelPackageDescription?: string; + DomainId?: string; /** - *

        A timestamp specifying when the model package was created.

        + *

        The user profile name.

        */ - CreationTime: Date | undefined; + UserProfileName?: string; /** - *

        Details about inference jobs that can be run with models based on this model - * package.

        + *

        The status.

        */ - InferenceSpecification?: InferenceSpecification; + Status?: AppStatus | string; /** - *

        Details about the algorithm that was used to create the model package.

        + *

        The timestamp of the last health check.

        */ - SourceAlgorithmSpecification?: SourceAlgorithmSpecification; + LastHealthCheckTimestamp?: Date; /** - *

        Configurations for one or more transform jobs that Amazon SageMaker runs to test the model - * package.

        + *

        The timestamp of the last user's activity.

        */ - ValidationSpecification?: ModelPackageValidationSpecification; + LastUserActivityTimestamp?: Date; /** - *

        The current status of the model package.

        + *

        The creation time.

        */ - ModelPackageStatus: ModelPackageStatus | string | undefined; + CreationTime?: Date; /** - *

        Details about the current status of the model package.

        + *

        The failure reason.

        */ - ModelPackageStatusDetails: ModelPackageStatusDetails | undefined; + FailureReason?: string; /** - *

        Whether the model package is certified for listing on AWS Marketplace.

        + *

        The instance type and the Amazon Resource Name (ARN) of the SageMaker image created on the instance.

        */ - CertifyForMarketplace?: boolean; + ResourceSpec?: ResourceSpec; } -export namespace DescribeModelPackageOutput { - export const filterSensitiveLog = (obj: DescribeModelPackageOutput): any => ({ +export namespace DescribeAppResponse { + export const filterSensitiveLog = (obj: DescribeAppResponse): any => ({ ...obj, }); } -export interface DescribeMonitoringScheduleRequest { +export interface DescribeAppImageConfigRequest { /** - *

        Name of a previously created monitoring schedule.

        + *

        The name of the AppImageConfig to describe.

        */ - MonitoringScheduleName: string | undefined; + AppImageConfigName: string | undefined; } -export namespace DescribeMonitoringScheduleRequest { - export const filterSensitiveLog = (obj: DescribeMonitoringScheduleRequest): any => ({ +export namespace DescribeAppImageConfigRequest { + export const filterSensitiveLog = (obj: DescribeAppImageConfigRequest): any => ({ ...obj, }); } -export enum ExecutionStatus { - COMPLETED = "Completed", - COMPLETED_WITH_VIOLATIONS = "CompletedWithViolations", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - PENDING = "Pending", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -/** - *

        Summary of information about the last monitoring job to run.

        - */ -export interface MonitoringExecutionSummary { +export interface DescribeAppImageConfigResponse { /** - *

        The name of the monitoring schedule.

        + *

        The Amazon Resource Name (ARN) of the AppImageConfig.

        */ - MonitoringScheduleName: string | undefined; + AppImageConfigArn?: string; /** - *

        The time the monitoring job was scheduled.

        + *

        The name of the AppImageConfig.

        */ - ScheduledTime: Date | undefined; + AppImageConfigName?: string; /** - *

        The time at which the monitoring job was created.

        + *

        When the AppImageConfig was created.

        */ - CreationTime: Date | undefined; + CreationTime?: Date; /** - *

        A timestamp that indicates the last time the monitoring job was modified.

        + *

        When the AppImageConfig was last modified.

        */ - LastModifiedTime: Date | undefined; + LastModifiedTime?: Date; /** - *

        The status of the monitoring job.

        + *

        The configuration of a KernelGateway app.

        */ - MonitoringExecutionStatus: ExecutionStatus | string | undefined; - - /** - *

        The Amazon Resource Name (ARN) of the monitoring job.

        - */ - ProcessingJobArn?: string; + KernelGatewayImageConfig?: KernelGatewayImageConfig; +} - /** - *

        The name of teh endpoint used to run the monitoring job.

        - */ - EndpointName?: string; +export namespace DescribeAppImageConfigResponse { + export const filterSensitiveLog = (obj: DescribeAppImageConfigResponse): any => ({ + ...obj, + }); +} +export interface DescribeArtifactRequest { /** - *

        Contains the reason a monitoring job failed, if it failed.

        + *

        The Amazon Resource Name (ARN) of the artifact to describe.

        */ - FailureReason?: string; + ArtifactArn: string | undefined; } -export namespace MonitoringExecutionSummary { - export const filterSensitiveLog = (obj: MonitoringExecutionSummary): any => ({ +export namespace DescribeArtifactRequest { + export const filterSensitiveLog = (obj: DescribeArtifactRequest): any => ({ ...obj, }); } -export enum ScheduleStatus { - FAILED = "Failed", - PENDING = "Pending", - SCHEDULED = "Scheduled", - STOPPED = "Stopped", -} +export interface DescribeArtifactResponse { + /** + *

        The name of the artifact.

        + */ + ArtifactName?: string; -export interface DescribeMonitoringScheduleResponse { /** - *

        The Amazon Resource Name (ARN) of the monitoring schedule.

        + *

        The Amazon Resource Name (ARN) of the artifact.

        */ - MonitoringScheduleArn: string | undefined; + ArtifactArn?: string; /** - *

        Name of the monitoring schedule.

        + *

        The source of the artifact.

        */ - MonitoringScheduleName: string | undefined; + Source?: ArtifactSource; /** - *

        The status of an monitoring job.

        + *

        The type of the artifact.

        */ - MonitoringScheduleStatus: ScheduleStatus | string | undefined; + ArtifactType?: string; /** - *

        A string, up to one KB in size, that contains the reason a monitoring job failed, if it - * failed.

        + *

        A list of the artifact's properties.

        */ - FailureReason?: string; + Properties?: { [key: string]: string }; /** - *

        The time at which the monitoring job was created.

        + *

        When the artifact was created.

        */ - CreationTime: Date | undefined; + CreationTime?: Date; /** - *

        The time at which the monitoring job was last modified.

        + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        */ - LastModifiedTime: Date | undefined; + CreatedBy?: UserContext; /** - *

        The configuration object that specifies the monitoring schedule and defines the - * monitoring job.

        + *

        When the artifact was last modified.

        */ - MonitoringScheduleConfig: MonitoringScheduleConfig | undefined; + LastModifiedTime?: Date; /** - *

        The name of the endpoint for the monitoring job.

        + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        */ - EndpointName?: string; + LastModifiedBy?: UserContext; /** - *

        Describes metadata on the last execution to run, if there was one.

        + *

        Metadata properties of the tracking entity, trial, or trial component.

        */ - LastMonitoringExecutionSummary?: MonitoringExecutionSummary; + MetadataProperties?: MetadataProperties; } -export namespace DescribeMonitoringScheduleResponse { - export const filterSensitiveLog = (obj: DescribeMonitoringScheduleResponse): any => ({ +export namespace DescribeArtifactResponse { + export const filterSensitiveLog = (obj: DescribeArtifactResponse): any => ({ ...obj, }); } -export interface DescribeNotebookInstanceInput { +export interface DescribeAutoMLJobRequest { /** - *

        The name of the notebook instance that you want information about.

        + *

        Request information about a job using that job's unique name.

        */ - NotebookInstanceName: string | undefined; + AutoMLJobName: string | undefined; } -export namespace DescribeNotebookInstanceInput { - export const filterSensitiveLog = (obj: DescribeNotebookInstanceInput): any => ({ +export namespace DescribeAutoMLJobRequest { + export const filterSensitiveLog = (obj: DescribeAutoMLJobRequest): any => ({ ...obj, }); } -export enum NotebookInstanceStatus { - Deleting = "Deleting", - Failed = "Failed", - InService = "InService", - Pending = "Pending", - Stopped = "Stopped", - Stopping = "Stopping", - Updating = "Updating", -} +/** + *

        The resolved attributes.

        + */ +export interface ResolvedAttributes { + /** + *

        Specifies a metric to minimize or maximize as the objective of a job.

        + */ + AutoMLJobObjective?: AutoMLJobObjective; -export interface DescribeNotebookInstanceOutput { /** - *

        The Amazon Resource Name (ARN) of the notebook instance.

        + *

        The problem type.

        */ - NotebookInstanceArn?: string; + ProblemType?: ProblemType | string; /** - *

        The name of the Amazon SageMaker notebook instance.

        + *

        How long a job is allowed to run, or how many candidates a job is allowed to + * generate.

        */ - NotebookInstanceName?: string; + CompletionCriteria?: AutoMLJobCompletionCriteria; +} +export namespace ResolvedAttributes { + export const filterSensitiveLog = (obj: ResolvedAttributes): any => ({ + ...obj, + }); +} + +export interface DescribeAutoMLJobResponse { /** - *

        The status of the notebook instance.

        + *

        Returns the name of a job.

        */ - NotebookInstanceStatus?: NotebookInstanceStatus | string; + AutoMLJobName: string | undefined; /** - *

        If status is Failed, the reason it failed.

        + *

        Returns the job's ARN.

        */ - FailureReason?: string; + AutoMLJobArn: string | undefined; /** - *

        The URL that you use to connect to the Jupyter notebook that is running in your - * notebook instance.

        + *

        Returns the job's input data config.

        */ - Url?: string; + InputDataConfig: AutoMLChannel[] | undefined; /** - *

        The type of ML compute instance running on the notebook instance.

        + *

        Returns the job's output data config.

        */ - InstanceType?: _InstanceType | string; + OutputDataConfig: AutoMLOutputDataConfig | undefined; /** - *

        The ID of the VPC subnet.

        + *

        The Amazon Resource Name (ARN) of the AWS Identity and Access Management (IAM) role that has read permission to + * the input data location and write permission to the output data location in Amazon S3.

        */ - SubnetId?: string; + RoleArn: string | undefined; /** - *

        The IDs of the VPC security groups.

        + *

        Returns the job's objective.

        */ - SecurityGroups?: string[]; + AutoMLJobObjective?: AutoMLJobObjective; /** - *

        The Amazon Resource Name (ARN) of the IAM role associated with the instance. - *

        + *

        Returns the job's problem type.

        */ - RoleArn?: string; + ProblemType?: ProblemType | string; /** - *

        The AWS KMS key ID Amazon SageMaker uses to encrypt data when storing it on the ML storage - * volume attached to the instance.

        + *

        Returns the job's config.

        */ - KmsKeyId?: string; + AutoMLJobConfig?: AutoMLJobConfig; /** - *

        The network interface IDs that Amazon SageMaker created at the time of creating the instance. - *

        + *

        Returns the job's creation time.

        */ - NetworkInterfaceId?: string; + CreationTime: Date | undefined; /** - *

        A timestamp. Use this parameter to retrieve the time when the notebook instance was - * last modified.

        + *

        Returns the job's end time.

        */ - LastModifiedTime?: Date; + EndTime?: Date; /** - *

        A timestamp. Use this parameter to return the time when the notebook instance was - * created

        + *

        Returns the job's last modified time.

        */ - CreationTime?: Date; + LastModifiedTime: Date | undefined; /** - *

        Returns the name of a notebook instance lifecycle configuration.

        - *

        For information about notebook instance lifestyle configurations, see Step - * 2.1: (Optional) Customize a Notebook Instance - *

        + *

        Returns the job's FailureReason.

        */ - NotebookInstanceLifecycleConfigName?: string; + FailureReason?: string; /** - *

        Describes whether Amazon SageMaker provides internet access to the notebook instance. If this - * value is set to Disabled, the notebook instance does not have - * internet access, and cannot connect to Amazon SageMaker training and endpoint services.

        - *

        For more information, see Notebook Instances Are Internet-Enabled by Default.

        + *

        Returns the job's BestCandidate.

        */ - DirectInternetAccess?: DirectInternetAccess | string; + BestCandidate?: AutoMLCandidate; /** - *

        The size, in GB, of the ML storage volume attached to the notebook instance.

        + *

        Returns the job's AutoMLJobStatus.

        */ - VolumeSizeInGB?: number; + AutoMLJobStatus: AutoMLJobStatus | string | undefined; /** - *

        A list of the Elastic Inference (EI) instance types associated with this notebook - * instance. Currently only one EI instance type can be associated with a notebook - * instance. For more information, see Using Elastic Inference in Amazon - * SageMaker.

        + *

        Returns the job's AutoMLJobSecondaryStatus.

        */ - AcceleratorTypes?: (NotebookInstanceAcceleratorType | string)[]; + AutoMLJobSecondaryStatus: AutoMLJobSecondaryStatus | string | undefined; /** - *

        The Git repository associated with the notebook instance as its default code - * repository. This can be either the name of a Git repository stored as a resource in your - * account, or the URL of a Git repository in AWS CodeCommit or in any - * other Git repository. When you open a notebook instance, it opens in the directory that - * contains this repository. For more information, see Associating Git Repositories with Amazon SageMaker - * Notebook Instances.

        + *

        Returns the job's output from GenerateCandidateDefinitionsOnly.

        */ - DefaultCodeRepository?: string; + GenerateCandidateDefinitionsOnly?: boolean; /** - *

        An array of up to three Git repositories associated with the notebook instance. These - * can be either the names of Git repositories stored as resources in your account, or the - * URL of Git repositories in AWS CodeCommit or in any - * other Git repository. These repositories are cloned at the same level as the default - * repository of your notebook instance. For more information, see Associating Git - * Repositories with Amazon SageMaker Notebook Instances.

        + *

        Returns information on the job's artifacts found in AutoMLJobArtifacts.

        */ - AdditionalCodeRepositories?: string[]; + AutoMLJobArtifacts?: AutoMLJobArtifacts; /** - *

        Whether root access is enabled or disabled for users of the notebook instance.

        - * - *

        Lifecycle configurations need root access to be able to set up a notebook - * instance. Because of this, lifecycle configurations associated with a notebook - * instance always run with root access even if you disable root access for - * users.

        - *
        + *

        This contains ProblemType, AutoMLJobObjective and CompletionCriteria. They're + * auto-inferred values, if not provided by you. If you do provide them, then they'll be the + * same as provided.

        */ - RootAccess?: RootAccess | string; + ResolvedAttributes?: ResolvedAttributes; } -export namespace DescribeNotebookInstanceOutput { - export const filterSensitiveLog = (obj: DescribeNotebookInstanceOutput): any => ({ +export namespace DescribeAutoMLJobResponse { + export const filterSensitiveLog = (obj: DescribeAutoMLJobResponse): any => ({ ...obj, }); } -export interface DescribeNotebookInstanceLifecycleConfigInput { +export interface DescribeCodeRepositoryInput { /** - *

        The name of the lifecycle configuration to describe.

        + *

        The name of the Git repository to describe.

        */ - NotebookInstanceLifecycleConfigName: string | undefined; + CodeRepositoryName: string | undefined; } -export namespace DescribeNotebookInstanceLifecycleConfigInput { - export const filterSensitiveLog = (obj: DescribeNotebookInstanceLifecycleConfigInput): any => ({ +export namespace DescribeCodeRepositoryInput { + export const filterSensitiveLog = (obj: DescribeCodeRepositoryInput): any => ({ ...obj, }); } -export interface DescribeNotebookInstanceLifecycleConfigOutput { - /** - *

        The Amazon Resource Name (ARN) of the lifecycle configuration.

        - */ - NotebookInstanceLifecycleConfigArn?: string; - +export interface DescribeCodeRepositoryOutput { /** - *

        The name of the lifecycle configuration.

        + *

        The name of the Git repository.

        */ - NotebookInstanceLifecycleConfigName?: string; + CodeRepositoryName: string | undefined; /** - *

        The shell script that runs only once, when you create a notebook instance.

        + *

        The Amazon Resource Name (ARN) of the Git repository.

        */ - OnCreate?: NotebookInstanceLifecycleHook[]; + CodeRepositoryArn: string | undefined; /** - *

        The shell script that runs every time you start a notebook instance, including when - * you create the notebook instance.

        + *

        The date and time that the repository was created.

        */ - OnStart?: NotebookInstanceLifecycleHook[]; + CreationTime: Date | undefined; /** - *

        A timestamp that tells when the lifecycle configuration was last modified.

        + *

        The date and time that the repository was last changed.

        */ - LastModifiedTime?: Date; + LastModifiedTime: Date | undefined; /** - *

        A timestamp that tells when the lifecycle configuration was created.

        + *

        Configuration details about the repository, including the URL where the repository is + * located, the default branch, and the Amazon Resource Name (ARN) of the AWS Secrets + * Manager secret that contains the credentials used to access the repository.

        */ - CreationTime?: Date; + GitConfig?: GitConfig; } -export namespace DescribeNotebookInstanceLifecycleConfigOutput { - export const filterSensitiveLog = (obj: DescribeNotebookInstanceLifecycleConfigOutput): any => ({ - ...obj, +export namespace DescribeCodeRepositoryOutput { + export const filterSensitiveLog = (obj: DescribeCodeRepositoryOutput): any => ({ + ...obj, }); } -export interface DescribeProcessingJobRequest { +export interface DescribeCompilationJobRequest { /** - *

        The name of the processing job. The name must be unique within an AWS Region in the - * AWS account.

        + *

        The name of the model compilation job that you want information about.

        */ - ProcessingJobName: string | undefined; + CompilationJobName: string | undefined; } -export namespace DescribeProcessingJobRequest { - export const filterSensitiveLog = (obj: DescribeProcessingJobRequest): any => ({ +export namespace DescribeCompilationJobRequest { + export const filterSensitiveLog = (obj: DescribeCompilationJobRequest): any => ({ ...obj, }); } -export enum ProcessingJobStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -export interface DescribeProcessingJobResponse { +/** + *

        Provides information about the location that is configured for storing model + * artifacts.

        + *

        Model artifacts are the output that results from training a model, and typically + * consist of trained parameters, a model defintion that desribes how to compute + * inferences, and other metadata.

        + */ +export interface ModelArtifacts { /** - *

        The inputs for a processing job.

        + *

        The path of the S3 object that contains the model artifacts. For example, + * s3://bucket-name/keynameprefix/model.tar.gz.

        */ - ProcessingInputs?: ProcessingInput[]; + S3ModelArtifacts: string | undefined; +} + +export namespace ModelArtifacts { + export const filterSensitiveLog = (obj: ModelArtifacts): any => ({ + ...obj, + }); +} +/** + *

        Provides information to verify the integrity of stored model artifacts.

        + */ +export interface ModelDigests { /** - *

        Output configuration for the processing job.

        + *

        Provides a hash value that uniquely identifies the stored model artifacts.

        */ - ProcessingOutputConfig?: ProcessingOutputConfig; + ArtifactDigest?: string; +} +export namespace ModelDigests { + export const filterSensitiveLog = (obj: ModelDigests): any => ({ + ...obj, + }); +} + +export interface DescribeCompilationJobResponse { /** - *

        The name of the processing job. The name must be unique within an AWS Region in the - * AWS account.

        + *

        The name of the model compilation job.

        */ - ProcessingJobName: string | undefined; + CompilationJobName: string | undefined; /** - *

        Identifies the resources, ML compute instances, and ML storage volumes to deploy for a - * processing job. In distributed training, you specify more than one instance.

        + *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker assumes to perform the model + * compilation job.

        */ - ProcessingResources: ProcessingResources | undefined; + CompilationJobArn: string | undefined; /** - *

        The time limit for how long the processing job is allowed to run.

        + *

        The status of the model compilation job.

        */ - StoppingCondition?: ProcessingStoppingCondition; + CompilationJobStatus: CompilationJobStatus | string | undefined; /** - *

        Configures the processing job to run a specified container image.

        + *

        The time when the model compilation job started the CompilationJob + * instances.

        + *

        You are billed for the time between this timestamp and the timestamp in the DescribeCompilationJobResponse$CompilationEndTime field. In Amazon CloudWatch Logs, + * the start time might be later than this time. That's because it takes time to download + * the compilation job, which depends on the size of the compilation job container.

        */ - AppSpecification: AppSpecification | undefined; + CompilationStartTime?: Date; /** - *

        The environment variables set in the Docker container.

        + *

        The time when the model compilation job on a compilation job instance ended. For a + * successful or stopped job, this is when the job's model artifacts have finished + * uploading. For a failed job, this is when Amazon SageMaker detected that the job failed.

        */ - Environment?: { [key: string]: string }; + CompilationEndTime?: Date; /** - *

        Networking options for a processing job.

        + *

        Specifies a limit to how long a model compilation job can run. When the job reaches + * the time limit, Amazon SageMaker ends the compilation job. Use this API to cap model training + * costs.

        */ - NetworkConfig?: NetworkConfig; + StoppingCondition: StoppingCondition | undefined; /** - *

        The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform tasks on - * your behalf.

        + *

        The time that the model compilation job was created.

        */ - RoleArn?: string; + CreationTime: Date | undefined; /** - *

        The configuration information used to create an experiment.

        + *

        The time that the status + * of + * the model compilation job was last modified.

        */ - ExperimentConfig?: ExperimentConfig; + LastModifiedTime: Date | undefined; /** - *

        The Amazon Resource Name (ARN) of the processing job.

        + *

        If a model compilation job failed, the reason it failed.

        */ - ProcessingJobArn: string | undefined; + FailureReason: string | undefined; /** - *

        Provides the status of a processing job.

        + *

        Information about the location in Amazon S3 that has been configured for storing the model + * artifacts used in the compilation job.

        */ - ProcessingJobStatus: ProcessingJobStatus | string | undefined; + ModelArtifacts: ModelArtifacts | undefined; /** - *

        An optional string, up to one KB in size, that contains metadata from the processing - * container when the processing job exits.

        + *

        Provides a BLAKE2 hash value that identifies the compiled model artifacts in Amazon S3.

        */ - ExitMessage?: string; + ModelDigests?: ModelDigests; /** - *

        A string, up to one KB in size, that contains the reason a processing job failed, if - * it failed.

        + *

        The Amazon Resource Name (ARN) of the model compilation job.

        */ - FailureReason?: string; + RoleArn: string | undefined; /** - *

        The time at which the processing job completed.

        + *

        Information about the location in Amazon S3 of the input model artifacts, the name and + * shape of the expected data inputs, and the framework in which the model was + * trained.

        */ - ProcessingEndTime?: Date; + InputConfig: InputConfig | undefined; /** - *

        The time at which the processing job started.

        + *

        Information about the output location for the compiled model and the target device + * that the model runs on.

        */ - ProcessingStartTime?: Date; + OutputConfig: OutputConfig | undefined; +} +export namespace DescribeCompilationJobResponse { + export const filterSensitiveLog = (obj: DescribeCompilationJobResponse): any => ({ + ...obj, + }); +} + +export interface DescribeContextRequest { /** - *

        The time at which the processing job was last modified.

        + *

        The name of the context to describe.

        */ - LastModifiedTime?: Date; + ContextName: string | undefined; +} + +export namespace DescribeContextRequest { + export const filterSensitiveLog = (obj: DescribeContextRequest): any => ({ + ...obj, + }); +} +export interface DescribeContextResponse { /** - *

        The time at which the processing job was created.

        + *

        The name of the context.

        */ - CreationTime: Date | undefined; + ContextName?: string; /** - *

        The ARN of a monitoring schedule for an endpoint associated with this processing - * job.

        + *

        The Amazon Resource Name (ARN) of the context.

        */ - MonitoringScheduleArn?: string; + ContextArn?: string; /** - *

        The ARN of an AutoML job associated with this processing job.

        + *

        The source of the context.

        */ - AutoMLJobArn?: string; + Source?: ContextSource; /** - *

        The ARN of a training job associated with this processing job.

        + *

        The type of the context.

        */ - TrainingJobArn?: string; -} - -export namespace DescribeProcessingJobResponse { - export const filterSensitiveLog = (obj: DescribeProcessingJobResponse): any => ({ - ...obj, - }); -} + ContextType?: string; -export interface DescribeSubscribedWorkteamRequest { /** - *

        The Amazon Resource Name (ARN) of the subscribed work team to describe.

        + *

        The description of the context.

        */ - WorkteamArn: string | undefined; -} - -export namespace DescribeSubscribedWorkteamRequest { - export const filterSensitiveLog = (obj: DescribeSubscribedWorkteamRequest): any => ({ - ...obj, - }); -} + Description?: string; -/** - *

        Describes a work team of a vendor that does the a labelling job.

        - */ -export interface SubscribedWorkteam { /** - *

        The Amazon Resource Name (ARN) of the vendor that you have subscribed.

        + *

        A list of the context's properties.

        */ - WorkteamArn: string | undefined; + Properties?: { [key: string]: string }; /** - *

        The title of the service provided by the vendor in the Amazon Marketplace.

        + *

        When the context was created.

        */ - MarketplaceTitle?: string; + CreationTime?: Date; /** - *

        The name of the vendor in the Amazon Marketplace.

        + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        */ - SellerName?: string; + CreatedBy?: UserContext; /** - *

        The description of the vendor from the Amazon Marketplace.

        + *

        When the context was last modified.

        */ - MarketplaceDescription?: string; + LastModifiedTime?: Date; /** - *

        Marketplace product listing ID.

        + *

        Information about the user who created or modified an experiment, trial, or trial + * component.

        */ - ListingId?: string; + LastModifiedBy?: UserContext; } -export namespace SubscribedWorkteam { - export const filterSensitiveLog = (obj: SubscribedWorkteam): any => ({ +export namespace DescribeContextResponse { + export const filterSensitiveLog = (obj: DescribeContextResponse): any => ({ ...obj, }); } -export interface DescribeSubscribedWorkteamResponse { +export interface DescribeDomainRequest { /** - *

        A Workteam instance that contains information about the work team.

        + *

        The domain ID.

        */ - SubscribedWorkteam: SubscribedWorkteam | undefined; + DomainId: string | undefined; } -export namespace DescribeSubscribedWorkteamResponse { - export const filterSensitiveLog = (obj: DescribeSubscribedWorkteamResponse): any => ({ +export namespace DescribeDomainRequest { + export const filterSensitiveLog = (obj: DescribeDomainRequest): any => ({ ...obj, }); } -export interface DescribeTrainingJobRequest { +export enum DomainStatus { + Delete_Failed = "Delete_Failed", + Deleting = "Deleting", + Failed = "Failed", + InService = "InService", + Pending = "Pending", + Update_Failed = "Update_Failed", + Updating = "Updating", +} + +export interface DescribeDomainResponse { /** - *

        The name of the training job.

        + *

        The domain's Amazon Resource Name (ARN).

        */ - TrainingJobName: string | undefined; -} + DomainArn?: string; -export namespace DescribeTrainingJobRequest { - export const filterSensitiveLog = (obj: DescribeTrainingJobRequest): any => ({ - ...obj, - }); -} + /** + *

        The domain ID.

        + */ + DomainId?: string; -/** - *

        The name, value, and date and time of a metric that was emitted to Amazon CloudWatch.

        - */ -export interface MetricData { /** - *

        The name of the metric.

        + *

        The domain name.

        */ - MetricName?: string; + DomainName?: string; /** - *

        The value of the metric.

        + *

        The ID of the Amazon Elastic File System (EFS) managed by this Domain.

        */ - Value?: number; + HomeEfsFileSystemId?: string; /** - *

        The date and time that the algorithm emitted the metric.

        + *

        The SSO managed application instance ID.

        */ - Timestamp?: Date; -} + SingleSignOnManagedApplicationInstanceId?: string; -export namespace MetricData { - export const filterSensitiveLog = (obj: MetricData): any => ({ - ...obj, - }); -} + /** + *

        The status.

        + */ + Status?: DomainStatus | string; -export enum SecondaryStatus { - COMPLETED = "Completed", - DOWNLOADING = "Downloading", - DOWNLOADING_TRAINING_IMAGE = "DownloadingTrainingImage", - FAILED = "Failed", - INTERRUPTED = "Interrupted", - LAUNCHING_ML_INSTANCES = "LaunchingMLInstances", - MAX_RUNTIME_EXCEEDED = "MaxRuntimeExceeded", - MAX_WAIT_TIME_EXCEEDED = "MaxWaitTimeExceeded", - PREPARING_TRAINING_STACK = "PreparingTrainingStack", - STARTING = "Starting", - STOPPED = "Stopped", - STOPPING = "Stopping", - TRAINING = "Training", - UPLOADING = "Uploading", -} + /** + *

        The creation time.

        + */ + CreationTime?: Date; -/** - *

        An array element of DescribeTrainingJobResponse$SecondaryStatusTransitions. It provides - * additional details about a status that the training job has transitioned through. A - * training job can be in one of several states, for example, starting, downloading, - * training, or uploading. Within each state, there are a number of intermediate states. - * For example, within the starting state, Amazon SageMaker could be starting the training job or - * launching the ML instances. These transitional states are referred to as the job's - * secondary - * status. - *

        - *

        - */ -export interface SecondaryStatusTransition { /** - *

        Contains a secondary status information from a training - * job.

        - *

        Status might be one of the following secondary statuses:

        - *
        - *
        InProgress
        - *
        - *
          - *
        • - *

          - * Starting - * - Starting the training job.

          - *
        • - *
        • - *

          - * Downloading - An optional stage for algorithms that - * support File training input mode. It indicates that - * data is being downloaded to the ML storage volumes.

          - *
        • - *
        • - *

          - * Training - Training is in progress.

          - *
        • - *
        • - *

          - * Uploading - Training is complete and the model - * artifacts are being uploaded to the S3 location.

          - *
        • - *
        - *
        - *
        Completed
        - *
        - *
          - *
        • - *

          - * Completed - The training job has completed.

          - *
        • - *
        - *
        - *
        Failed
        - *
        - *
          - *
        • - *

          - * Failed - The training job has failed. The reason for - * the failure is returned in the FailureReason field of - * DescribeTrainingJobResponse.

          - *
        • - *
        - *
        - *
        Stopped
        - *
        - *
          - *
        • - *

          - * MaxRuntimeExceeded - The job stopped because it - * exceeded the maximum allowed runtime.

          - *
        • - *
        • - *

          - * Stopped - The training job has stopped.

          - *
        • - *
        - *
        - *
        Stopping
        - *
        - *
          - *
        • - *

          - * Stopping - Stopping the training job.

          - *
        • - *
        - *
        - *
        - *

        We no longer support the following secondary statuses:

        - *
          - *
        • - *

          - * LaunchingMLInstances - *

          - *
        • - *
        • - *

          - * PreparingTrainingStack - *

          - *
        • - *
        • - *

          - * DownloadingTrainingImage - *

          - *
        • - *
        + *

        The last modified time.

        */ - Status: SecondaryStatus | string | undefined; + LastModifiedTime?: Date; /** - *

        A timestamp that shows when the training job transitioned to the current secondary - * status state.

        + *

        The failure reason.

        */ - StartTime: Date | undefined; + FailureReason?: string; /** - *

        A timestamp that shows when the training job transitioned out of this secondary status - * state into another secondary status state or when the training job has ended.

        + *

        The domain's authentication mode.

        */ - EndTime?: Date; + AuthMode?: AuthMode | string; /** - *

        A detailed description of the progress within a secondary status. - *

        - *

        Amazon SageMaker provides secondary statuses and status messages that apply to each of - * them:

        - *
        - *
        Starting
        - *
        - *
          - *
        • - *

          Starting the training job.

          - *
        • - *
        • - *

          Launching - * requested ML instances.

          - *
        • - *
        • - *

          Insufficient - * capacity error from EC2 while launching instances, - * retrying!

          - *
        • - *
        • - *

          Launched - * instance was unhealthy, replacing it!

          - *
        • - *
        • - *

          Preparing the instances for training.

          - *
        • - *
        - *
        - *
        Training
        - *
        - *
          - *
        • - *

          Downloading the training image.

          - *
        • - *
        • - *

          Training - * image download completed. Training in - * progress.

          - *
        • - *
        - *
        - *
        - * - *

        Status messages are subject to change. Therefore, we recommend not including them - * in code that programmatically initiates actions. For examples, don't use status - * messages in if statements.

        - *
        - *

        To have an overview of your training job's progress, view - * TrainingJobStatus and SecondaryStatus in DescribeTrainingJob, and StatusMessage together. For - * example, at the start of a training job, you might see the following:

        - *
          - *
        • - *

          - * TrainingJobStatus - InProgress

          - *
        • + *

          Settings which are applied to all UserProfiles in this domain, if settings are not explicitly specified + * in a given UserProfile. + *

          + */ + DefaultUserSettings?: UserSettings; + + /** + *

          Specifies the VPC used for non-EFS traffic. The default value is + * PublicInternetOnly.

          + *
            *
          • - *

            - * SecondaryStatus - Training

            + *

            + * PublicInternetOnly - Non-EFS traffic is through a VPC managed by + * Amazon SageMaker, which allows direct internet access

            *
          • *
          • - *

            - * StatusMessage - Downloading the training image

            + *

            + * VpcOnly - All Studio traffic is through the specified VPC and subnets

            *
          • *
          */ - StatusMessage?: string; -} - -export namespace SecondaryStatusTransition { - export const filterSensitiveLog = (obj: SecondaryStatusTransition): any => ({ - ...obj, - }); -} + AppNetworkAccessType?: AppNetworkAccessType | string; -export interface DescribeTrainingJobResponse { /** - *

          Name of the model training job.

          + *

          This member is deprecated and replaced with KmsKeyId.

          */ - TrainingJobName: string | undefined; + HomeEfsFileSystemKmsKeyId?: string; /** - *

          The Amazon Resource Name (ARN) of the training job.

          + *

          The VPC subnets that Studio uses for communication.

          */ - TrainingJobArn: string | undefined; + SubnetIds?: string[]; /** - *

          The Amazon Resource Name (ARN) of the associated hyperparameter tuning job if the - * training job was launched by a hyperparameter tuning job.

          + *

          The domain's URL.

          */ - TuningJobArn?: string; + Url?: string; /** - *

          The Amazon Resource Name (ARN) of the Amazon SageMaker Ground Truth labeling job that created the - * transform or training job.

          + *

          The ID of the Amazon Virtual Private Cloud (VPC) that Studio uses for communication.

          */ - LabelingJobArn?: string; + VpcId?: string; /** - *

          The Amazon Resource Name (ARN) of an AutoML job.

          + *

          The AWS KMS customer managed CMK used to encrypt + * the EFS volume attached to the domain.

          */ - AutoMLJobArn?: string; + KmsKeyId?: string; +} - /** - *

          Information about the Amazon S3 location that is configured for storing model artifacts. - *

          - */ - ModelArtifacts: ModelArtifacts | undefined; +export namespace DescribeDomainResponse { + export const filterSensitiveLog = (obj: DescribeDomainResponse): any => ({ + ...obj, + }); +} +export interface DescribeEndpointInput { /** - *

          The status of the - * training - * job.

          - *

          Amazon SageMaker provides the following training job statuses:

          + *

          The name of the endpoint.

          + */ + EndpointName: string | undefined; +} + +export namespace DescribeEndpointInput { + export const filterSensitiveLog = (obj: DescribeEndpointInput): any => ({ + ...obj, + }); +} + +export enum EndpointStatus { + CREATING = "Creating", + DELETING = "Deleting", + FAILED = "Failed", + IN_SERVICE = "InService", + OUT_OF_SERVICE = "OutOfService", + ROLLING_BACK = "RollingBack", + SYSTEM_UPDATING = "SystemUpdating", + UPDATING = "Updating", +} + +/** + *

          Describes weight and capacities for a production variant associated with an + * endpoint. If you sent a request to the UpdateEndpointWeightsAndCapacities + * API and the endpoint status is Updating, you get different desired and + * current values.

          + */ +export interface ProductionVariantSummary { + /** + *

          The name of the variant.

          + */ + VariantName: string | undefined; + + /** + *

          An array of DeployedImage objects that specify the Amazon EC2 Container Registry paths of the + * inference images deployed on instances of this ProductionVariant.

          + */ + DeployedImages?: DeployedImage[]; + + /** + *

          The weight associated with the variant.

          + */ + CurrentWeight?: number; + + /** + *

          The requested weight, as specified in the + * UpdateEndpointWeightsAndCapacities request.

          + */ + DesiredWeight?: number; + + /** + *

          The number of instances associated with the variant.

          + */ + CurrentInstanceCount?: number; + + /** + *

          The number of instances requested in the + * UpdateEndpointWeightsAndCapacities request.

          + */ + DesiredInstanceCount?: number; +} + +export namespace ProductionVariantSummary { + export const filterSensitiveLog = (obj: ProductionVariantSummary): any => ({ + ...obj, + }); +} + +export interface DescribeEndpointOutput { + /** + *

          Name of the endpoint.

          + */ + EndpointName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the endpoint.

          + */ + EndpointArn: string | undefined; + + /** + *

          The name of the endpoint configuration associated with this endpoint.

          + */ + EndpointConfigName: string | undefined; + + /** + *

          An array of ProductionVariantSummary objects, one for each model + * hosted behind this endpoint.

          + */ + ProductionVariants?: ProductionVariantSummary[]; + + /** + *

          + */ + DataCaptureConfig?: DataCaptureConfigSummary; + + /** + *

          The status of the endpoint.

          *
            *
          • *

            - * InProgress - The training is in progress.

            + * OutOfService: Endpoint is not available to take incoming + * requests.

            *
          • *
          • *

            - * Completed - The training job has completed.

            + * Creating: CreateEndpoint is executing.

            *
          • *
          • *

            - * Failed - The training job has failed. To see the reason for the - * failure, see the FailureReason field in the response to a - * DescribeTrainingJobResponse call.

            + * Updating: UpdateEndpoint or UpdateEndpointWeightsAndCapacities is executing.

            *
          • *
          • *

            - * Stopping - The training job is stopping.

            + * SystemUpdating: Endpoint is undergoing maintenance and cannot be + * updated or deleted or re-scaled until it has completed. This maintenance + * operation does not change any customer-specified values such as VPC config, KMS + * encryption, model, instance type, or instance count.

            *
          • *
          • *

            - * Stopped - The training job has stopped.

            + * RollingBack: Endpoint fails to scale up or down or change its + * variant weight and is in the process of rolling back to its previous + * configuration. Once the rollback completes, endpoint returns to an + * InService status. This transitional status only applies to an + * endpoint that has autoscaling enabled and is undergoing variant weight or + * capacity changes as part of an UpdateEndpointWeightsAndCapacities call or when the UpdateEndpointWeightsAndCapacities operation is called + * explicitly.

            *
          • - *
          - *

          For - * more detailed information, see SecondaryStatus.

          - */ - TrainingJobStatus: TrainingJobStatus | string | undefined; - - /** - *

          Provides detailed information about the state of the training job. For detailed - * information on the secondary status of the training job, see StatusMessage - * under SecondaryStatusTransition.

          - *

          Amazon SageMaker provides primary statuses and secondary statuses that apply to each of - * them:

          - *
          - *
          InProgress
          - *
          - *
            - *
          • - *

            - * Starting - * - Starting the training job.

            - *
          • - *
          • - *

            - * Downloading - An optional stage for algorithms that - * support File training input mode. It indicates that - * data is being downloaded to the ML storage volumes.

            - *
          • - *
          • - *

            - * Training - Training is in progress.

            - *
          • - *
          • - *

            - * Interrupted - The job stopped because the managed - * spot training instances were interrupted.

            - *
          • - *
          • - *

            - * Uploading - Training is complete and the model - * artifacts are being uploaded to the S3 location.

            - *
          • - *
          - *
          - *
          Completed
          - *
          - *
            - *
          • - *

            - * Completed - The training job has completed.

            - *
          • - *
          - *
          - *
          Failed
          - *
          - *
            - *
          • - *

            - * Failed - The training job has failed. The reason for - * the failure is returned in the FailureReason field of - * DescribeTrainingJobResponse.

            - *
          • - *
          - *
          - *
          Stopped
          - *
          - *
            - *
          • - *

            - * MaxRuntimeExceeded - The job stopped because it - * exceeded the maximum allowed runtime.

            - *
          • - *
          • - *

            - * MaxWaitTimeExceeded - The job stopped because it - * exceeded the maximum allowed wait time.

            - *
          • - *
          • - *

            - * Stopped - The training job has stopped.

            - *
          • - *
          - *
          - *
          Stopping
          - *
          - *
            - *
          • - *

            - * Stopping - Stopping the training job.

            - *
          • - *
          - *
          - *
          - * - * - *

          Valid values for SecondaryStatus are subject to change.

          - *
          - *

          We no longer support the following secondary statuses:

          - *
            *
          • *

            - * LaunchingMLInstances - *

            + * InService: Endpoint is available to process incoming + * requests.

            *
          • *
          • *

            - * PreparingTrainingStack - *

            + * Deleting: DeleteEndpoint is executing.

            *
          • *
          • *

            - * DownloadingTrainingImage - *

            + * Failed: Endpoint could not be created, updated, or re-scaled. Use + * DescribeEndpointOutput$FailureReason for information about + * the failure. DeleteEndpoint is the only operation that can be + * performed on a failed endpoint.

            *
          • *
          */ - SecondaryStatus: SecondaryStatus | string | undefined; + EndpointStatus: EndpointStatus | string | undefined; /** - *

          If the training job failed, the reason it failed.

          + *

          If the status of the endpoint is Failed, the reason why it failed. + *

          */ FailureReason?: string; /** - *

          Algorithm-specific parameters.

          + *

          A timestamp that shows when the endpoint was created.

          */ - HyperParameters?: { [key: string]: string }; + CreationTime: Date | undefined; /** - *

          Information about the algorithm used for training, and algorithm metadata. - *

          + *

          A timestamp that shows when the endpoint was last modified.

          */ - AlgorithmSpecification: AlgorithmSpecification | undefined; + LastModifiedTime: Date | undefined; /** - *

          The AWS Identity and Access Management (IAM) role configured for the training job.

          + *

          The most recent deployment configuration for the endpoint.

          */ - RoleArn?: string; + LastDeploymentConfig?: DeploymentConfig; +} - /** - *

          An array of Channel objects that describes each data input channel. - *

          - */ - InputDataConfig?: Channel[]; - - /** - *

          The S3 path where model artifacts that you configured when creating the job are - * stored. Amazon SageMaker creates subfolders for model artifacts.

          - */ - OutputDataConfig?: OutputDataConfig; - - /** - *

          Resources, including ML compute instances and ML storage volumes, that are - * configured for model training.

          - */ - ResourceConfig: ResourceConfig | undefined; - - /** - *

          A VpcConfig object that specifies the VPC that this training job has - * access to. For more information, see Protect Training Jobs by Using an Amazon - * Virtual Private Cloud.

          - */ - VpcConfig?: VpcConfig; - - /** - *

          Specifies a limit to how long a model training job can run. It also specifies the - * maximum time to wait for a spot instance. When the job reaches the time limit, Amazon SageMaker ends - * the training job. Use this API to cap model training costs.

          - *

          To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays - * job termination for 120 seconds. Algorithms can use this 120-second window to save the - * model artifacts, so the results of training are not lost.

          - */ - StoppingCondition: StoppingCondition | undefined; - - /** - *

          A timestamp that indicates when the training job was created.

          - */ - CreationTime: Date | undefined; - - /** - *

          Indicates the time when the training job starts on training instances. You are - * billed for the time interval between this time and the value of - * TrainingEndTime. The start time in CloudWatch Logs might be later than this time. - * The difference is due to the time it takes to download the training data and to the size - * of the training container.

          - */ - TrainingStartTime?: Date; - - /** - *

          Indicates the time when the training job ends on training instances. You are billed - * for the time interval between the value of TrainingStartTime and this time. - * For successful jobs and stopped jobs, this is the time after model artifacts are - * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

          - */ - TrainingEndTime?: Date; - - /** - *

          A timestamp that indicates when the status of the training job was last - * modified.

          - */ - LastModifiedTime?: Date; - - /** - *

          A history of all of the secondary statuses that the training job has transitioned - * through.

          - */ - SecondaryStatusTransitions?: SecondaryStatusTransition[]; - - /** - *

          A collection of MetricData objects that specify the names, values, and - * dates and times that the training algorithm emitted to Amazon CloudWatch.

          - */ - FinalMetricDataList?: MetricData[]; - - /** - *

          If you want to allow inbound or outbound network calls, except for calls between peers - * within a training cluster for distributed training, choose True. If you - * enable network isolation for training jobs that are configured to use a VPC, Amazon SageMaker - * downloads and uploads customer data and model artifacts through the specified VPC, but - * the training container does not have network access.

          - */ - EnableNetworkIsolation?: boolean; - - /** - *

          To encrypt all communications between ML compute instances in distributed training, - * choose True. Encryption provides greater security for distributed training, - * but training might take longer. How long it takes depends on the amount of communication - * between compute instances, especially if you use a deep learning algorithms in - * distributed training.

          - */ - EnableInterContainerTrafficEncryption?: boolean; - - /** - *

          A Boolean indicating whether managed spot training is enabled (True) or - * not (False).

          - */ - EnableManagedSpotTraining?: boolean; +export namespace DescribeEndpointOutput { + export const filterSensitiveLog = (obj: DescribeEndpointOutput): any => ({ + ...obj, + }); +} +export interface DescribeEndpointConfigInput { /** - *

          Contains information about the output location for managed spot training checkpoint - * data.

          + *

          The name of the endpoint configuration.

          */ - CheckpointConfig?: CheckpointConfig; + EndpointConfigName: string | undefined; +} - /** - *

          The training time in seconds.

          - */ - TrainingTimeInSeconds?: number; +export namespace DescribeEndpointConfigInput { + export const filterSensitiveLog = (obj: DescribeEndpointConfigInput): any => ({ + ...obj, + }); +} +export interface DescribeEndpointConfigOutput { /** - *

          The billable time in seconds.

          - *

          You can calculate the savings from using managed spot training using the formula - * (1 - BillableTimeInSeconds / TrainingTimeInSeconds) * 100. For example, - * if BillableTimeInSeconds is 100 and TrainingTimeInSeconds is - * 500, the savings is 80%.

          + *

          Name of the Amazon SageMaker endpoint configuration.

          */ - BillableTimeInSeconds?: number; + EndpointConfigName: string | undefined; /** - *

          Configuration information for the debug hook parameters, collection configuration, and - * storage paths.

          + *

          The Amazon Resource Name (ARN) of the endpoint configuration.

          */ - DebugHookConfig?: DebugHookConfig; + EndpointConfigArn: string | undefined; /** - *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

          - * + *

          An array of ProductionVariant objects, one for each model that you + * want to host at this endpoint.

          */ - ExperimentConfig?: ExperimentConfig; + ProductionVariants: ProductionVariant[] | undefined; /** - *

          Configuration information for debugging rules.

          + *

          */ - DebugRuleConfigurations?: DebugRuleConfiguration[]; + DataCaptureConfig?: DataCaptureConfig; /** - *

          Configuration of storage locations for TensorBoard output.

          + *

          AWS KMS key ID Amazon SageMaker uses to encrypt data when storing it on the ML storage + * volume attached to the instance.

          */ - TensorBoardOutputConfig?: TensorBoardOutputConfig; + KmsKeyId?: string; /** - *

          Status about the debug rule evaluation.

          + *

          A timestamp that shows when the endpoint configuration was created.

          */ - DebugRuleEvaluationStatuses?: DebugRuleEvaluationStatus[]; + CreationTime: Date | undefined; } -export namespace DescribeTrainingJobResponse { - export const filterSensitiveLog = (obj: DescribeTrainingJobResponse): any => ({ +export namespace DescribeEndpointConfigOutput { + export const filterSensitiveLog = (obj: DescribeEndpointConfigOutput): any => ({ ...obj, }); } -export interface DescribeTransformJobRequest { +export interface DescribeExperimentRequest { /** - *

          The name of the transform job that you want to view details of.

          + *

          The name of the experiment to describe.

          */ - TransformJobName: string | undefined; + ExperimentName: string | undefined; } -export namespace DescribeTransformJobRequest { - export const filterSensitiveLog = (obj: DescribeTransformJobRequest): any => ({ +export namespace DescribeExperimentRequest { + export const filterSensitiveLog = (obj: DescribeExperimentRequest): any => ({ ...obj, }); } -export enum TransformJobStatus { - COMPLETED = "Completed", - FAILED = "Failed", - IN_PROGRESS = "InProgress", - STOPPED = "Stopped", - STOPPING = "Stopping", -} - -export interface DescribeTransformJobResponse { - /** - *

          The name of the transform job.

          - */ - TransformJobName: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the transform job.

          - */ - TransformJobArn: string | undefined; - - /** - *

          The - * status of the transform job. If the transform job failed, the reason - * is returned in the FailureReason field.

          - */ - TransformJobStatus: TransformJobStatus | string | undefined; - +/** + *

          The source of the experiment.

          + */ +export interface ExperimentSource { /** - *

          If the transform job failed, FailureReason describes - * why - * it failed. A transform job creates a log file, which includes error - * messages, and stores it - * as - * an Amazon S3 object. For more information, see Log Amazon SageMaker Events with - * Amazon CloudWatch.

          + *

          The Amazon Resource Name (ARN) of the source.

          */ - FailureReason?: string; + SourceArn: string | undefined; /** - *

          The name of the model used in the transform job.

          + *

          The source type.

          */ - ModelName: string | undefined; + SourceType?: string; +} - /** - *

          The - * maximum number - * of - * parallel requests on each instance node - * that can be launched in a transform job. The default value is 1.

          - */ - MaxConcurrentTransforms?: number; +export namespace ExperimentSource { + export const filterSensitiveLog = (obj: ExperimentSource): any => ({ + ...obj, + }); +} +export interface DescribeExperimentResponse { /** - *

          The timeout and maximum number of retries for processing a transform job - * invocation.

          + *

          The name of the experiment.

          */ - ModelClientConfig?: ModelClientConfig; + ExperimentName?: string; /** - *

          The - * maximum - * payload size, in MB, used in the - * transform job.

          + *

          The Amazon Resource Name (ARN) of the experiment.

          */ - MaxPayloadInMB?: number; + ExperimentArn?: string; /** - *

          Specifies the number of records to include in a mini-batch for an HTTP inference - * request. - * A record - * is a single unit of input data that inference - * can be made on. For example, a single line in a CSV file is a record.

          - *

          To enable the batch strategy, you must set SplitType - * to - * Line, RecordIO, or - * TFRecord.

          - */ - BatchStrategy?: BatchStrategy | string; - - /** - *

          The - * environment variables to set in the Docker container. We support up to 16 key and values - * entries in the map.

          - */ - Environment?: { [key: string]: string }; - - /** - *

          Describes the dataset to be transformed and the Amazon S3 location where it is - * stored.

          - */ - TransformInput: TransformInput | undefined; - - /** - *

          Identifies the Amazon S3 location where you want Amazon SageMaker to save the results from the - * transform job.

          - */ - TransformOutput?: TransformOutput; - - /** - *

          Describes - * the resources, including ML instance types and ML instance count, to - * use for the transform job.

          - */ - TransformResources: TransformResources | undefined; - - /** - *

          A timestamp that shows when the transform Job was created.

          - */ - CreationTime: Date | undefined; - - /** - *

          Indicates when the transform job starts - * on - * ML instances. You are billed for the time interval between this time - * and the value of TransformEndTime.

          - */ - TransformStartTime?: Date; - - /** - *

          Indicates when the transform job has been - * - * completed, or has stopped or failed. You are billed for the time - * interval between this time and the value of TransformStartTime.

          - */ - TransformEndTime?: Date; - - /** - *

          The Amazon Resource Name (ARN) of the Amazon SageMaker Ground Truth labeling job that created the - * transform or training job.

          - */ - LabelingJobArn?: string; - - /** - *

          The Amazon Resource Name (ARN) of the AutoML transform job.

          - */ - AutoMLJobArn?: string; - - /** - *

          The data structure used to specify the data to be used for inference in a batch - * transform job and to associate the data that is relevant to the prediction results in - * the output. The input filter provided allows you to exclude input data that is not - * needed for inference in a batch transform job. The output filter provided allows you to - * include input data relevant to interpreting the predictions in the output from the job. - * For more information, see Associate Prediction - * Results with their Corresponding Input Records.

          - */ - DataProcessing?: DataProcessing; - - /** - *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

          - * - */ - ExperimentConfig?: ExperimentConfig; -} - -export namespace DescribeTransformJobResponse { - export const filterSensitiveLog = (obj: DescribeTransformJobResponse): any => ({ - ...obj, - }); -} - -export interface DescribeTrialRequest { - /** - *

          The name of the trial to describe.

          - */ - TrialName: string | undefined; -} - -export namespace DescribeTrialRequest { - export const filterSensitiveLog = (obj: DescribeTrialRequest): any => ({ - ...obj, - }); -} - -/** - *

          The source of the trial.

          - */ -export interface TrialSource { - /** - *

          The Amazon Resource Name (ARN) of the source.

          - */ - SourceArn: string | undefined; - - /** - *

          The source job type.

          - */ - SourceType?: string; -} - -export namespace TrialSource { - export const filterSensitiveLog = (obj: TrialSource): any => ({ - ...obj, - }); -} - -export interface DescribeTrialResponse { - /** - *

          The name of the trial.

          - */ - TrialName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the trial.

          - */ - TrialArn?: string; - - /** - *

          The name of the trial as displayed. If DisplayName isn't specified, - * TrialName is displayed.

          - */ - DisplayName?: string; - - /** - *

          The name of the experiment the trial is part of.

          - */ - ExperimentName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the source and, optionally, the job type.

          - */ - Source?: TrialSource; - - /** - *

          When the trial was created.

          - */ - CreationTime?: Date; - - /** - *

          Who created the trial.

          - */ - CreatedBy?: UserContext; - - /** - *

          When the trial was last modified.

          - */ - LastModifiedTime?: Date; - - /** - *

          Who last modified the trial.

          - */ - LastModifiedBy?: UserContext; -} - -export namespace DescribeTrialResponse { - export const filterSensitiveLog = (obj: DescribeTrialResponse): any => ({ - ...obj, - }); -} - -export interface DescribeTrialComponentRequest { - /** - *

          The name of the trial component to describe.

          - */ - TrialComponentName: string | undefined; -} - -export namespace DescribeTrialComponentRequest { - export const filterSensitiveLog = (obj: DescribeTrialComponentRequest): any => ({ - ...obj, - }); -} - -/** - *

          A summary of the metrics of a trial component.

          - */ -export interface TrialComponentMetricSummary { - /** - *

          The name of the metric.

          - */ - MetricName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the source.

          - */ - SourceArn?: string; - - /** - *

          When the metric was last updated.

          - */ - TimeStamp?: Date; - - /** - *

          The maximum value of the metric.

          - */ - Max?: number; - - /** - *

          The minimum value of the metric.

          - */ - Min?: number; - - /** - *

          The most recent value of the metric.

          - */ - Last?: number; - - /** - *

          The number of samples used to generate the metric.

          - */ - Count?: number; - - /** - *

          The average value of the metric.

          - */ - Avg?: number; - - /** - *

          The standard deviation of the metric.

          - */ - StdDev?: number; -} - -export namespace TrialComponentMetricSummary { - export const filterSensitiveLog = (obj: TrialComponentMetricSummary): any => ({ - ...obj, - }); -} - -/** - *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          - */ -export interface TrialComponentSource { - /** - *

          The source ARN.

          - */ - SourceArn: string | undefined; - - /** - *

          The source job type.

          - */ - SourceType?: string; -} - -export namespace TrialComponentSource { - export const filterSensitiveLog = (obj: TrialComponentSource): any => ({ - ...obj, - }); -} - -export interface DescribeTrialComponentResponse { - /** - *

          The name of the trial component.

          - */ - TrialComponentName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the trial component.

          - */ - TrialComponentArn?: string; - - /** - *

          The name of the component as displayed. If DisplayName isn't specified, - * TrialComponentName is displayed.

          - */ - DisplayName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the source and, optionally, the job type.

          - */ - Source?: TrialComponentSource; - - /** - *

          The status of the component. States include:

          - *
            - *
          • - *

            InProgress

            - *
          • - *
          • - *

            Completed

            - *
          • - *
          • - *

            Failed

            - *
          • - *
          - */ - Status?: TrialComponentStatus; - - /** - *

          When the component started.

          - */ - StartTime?: Date; - - /** - *

          When the component ended.

          - */ - EndTime?: Date; - - /** - *

          When the component was created.

          - */ - CreationTime?: Date; - - /** - *

          Who created the component.

          - */ - CreatedBy?: UserContext; - - /** - *

          When the component was last modified.

          - */ - LastModifiedTime?: Date; - - /** - *

          Who last modified the component.

          - */ - LastModifiedBy?: UserContext; - - /** - *

          The hyperparameters of the component.

          - */ - Parameters?: { [key: string]: TrialComponentParameterValue }; - - /** - *

          The input artifacts of the component.

          - */ - InputArtifacts?: { [key: string]: TrialComponentArtifact }; - - /** - *

          The output artifacts of the component.

          - */ - OutputArtifacts?: { [key: string]: TrialComponentArtifact }; - - /** - *

          The metrics for the component.

          - */ - Metrics?: TrialComponentMetricSummary[]; -} - -export namespace DescribeTrialComponentResponse { - export const filterSensitiveLog = (obj: DescribeTrialComponentResponse): any => ({ - ...obj, - }); -} - -export interface DescribeUserProfileRequest { - /** - *

          The domain ID.

          - */ - DomainId: string | undefined; - - /** - *

          The user profile name.

          - */ - UserProfileName: string | undefined; -} - -export namespace DescribeUserProfileRequest { - export const filterSensitiveLog = (obj: DescribeUserProfileRequest): any => ({ - ...obj, - }); -} - -export enum UserProfileStatus { - Delete_Failed = "Delete_Failed", - Deleting = "Deleting", - Failed = "Failed", - InService = "InService", - Pending = "Pending", - Update_Failed = "Update_Failed", - Updating = "Updating", -} - -export interface DescribeUserProfileResponse { - /** - *

          The ID of the domain that contains the profile.

          - */ - DomainId?: string; - - /** - *

          The user profile Amazon Resource Name (ARN).

          - */ - UserProfileArn?: string; - - /** - *

          The user profile name.

          - */ - UserProfileName?: string; - - /** - *

          The ID of the user's profile in the Amazon Elastic File System (EFS) volume.

          - */ - HomeEfsFileSystemUid?: string; - - /** - *

          The status.

          - */ - Status?: UserProfileStatus | string; - - /** - *

          The last modified time.

          - */ - LastModifiedTime?: Date; - - /** - *

          The creation time.

          - */ - CreationTime?: Date; - - /** - *

          The failure reason.

          - */ - FailureReason?: string; - - /** - *

          The SSO user identifier.

          - */ - SingleSignOnUserIdentifier?: string; - - /** - *

          The SSO user value.

          - */ - SingleSignOnUserValue?: string; - - /** - *

          A collection of settings.

          - */ - UserSettings?: UserSettings; -} - -export namespace DescribeUserProfileResponse { - export const filterSensitiveLog = (obj: DescribeUserProfileResponse): any => ({ - ...obj, - }); -} - -export interface DescribeWorkforceRequest { - /** - *

          The name of the private workforce whose access you want to restrict. - * WorkforceName is automatically set to default when a - * workforce is created and cannot be modified.

          - */ - WorkforceName: string | undefined; -} - -export namespace DescribeWorkforceRequest { - export const filterSensitiveLog = (obj: DescribeWorkforceRequest): any => ({ - ...obj, - }); -} - -/** - *

          Your OIDC IdP workforce configuration.

          - */ -export interface OidcConfigForResponse { - /** - *

          The OIDC IdP client ID used to configure your private workforce.

          - */ - ClientId?: string; - - /** - *

          The OIDC IdP issuer used to configure your private workforce.

          - */ - Issuer?: string; - - /** - *

          The OIDC IdP authorization endpoint used to configure your private workforce.

          - */ - AuthorizationEndpoint?: string; - - /** - *

          The OIDC IdP token endpoint used to configure your private workforce.

          - */ - TokenEndpoint?: string; - - /** - *

          The OIDC IdP user information endpoint used to configure your private workforce.

          - */ - UserInfoEndpoint?: string; - - /** - *

          The OIDC IdP logout endpoint used to configure your private workforce.

          - */ - LogoutEndpoint?: string; - - /** - *

          The OIDC IdP JSON Web Key Set (Jwks) URI used to configure your private workforce.

          - */ - JwksUri?: string; -} - -export namespace OidcConfigForResponse { - export const filterSensitiveLog = (obj: OidcConfigForResponse): any => ({ - ...obj, - }); -} - -/** - *

          A single private workforce, which is automatically created when you create your first - * private work team. You can create one private work force in each AWS Region. By default, - * any workforce-related API operation used in a specific region will apply to the - * workforce created in that region. To learn how to create a private workforce, see Create a Private Workforce.

          - */ -export interface Workforce { - /** - *

          The name of the private workforce.

          - */ - WorkforceName: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the private workforce.

          - */ - WorkforceArn: string | undefined; - - /** - *

          The most recent date that was used to - * successfully add one or more IP address ranges (CIDRs) to a private workforce's - * allow list.

          - */ - LastUpdatedDate?: Date; - - /** - *

          A list of one to ten IP address ranges (CIDRs) to be added to the - * workforce allow list. By default, a workforce isn't restricted to specific IP addresses.

          - */ - SourceIpConfig?: SourceIpConfig; - - /** - *

          The subdomain for your OIDC Identity Provider.

          - */ - SubDomain?: string; - - /** - *

          The configuration of an Amazon Cognito workforce. - * A single Cognito workforce is created using and corresponds to a single - * - * Amazon Cognito user pool.

          - */ - CognitoConfig?: CognitoConfig; - - /** - *

          The configuration of an OIDC Identity Provider (IdP) private workforce.

          - */ - OidcConfig?: OidcConfigForResponse; - - /** - *

          The date that the workforce is created.

          - */ - CreateDate?: Date; -} - -export namespace Workforce { - export const filterSensitiveLog = (obj: Workforce): any => ({ - ...obj, - }); -} - -export interface DescribeWorkforceResponse { - /** - *

          A single private workforce, which is automatically created when you create your first - * private work team. You can create one private work force in each AWS Region. By default, - * any workforce-related API operation used in a specific region will apply to the - * workforce created in that region. To learn how to create a private workforce, see Create a Private Workforce.

          - */ - Workforce: Workforce | undefined; -} - -export namespace DescribeWorkforceResponse { - export const filterSensitiveLog = (obj: DescribeWorkforceResponse): any => ({ - ...obj, - }); -} - -export interface DescribeWorkteamRequest { - /** - *

          The name of the work team to return a description of.

          - */ - WorkteamName: string | undefined; -} - -export namespace DescribeWorkteamRequest { - export const filterSensitiveLog = (obj: DescribeWorkteamRequest): any => ({ - ...obj, - }); -} - -/** - *

          Provides details about a labeling work team.

          - */ -export interface Workteam { - /** - *

          The name of the work team.

          - */ - WorkteamName: string | undefined; - - /** - *

          A list of MemberDefinition objects that contains objects that identify - * the workers that make up the work team.

          - *

          Workforces can be created using Amazon Cognito or your own OIDC Identity Provider (IdP). - * For private workforces created using Amazon Cognito use - * CognitoMemberDefinition. For workforces created using your own OIDC identity - * provider (IdP) use OidcMemberDefinition.

          - */ - MemberDefinitions: MemberDefinition[] | undefined; - - /** - *

          The Amazon Resource Name (ARN) that identifies the work team.

          - */ - WorkteamArn: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the workforce.

          - */ - WorkforceArn?: string; - - /** - *

          The Amazon Marketplace identifier for a vendor's work team.

          - */ - ProductListingIds?: string[]; - - /** - *

          A description of the work team.

          - */ - Description: string | undefined; - - /** - *

          The URI of the labeling job's user interface. Workers open this URI to start labeling - * your data objects.

          - */ - SubDomain?: string; - - /** - *

          The date and time that the work team was created (timestamp).

          - */ - CreateDate?: Date; - - /** - *

          The date and time that the work team was last updated (timestamp).

          - */ - LastUpdatedDate?: Date; - - /** - *

          Configures SNS notifications of available or expiring work items for work - * teams.

          - */ - NotificationConfiguration?: NotificationConfiguration; -} - -export namespace Workteam { - export const filterSensitiveLog = (obj: Workteam): any => ({ - ...obj, - }); -} - -export interface DescribeWorkteamResponse { - /** - *

          A Workteam instance that contains information about the work team. - *

          - */ - Workteam: Workteam | undefined; -} - -export namespace DescribeWorkteamResponse { - export const filterSensitiveLog = (obj: DescribeWorkteamResponse): any => ({ - ...obj, - }); -} - -/** - *

          Specifies weight and capacity values for a production variant.

          - */ -export interface DesiredWeightAndCapacity { - /** - *

          The name of the - * variant - * to update.

          - */ - VariantName: string | undefined; - - /** - *

          The variant's weight.

          - */ - DesiredWeight?: number; - - /** - *

          The variant's capacity.

          - */ - DesiredInstanceCount?: number; -} - -export namespace DesiredWeightAndCapacity { - export const filterSensitiveLog = (obj: DesiredWeightAndCapacity): any => ({ - ...obj, - }); -} - -export interface DisassociateTrialComponentRequest { - /** - *

          The name of the component to disassociate from the trial.

          - */ - TrialComponentName: string | undefined; - - /** - *

          The name of the trial to disassociate from.

          - */ - TrialName: string | undefined; -} - -export namespace DisassociateTrialComponentRequest { - export const filterSensitiveLog = (obj: DisassociateTrialComponentRequest): any => ({ - ...obj, - }); -} - -export interface DisassociateTrialComponentResponse { - /** - *

          The ARN of the trial component.

          - */ - TrialComponentArn?: string; - - /** - *

          The Amazon Resource Name (ARN) of the trial.

          - */ - TrialArn?: string; -} - -export namespace DisassociateTrialComponentResponse { - export const filterSensitiveLog = (obj: DisassociateTrialComponentResponse): any => ({ - ...obj, - }); -} - -/** - *

          The domain's details.

          - */ -export interface DomainDetails { - /** - *

          The domain's Amazon Resource Name (ARN).

          - */ - DomainArn?: string; - - /** - *

          The domain ID.

          - */ - DomainId?: string; - - /** - *

          The domain name.

          - */ - DomainName?: string; - - /** - *

          The status.

          - */ - Status?: DomainStatus | string; - - /** - *

          The creation time.

          - */ - CreationTime?: Date; - - /** - *

          The last modified time.

          - */ - LastModifiedTime?: Date; - - /** - *

          The domain's URL.

          - */ - Url?: string; -} - -export namespace DomainDetails { - export const filterSensitiveLog = (obj: DomainDetails): any => ({ - ...obj, - }); -} - -export enum EndpointConfigSortKey { - CreationTime = "CreationTime", - Name = "Name", -} - -/** - *

          Provides summary information for an endpoint configuration.

          - */ -export interface EndpointConfigSummary { - /** - *

          The name of the endpoint configuration.

          - */ - EndpointConfigName: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the endpoint configuration.

          - */ - EndpointConfigArn: string | undefined; - - /** - *

          A timestamp that shows when the endpoint configuration was created.

          - */ - CreationTime: Date | undefined; -} - -export namespace EndpointConfigSummary { - export const filterSensitiveLog = (obj: EndpointConfigSummary): any => ({ - ...obj, - }); -} - -export enum EndpointSortKey { - CreationTime = "CreationTime", - Name = "Name", - Status = "Status", -} - -/** - *

          Provides summary information for an endpoint.

          - */ -export interface EndpointSummary { - /** - *

          The name of the endpoint.

          - */ - EndpointName: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the endpoint.

          - */ - EndpointArn: string | undefined; - - /** - *

          A timestamp that shows when the endpoint was created.

          - */ - CreationTime: Date | undefined; - - /** - *

          A timestamp that shows when the endpoint was last modified.

          - */ - LastModifiedTime: Date | undefined; - - /** - *

          The status of the endpoint.

          - *
            - *
          • - *

            - * OutOfService: Endpoint is not available to take incoming - * requests.

            - *
          • - *
          • - *

            - * Creating: CreateEndpoint is executing.

            - *
          • - *
          • - *

            - * Updating: UpdateEndpoint or UpdateEndpointWeightsAndCapacities is executing.

            - *
          • - *
          • - *

            - * SystemUpdating: Endpoint is undergoing maintenance and cannot be - * updated or deleted or re-scaled until it has completed. This maintenance - * operation does not change any customer-specified values such as VPC config, KMS - * encryption, model, instance type, or instance count.

            - *
          • - *
          • - *

            - * RollingBack: Endpoint fails to scale up or down or change its - * variant weight and is in the process of rolling back to its previous - * configuration. Once the rollback completes, endpoint returns to an - * InService status. This transitional status only applies to an - * endpoint that has autoscaling enabled and is undergoing variant weight or - * capacity changes as part of an UpdateEndpointWeightsAndCapacities call or when the UpdateEndpointWeightsAndCapacities operation is called - * explicitly.

            - *
          • - *
          • - *

            - * InService: Endpoint is available to process incoming - * requests.

            - *
          • - *
          • - *

            - * Deleting: DeleteEndpoint is executing.

            - *
          • - *
          • - *

            - * Failed: Endpoint could not be created, updated, or re-scaled. Use - * DescribeEndpointOutput$FailureReason for information about - * the failure. DeleteEndpoint is the only operation that can be - * performed on a failed endpoint.

            - *
          • - *
          - *

          To get a list of endpoints with a specified status, use the ListEndpointsInput$StatusEquals filter.

          - */ - EndpointStatus: EndpointStatus | string | undefined; -} - -export namespace EndpointSummary { - export const filterSensitiveLog = (obj: EndpointSummary): any => ({ - ...obj, - }); -} - -/** - *

          The properties of an experiment as returned by the Search API.

          - */ -export interface Experiment { - /** - *

          The name of the experiment.

          - */ - ExperimentName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the experiment.

          - */ - ExperimentArn?: string; - - /** - *

          The name of the experiment as displayed. If DisplayName isn't specified, - * ExperimentName is displayed.

          - */ - DisplayName?: string; - - /** - *

          The source of the experiment.

          - */ - Source?: ExperimentSource; - - /** - *

          The description of the experiment.

          - */ - Description?: string; - - /** - *

          When the experiment was created.

          - */ - CreationTime?: Date; - - /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          - */ - CreatedBy?: UserContext; - - /** - *

          When the experiment was last modified.

          - */ - LastModifiedTime?: Date; - - /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          - */ - LastModifiedBy?: UserContext; - - /** - *

          The list of tags that are associated with the experiment. You can use Search API to search on the tags.

          - */ - Tags?: Tag[]; -} - -export namespace Experiment { - export const filterSensitiveLog = (obj: Experiment): any => ({ - ...obj, - }); -} - -/** - *

          A summary of the properties of an experiment. To get the complete set of properties, call - * the DescribeExperiment API and provide the - * ExperimentName.

          - */ -export interface ExperimentSummary { - /** - *

          The Amazon Resource Name (ARN) of the experiment.

          - */ - ExperimentArn?: string; - - /** - *

          The name of the experiment.

          - */ - ExperimentName?: string; - - /** - *

          The name of the experiment as displayed. If DisplayName isn't specified, - * ExperimentName is displayed.

          - */ - DisplayName?: string; - - /** - *

          The source of the experiment.

          - */ - ExperimentSource?: ExperimentSource; - - /** - *

          When the experiment was created.

          - */ - CreationTime?: Date; - - /** - *

          When the experiment was last modified.

          - */ - LastModifiedTime?: Date; -} - -export namespace ExperimentSummary { - export const filterSensitiveLog = (obj: ExperimentSummary): any => ({ - ...obj, - }); -} - -export enum Operator { - CONTAINS = "Contains", - EQUALS = "Equals", - EXISTS = "Exists", - GREATER_THAN = "GreaterThan", - GREATER_THAN_OR_EQUAL_TO = "GreaterThanOrEqualTo", - IN = "In", - LESS_THAN = "LessThan", - LESS_THAN_OR_EQUAL_TO = "LessThanOrEqualTo", - NOT_EQUALS = "NotEquals", - NOT_EXISTS = "NotExists", -} - -/** - *

          A conditional statement for a search expression that includes a resource property, a - * Boolean operator, and a value. Resources that match the statement are returned in the - * results from the Search API.

          - * - *

          If you specify a Value, but not an Operator, Amazon SageMaker uses the - * equals operator.

          - *

          In search, there are several property types:

          - *
          - *
          Metrics
          - *
          - *

          To define a metric filter, enter a value using the form - * "Metrics.", where is - * a metric name. For example, the following filter searches for training jobs - * with an "accuracy" metric greater than - * "0.9":

          - *

          - * { - *

          - *

          - * "Name": "Metrics.accuracy", - *

          - *

          - * "Operator": "GreaterThan", - *

          - *

          - * "Value": "0.9" - *

          - *

          - * } - *

          - *
          - *
          HyperParameters
          - *
          - *

          To define a hyperparameter filter, enter a value with the form - * "HyperParameters.". Decimal hyperparameter - * values are treated as a decimal in a comparison if the specified - * Value is also a decimal value. If the specified - * Value is an integer, the decimal hyperparameter values are - * treated as integers. For example, the following filter is satisfied by - * training jobs with a "learning_rate" hyperparameter that is - * less than "0.5":

          - *

          - * { - *

          - *

          - * "Name": "HyperParameters.learning_rate", - *

          - *

          - * "Operator": "LessThan", - *

          - *

          - * "Value": "0.5" - *

          - *

          - * } - *

          - *
          - *
          Tags
          - *
          - *

          To define a tag filter, enter a value with the form - * Tags..

          - *
          - *
          - */ -export interface Filter { - /** - *

          A resource property name. For example, TrainingJobName. For - * valid property names, see SearchRecord. - * You must specify a valid property for the resource.

          - */ - Name: string | undefined; - - /** - *

          A Boolean binary operator that is used to evaluate the filter. The operator field - * contains one of the following values:

          - *
          - *
          Equals
          - *
          - *

          The value of Name equals Value.

          - *
          - *
          NotEquals
          - *
          - *

          The value of Name doesn't equal Value.

          - *
          - *
          Exists
          - *
          - *

          The Name property exists.

          - *
          - *
          NotExists
          - *
          - *

          The Name property does not exist.

          - *
          - *
          GreaterThan
          - *
          - *

          The value of Name is greater than Value. - * Not supported for text properties.

          - *
          - *
          GreaterThanOrEqualTo
          - *
          - *

          The value of Name is greater than or equal to Value. - * Not supported for text properties.

          - *
          - *
          LessThan
          - *
          - *

          The value of Name is less than Value. - * Not supported for text properties.

          - *
          - *
          LessThanOrEqualTo
          - *
          - *

          The value of Name is less than or equal to Value. - * Not supported for text properties.

          - *
          - *
          In
          - *
          - *

          The value of Name is one of the comma delimited strings in - * Value. Only supported for text properties.

          - *
          - *
          Contains
          - *
          - *

          The value of Name contains the string Value. - * Only supported for text properties.

          - *

          A SearchExpression can include the Contains operator - * multiple times when the value of Name is one of the following:

          - *
            - *
          • - *

            - * Experiment.DisplayName - *

            - *
          • - *
          • - *

            - * Experiment.ExperimentName - *

            - *
          • - *
          • - *

            - * Experiment.Tags - *

            - *
          • - *
          • - *

            - * Trial.DisplayName - *

            - *
          • - *
          • - *

            - * Trial.TrialName - *

            - *
          • - *
          • - *

            - * Trial.Tags - *

            - *
          • - *
          • - *

            - * TrialComponent.DisplayName - *

            - *
          • - *
          • - *

            - * TrialComponent.TrialComponentName - *

            - *
          • - *
          • - *

            - * TrialComponent.Tags - *

            - *
          • - *
          • - *

            - * TrialComponent.InputArtifacts - *

            - *
          • - *
          • - *

            - * TrialComponent.OutputArtifacts - *

            - *
          • - *
          - *

          A SearchExpression can include only one Contains operator - * for all other values of Name. In these cases, if you include multiple - * Contains operators in the SearchExpression, the result is - * the following error message: "'CONTAINS' operator usage limit of 1 - * exceeded."

          - *
          - *
          - */ - Operator?: Operator | string; - - /** - *

          A value used with Name and Operator to determine which - * resources satisfy the filter's condition. For numerical properties, Value - * must be an integer or floating-point decimal. For timestamp properties, - * Value must be an ISO 8601 date-time string of the following format: - * YYYY-mm-dd'T'HH:MM:SS.

          - */ - Value?: string; -} - -export namespace Filter { - export const filterSensitiveLog = (obj: Filter): any => ({ - ...obj, - }); -} - -/** - *

          Contains summary information about the flow definition.

          - */ -export interface FlowDefinitionSummary { - /** - *

          The name of the flow definition.

          + *

          The name of the experiment as displayed. If DisplayName isn't specified, + * ExperimentName is displayed.

          */ - FlowDefinitionName: string | undefined; + DisplayName?: string; /** - *

          The Amazon Resource Name (ARN) of the flow definition.

          + *

          The ARN of the source and, optionally, the type.

          */ - FlowDefinitionArn: string | undefined; + Source?: ExperimentSource; /** - *

          The status of the flow definition. Valid values:

          + *

          The description of the experiment.

          */ - FlowDefinitionStatus: FlowDefinitionStatus | string | undefined; + Description?: string; /** - *

          The timestamp when SageMaker created the flow definition.

          + *

          When the experiment was created.

          */ - CreationTime: Date | undefined; + CreationTime?: Date; /** - *

          The reason why the flow definition creation failed. A failure reason is returned only when the flow definition status is Failed.

          + *

          Who created the experiment.

          */ - FailureReason?: string; -} - -export namespace FlowDefinitionSummary { - export const filterSensitiveLog = (obj: FlowDefinitionSummary): any => ({ - ...obj, - }); -} - -export enum ResourceType { - EXPERIMENT = "Experiment", - EXPERIMENT_TRIAL = "ExperimentTrial", - EXPERIMENT_TRIAL_COMPONENT = "ExperimentTrialComponent", - TRAINING_JOB = "TrainingJob", -} + CreatedBy?: UserContext; -/** - *

          Part of the SuggestionQuery type. Specifies a hint for retrieving property - * names that begin with the specified text.

          - */ -export interface PropertyNameQuery { /** - *

          Text that begins a property's name.

          + *

          When the experiment was last modified.

          */ - PropertyNameHint: string | undefined; -} - -export namespace PropertyNameQuery { - export const filterSensitiveLog = (obj: PropertyNameQuery): any => ({ - ...obj, - }); -} + LastModifiedTime?: Date; -/** - *

          Specified in the GetSearchSuggestions request. - * Limits the property names that are included in the response.

          - */ -export interface SuggestionQuery { /** - *

          Defines a property name hint. Only property - * names that begin with the specified hint are included in the response.

          + *

          Who last modified the experiment.

          */ - PropertyNameQuery?: PropertyNameQuery; + LastModifiedBy?: UserContext; } -export namespace SuggestionQuery { - export const filterSensitiveLog = (obj: SuggestionQuery): any => ({ +export namespace DescribeExperimentResponse { + export const filterSensitiveLog = (obj: DescribeExperimentResponse): any => ({ ...obj, }); } -export interface GetSearchSuggestionsRequest { +export interface DescribeFeatureGroupRequest { /** - *

          The name of the Amazon SageMaker resource to search for.

          + *

          The name of the FeatureGroup you want described.

          */ - Resource: ResourceType | string | undefined; + FeatureGroupName: string | undefined; /** - *

          Limits the property names that are included in the response.

          + *

          A token to resume pagination of the list of Features + * (FeatureDefinitions). 2,500 Features are returned by + * default.

          */ - SuggestionQuery?: SuggestionQuery; + NextToken?: string; } -export namespace GetSearchSuggestionsRequest { - export const filterSensitiveLog = (obj: GetSearchSuggestionsRequest): any => ({ +export namespace DescribeFeatureGroupRequest { + export const filterSensitiveLog = (obj: DescribeFeatureGroupRequest): any => ({ ...obj, }); } -/** - *

          A property name returned from a GetSearchSuggestions call that specifies - * a value in the PropertyNameQuery field.

          - */ -export interface PropertyNameSuggestion { - /** - *

          A suggested property name based on what you entered in the search textbox in the Amazon SageMaker - * console.

          - */ - PropertyName?: string; +export enum FeatureGroupStatus { + CREATED = "Created", + CREATE_FAILED = "CreateFailed", + CREATING = "Creating", + DELETE_FAILED = "DeleteFailed", + DELETING = "Deleting", } -export namespace PropertyNameSuggestion { - export const filterSensitiveLog = (obj: PropertyNameSuggestion): any => ({ - ...obj, - }); +export enum OfflineStoreStatusValue { + ACTIVE = "Active", + BLOCKED = "Blocked", + DISABLED = "Disabled", } -export interface GetSearchSuggestionsResponse { +/** + *

          The status of OfflineStore.

          + */ +export interface OfflineStoreStatus { /** - *

          A list of property names for a Resource that match a - * SuggestionQuery.

          + *

          An OfflineStore status.

          */ - PropertyNameSuggestions?: PropertyNameSuggestion[]; -} - -export namespace GetSearchSuggestionsResponse { - export const filterSensitiveLog = (obj: GetSearchSuggestionsResponse): any => ({ - ...obj, - }); -} + Status: OfflineStoreStatusValue | string | undefined; -/** - *

          Specifies configuration details for a Git repository when the repository is - * updated.

          - */ -export interface GitConfigForUpdate { /** - *

          The Amazon Resource Name (ARN) of the AWS Secrets Manager secret that contains the - * credentials used to access the git repository. The secret must have a staging label of - * AWSCURRENT and must be in the following format:

          - *

          - * {"username": UserName, "password": - * Password} - *

          + *

          The justification for why the OfflineStoreStatus is Blocked (if applicable).

          */ - SecretArn?: string; + BlockedReason?: string; } -export namespace GitConfigForUpdate { - export const filterSensitiveLog = (obj: GitConfigForUpdate): any => ({ +export namespace OfflineStoreStatus { + export const filterSensitiveLog = (obj: OfflineStoreStatus): any => ({ ...obj, }); } -/** - *

          Container for human task user interface information.

          - */ -export interface HumanTaskUiSummary { +export interface DescribeFeatureGroupResponse { /** - *

          The name of the human task user interface.

          + *

          The Amazon Resource Name (ARN) of the FeatureGroup.

          */ - HumanTaskUiName: string | undefined; + FeatureGroupArn: string | undefined; /** - *

          The Amazon Resource Name (ARN) of the human task user interface.

          + *

          he name of the FeatureGroup.

          */ - HumanTaskUiArn: string | undefined; + FeatureGroupName: string | undefined; /** - *

          A timestamp when SageMaker created the human task user interface.

          + *

          The name of the Feature used for RecordIdentifier, whose value + * uniquely identifies a record stored in the feature store.

          */ - CreationTime: Date | undefined; -} + RecordIdentifierFeatureName: string | undefined; -export namespace HumanTaskUiSummary { - export const filterSensitiveLog = (obj: HumanTaskUiSummary): any => ({ - ...obj, - }); -} + /** + *

          The name of the feature that stores the EventTime of a Record in a + * FeatureGroup.

          + *

          An EventTime is a point in time when a new event occurs that + * corresponds to the creation or update of a Record in a + * FeatureGroup. All Records in the FeatureGroup + * have a corresponding EventTime.

          + */ + EventTimeFeatureName: string | undefined; -export enum HyperParameterTuningJobSortByOptions { - CreationTime = "CreationTime", - Name = "Name", - Status = "Status", -} + /** + *

          A list of the Features in the FeatureGroup. + * Each feature is defined by a FeatureName and FeatureType.

          + */ + FeatureDefinitions: FeatureDefinition[] | undefined; -/** - *

          Provides summary information about a hyperparameter tuning job.

          - */ -export interface HyperParameterTuningJobSummary { /** - *

          The name of the tuning job.

          + *

          A timestamp indicating when SageMaker created the FeatureGroup.

          */ - HyperParameterTuningJobName: string | undefined; + CreationTime: Date | undefined; /** - *

          The - * Amazon - * Resource Name (ARN) of the tuning job.

          + *

          The configuration for the OnlineStore.

          */ - HyperParameterTuningJobArn: string | undefined; + OnlineStoreConfig?: OnlineStoreConfig; /** - *

          The status of the - * tuning - * job.

          + *

          The configuration of the OfflineStore, inducing the S3 location of the + * OfflineStore, AWS Glue or AWS Hive data catalogue configurations, and the + * security configuration.

          */ - HyperParameterTuningJobStatus: HyperParameterTuningJobStatus | string | undefined; + OfflineStoreConfig?: OfflineStoreConfig; /** - *

          Specifies the search strategy hyperparameter tuning uses to choose which - * hyperparameters to - * use - * for each iteration. Currently, the only valid value is - * Bayesian.

          + *

          The Amazon Resource Name (ARN) of the IAM execution role used to persist data into the + * OfflineStore if an OfflineStoreConfig is provided.

          */ - Strategy: HyperParameterTuningJobStrategyType | string | undefined; + RoleArn?: string; /** - *

          The date and time that the tuning job was created.

          + *

          The status of the feature group.

          */ - CreationTime: Date | undefined; + FeatureGroupStatus?: FeatureGroupStatus | string; /** - *

          The date and time that the tuning job ended.

          + *

          The status of the OfflineStore. Notifies you if replicating data into the + * OfflineStore has failed. Returns either: Active or + * Blocked + *

          */ - HyperParameterTuningEndTime?: Date; + OfflineStoreStatus?: OfflineStoreStatus; /** - *

          The date and time that the tuning job was - * modified.

          + *

          The reason that the FeatureGroup failed to be replicated in the + * OfflineStore. This is failure can occur because:

          + *
            + *
          • + *

            The FeatureGroup could not be created in the + * OfflineStore.

            + *
          • + *
          • + *

            The FeatureGroup could not be deleted from the + * OfflineStore.

            + *
          • + *
          */ - LastModifiedTime?: Date; + FailureReason?: string; /** - *

          The TrainingJobStatusCounters object that specifies the numbers of - * training jobs, categorized by status, that this tuning job launched.

          + *

          A free form description of the feature group.

          */ - TrainingJobStatusCounters: TrainingJobStatusCounters | undefined; + Description?: string; /** - *

          The ObjectiveStatusCounters object that specifies the numbers of - * training jobs, categorized by objective metric status, that this tuning job - * launched.

          + *

          A token to resume pagination of the list of Features + * (FeatureDefinitions).

          */ - ObjectiveStatusCounters: ObjectiveStatusCounters | undefined; + NextToken: string | undefined; +} + +export namespace DescribeFeatureGroupResponse { + export const filterSensitiveLog = (obj: DescribeFeatureGroupResponse): any => ({ + ...obj, + }); +} +export interface DescribeFlowDefinitionRequest { /** - *

          The ResourceLimits object that specifies the maximum number of - * training jobs and parallel training jobs allowed for this tuning job.

          + *

          The name of the flow definition.

          */ - ResourceLimits?: ResourceLimits; + FlowDefinitionName: string | undefined; } -export namespace HyperParameterTuningJobSummary { - export const filterSensitiveLog = (obj: HyperParameterTuningJobSummary): any => ({ +export namespace DescribeFlowDefinitionRequest { + export const filterSensitiveLog = (obj: DescribeFlowDefinitionRequest): any => ({ ...obj, }); } -/** - *

          A SageMaker image. A SageMaker image represents a set of container images that are derived from - * a common base container image. Each of these container images is represented by a SageMaker - * ImageVersion.

          - */ -export interface Image { +export enum FlowDefinitionStatus { + ACTIVE = "Active", + DELETING = "Deleting", + FAILED = "Failed", + INITIALIZING = "Initializing", +} + +export interface DescribeFlowDefinitionResponse { /** - *

          When the image was created.

          + *

          The Amazon Resource Name (ARN) of the flow defintion.

          */ - CreationTime: Date | undefined; + FlowDefinitionArn: string | undefined; /** - *

          The description of the image.

          + *

          The Amazon Resource Name (ARN) of the flow definition.

          */ - Description?: string; + FlowDefinitionName: string | undefined; /** - *

          The name of the image as displayed.

          + *

          The status of the flow definition. Valid values are listed below.

          */ - DisplayName?: string; + FlowDefinitionStatus: FlowDefinitionStatus | string | undefined; /** - *

          When a create, update, or delete operation fails, the reason for the failure.

          + *

          The timestamp when the flow definition was created.

          */ - FailureReason?: string; + CreationTime: Date | undefined; /** - *

          The Amazon Resource Name (ARN) of the image.

          + *

          Container for configuring the source of human task requests. Used to specify if + * Amazon Rekognition or Amazon Textract is used as an integration source.

          */ - ImageArn: string | undefined; + HumanLoopRequestSource?: HumanLoopRequestSource; /** - *

          The name of the image.

          + *

          An object containing information about what triggers a human review workflow.

          */ - ImageName: string | undefined; + HumanLoopActivationConfig?: HumanLoopActivationConfig; /** - *

          The status of the image.

          + *

          An object containing information about who works on the task, the workforce task price, and other task details.

          */ - ImageStatus: ImageStatus | string | undefined; + HumanLoopConfig: HumanLoopConfig | undefined; + + /** + *

          An object containing information about the output file.

          + */ + OutputConfig: FlowDefinitionOutputConfig | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the AWS Identity and Access Management (IAM) execution role for the flow definition.

          + */ + RoleArn: string | undefined; /** - *

          When the image was last modified.

          + *

          The reason your flow definition failed.

          */ - LastModifiedTime: Date | undefined; + FailureReason?: string; } -export namespace Image { - export const filterSensitiveLog = (obj: Image): any => ({ +export namespace DescribeFlowDefinitionResponse { + export const filterSensitiveLog = (obj: DescribeFlowDefinitionResponse): any => ({ ...obj, }); } -export enum ImageSortBy { - CREATION_TIME = "CREATION_TIME", - IMAGE_NAME = "IMAGE_NAME", - LAST_MODIFIED_TIME = "LAST_MODIFIED_TIME", +export interface DescribeHumanTaskUiRequest { + /** + *

          The name of the human task user interface + * (worker task template) you want information about.

          + */ + HumanTaskUiName: string | undefined; } -export enum ImageSortOrder { - ASCENDING = "ASCENDING", - DESCENDING = "DESCENDING", +export namespace DescribeHumanTaskUiRequest { + export const filterSensitiveLog = (obj: DescribeHumanTaskUiRequest): any => ({ + ...obj, + }); +} + +export enum HumanTaskUiStatus { + ACTIVE = "Active", + DELETING = "Deleting", } /** - *

          A version of a SageMaker Image. A version represents an existing container - * image.

          + *

          Container for user interface template information.

          */ -export interface ImageVersion { +export interface UiTemplateInfo { /** - *

          When the version was created.

          + *

          The URL for the user interface template.

          */ - CreationTime: Date | undefined; + Url?: string; /** - *

          When a create or delete operation fails, the reason for the failure.

          + *

          The SHA-256 digest of the contents of the template.

          */ - FailureReason?: string; + ContentSha256?: string; +} + +export namespace UiTemplateInfo { + export const filterSensitiveLog = (obj: UiTemplateInfo): any => ({ + ...obj, + }); +} +export interface DescribeHumanTaskUiResponse { /** - *

          The Amazon Resource Name (ARN) of the image the version is based on.

          + *

          The Amazon Resource Name (ARN) of the human task user interface (worker task template).

          */ - ImageArn: string | undefined; + HumanTaskUiArn: string | undefined; /** - *

          The ARN of the version.

          + *

          The name of the human task user interface (worker task template).

          */ - ImageVersionArn: string | undefined; + HumanTaskUiName: string | undefined; /** - *

          The status of the version.

          + *

          The status of the human task user interface (worker task template). Valid values are listed below.

          */ - ImageVersionStatus: ImageVersionStatus | string | undefined; + HumanTaskUiStatus?: HumanTaskUiStatus | string; /** - *

          When the version was last modified.

          + *

          The timestamp when the human task user interface was created.

          */ - LastModifiedTime: Date | undefined; + CreationTime: Date | undefined; /** - *

          The version number.

          + *

          Container for user interface template information.

          */ - Version: number | undefined; + UiTemplate: UiTemplateInfo | undefined; } -export namespace ImageVersion { - export const filterSensitiveLog = (obj: ImageVersion): any => ({ +export namespace DescribeHumanTaskUiResponse { + export const filterSensitiveLog = (obj: DescribeHumanTaskUiResponse): any => ({ ...obj, }); } -export enum ImageVersionSortBy { - CREATION_TIME = "CREATION_TIME", - LAST_MODIFIED_TIME = "LAST_MODIFIED_TIME", - VERSION = "VERSION", +export interface DescribeHyperParameterTuningJobRequest { + /** + *

          The name of the tuning job.

          + */ + HyperParameterTuningJobName: string | undefined; } -export enum ImageVersionSortOrder { - ASCENDING = "ASCENDING", - DESCENDING = "DESCENDING", +export namespace DescribeHyperParameterTuningJobRequest { + export const filterSensitiveLog = (obj: DescribeHyperParameterTuningJobRequest): any => ({ + ...obj, + }); } /** - *

          Provides counts for human-labeled tasks in the labeling job.

          + *

          Shows the final value for the + * objective + * metric for a training job that was launched by a hyperparameter + * tuning job. You define the objective metric in the + * HyperParameterTuningJobObjective parameter of HyperParameterTuningJobConfig.

          */ -export interface LabelCountersForWorkteam { +export interface FinalHyperParameterTuningJobObjectiveMetric { /** - *

          The total number of data objects labeled by a human worker.

          + *

          Whether to + * minimize + * or maximize the objective metric. Valid values are Minimize and + * Maximize.

          */ - HumanLabeled?: number; + Type?: HyperParameterTuningJobObjectiveType | string; /** - *

          The total number of data objects that need to be labeled by a human worker.

          + *

          The name of the + * objective + * metric.

          */ - PendingHuman?: number; + MetricName: string | undefined; /** - *

          The total number of tasks in the labeling job.

          + *

          The value of the objective metric.

          */ - Total?: number; + Value: number | undefined; } -export namespace LabelCountersForWorkteam { - export const filterSensitiveLog = (obj: LabelCountersForWorkteam): any => ({ +export namespace FinalHyperParameterTuningJobObjectiveMetric { + export const filterSensitiveLog = (obj: FinalHyperParameterTuningJobObjectiveMetric): any => ({ ...obj, }); } +export enum TrainingJobStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} + /** - *

          Provides summary information for a work team.

          + *

          Specifies + * summary information about a training job.

          */ -export interface LabelingJobForWorkteamSummary { +export interface HyperParameterTrainingJobSummary { /** - *

          The name of the labeling job that the work team is assigned to.

          + *

          The training job definition name.

          */ - LabelingJobName?: string; + TrainingJobDefinitionName?: string; /** - *

          A unique identifier for a labeling job. You can use this to refer to a specific - * labeling job.

          + *

          The name of the training job.

          */ - JobReferenceCode: string | undefined; + TrainingJobName: string | undefined; /** - *

          + *

          The + * Amazon + * Resource Name (ARN) of the training job.

          */ - WorkRequesterAccountId: string | undefined; + TrainingJobArn: string | undefined; /** - *

          The date and time that the labeling job was created.

          + *

          The HyperParameter tuning job that launched the training job.

          + */ + TuningJobName?: string; + + /** + *

          The date and time that the training job was created.

          */ CreationTime: Date | undefined; /** - *

          Provides information about the progress of a labeling job.

          + *

          The date and time that the training job started.

          */ - LabelCounters?: LabelCountersForWorkteam; + TrainingStartTime?: Date; /** - *

          The configured number of workers per data object.

          + *

          Specifies the time when the training job ends on training instances. You are billed + * for the time interval between the value of TrainingStartTime and this time. + * For successful jobs and stopped jobs, this is the time after model artifacts are + * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

          */ - NumberOfHumanWorkersPerDataObject?: number; -} + TrainingEndTime?: Date; -export namespace LabelingJobForWorkteamSummary { - export const filterSensitiveLog = (obj: LabelingJobForWorkteamSummary): any => ({ - ...obj, - }); -} + /** + *

          The + * status + * of the training job.

          + */ + TrainingJobStatus: TrainingJobStatus | string | undefined; -/** - *

          Provides summary information about a labeling job.

          - */ -export interface LabelingJobSummary { /** - *

          The name of the labeling job.

          + *

          A + * list of the hyperparameters for which you specified ranges to + * search.

          */ - LabelingJobName: string | undefined; + TunedHyperParameters: { [key: string]: string } | undefined; /** - *

          The Amazon Resource Name (ARN) assigned to the labeling job when it was - * created.

          + *

          The + * reason that the training job failed. + *

          */ - LabelingJobArn: string | undefined; + FailureReason?: string; /** - *

          The date and time that the job was created (timestamp).

          + *

          The FinalHyperParameterTuningJobObjectiveMetric object that + * specifies the + * value + * of the + * objective + * metric of the tuning job that launched this training job.

          */ - CreationTime: Date | undefined; + FinalHyperParameterTuningJobObjectiveMetric?: FinalHyperParameterTuningJobObjectiveMetric; /** - *

          The date and time that the job was last modified (timestamp).

          + *

          The status of the objective metric for the training job:

          + *
            + *
          • + *

            Succeeded: The + * final + * objective metric for the training job was evaluated by the + * hyperparameter tuning job and + * used + * in the hyperparameter tuning process.

            + *
          • + *
          + *
            + *
          • + *

            Pending: The training job is in progress and evaluation of its final objective + * metric is pending.

            + *
          • + *
          + *
            + *
          • + *

            Failed: + * The final objective metric for the training job was not evaluated, and was not + * used in the hyperparameter tuning process. This typically occurs when the + * training job failed or did not emit an objective + * metric.

            + *
          • + *
          */ - LastModifiedTime: Date | undefined; + ObjectiveStatus?: ObjectiveStatus | string; +} + +export namespace HyperParameterTrainingJobSummary { + export const filterSensitiveLog = (obj: HyperParameterTrainingJobSummary): any => ({ + ...obj, + }); +} +export enum HyperParameterTuningJobStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} + +/** + *

          Specifies the number of training jobs that this hyperparameter tuning job launched, + * categorized by the status of their objective metric. The objective metric status shows + * whether the + * final + * objective metric for the training job has been evaluated by the + * tuning job and used in the hyperparameter tuning process.

          + */ +export interface ObjectiveStatusCounters { /** - *

          The current status of the labeling job.

          + *

          The number of training jobs whose final objective metric was evaluated by the + * hyperparameter tuning job and used in the hyperparameter tuning process.

          */ - LabelingJobStatus: LabelingJobStatus | string | undefined; + Succeeded?: number; /** - *

          Counts showing the progress of the labeling job.

          + *

          The number of training jobs that are in progress and pending evaluation of their final + * objective metric.

          */ - LabelCounters: LabelCounters | undefined; + Pending?: number; /** - *

          The Amazon Resource Name (ARN) of the work team assigned to the job.

          + *

          The number of training jobs whose final objective metric was not evaluated and used in + * the hyperparameter tuning process. This typically occurs when the training job failed or + * did not emit an objective metric.

          */ - WorkteamArn: string | undefined; + Failed?: number; +} + +export namespace ObjectiveStatusCounters { + export const filterSensitiveLog = (obj: ObjectiveStatusCounters): any => ({ + ...obj, + }); +} +/** + *

          The numbers of training jobs launched by a hyperparameter tuning job, categorized by + * status.

          + */ +export interface TrainingJobStatusCounters { /** - *

          The Amazon Resource Name (ARN) of a Lambda function. The function is run before each - * data object is sent to a worker.

          + *

          The number of completed training jobs launched by the hyperparameter tuning + * job.

          */ - PreHumanTaskLambdaArn: string | undefined; + Completed?: number; /** - *

          The Amazon Resource Name (ARN) of the Lambda function used to consolidate the - * annotations from individual workers into a label for a data object. For more - * information, see Annotation - * Consolidation.

          + *

          The number of in-progress training jobs launched by a hyperparameter tuning + * job.

          */ - AnnotationConsolidationLambdaArn?: string; + InProgress?: number; /** - *

          If the LabelingJobStatus field is Failed, this field - * contains a description of the error.

          + *

          The number of training jobs that failed, but can be retried. A failed training job can + * be retried only if it failed because an internal service error occurred.

          */ - FailureReason?: string; + RetryableError?: number; /** - *

          The location of the output produced by the labeling job.

          + *

          The number of training jobs that failed and can't be retried. A failed training job + * can't be retried if it failed because a client error occurred.

          */ - LabelingJobOutput?: LabelingJobOutput; + NonRetryableError?: number; /** - *

          Input configuration for the labeling job.

          + *

          The number of training jobs launched by a hyperparameter tuning job that were + * manually + * stopped.

          */ - InputConfig?: LabelingJobInputConfig; + Stopped?: number; } -export namespace LabelingJobSummary { - export const filterSensitiveLog = (obj: LabelingJobSummary): any => ({ +export namespace TrainingJobStatusCounters { + export const filterSensitiveLog = (obj: TrainingJobStatusCounters): any => ({ ...obj, }); } -export enum SortOrder { - ASCENDING = "Ascending", - DESCENDING = "Descending", -} - -export interface ListAlgorithmsInput { - /** - *

          A filter that returns only algorithms created after the specified time - * (timestamp).

          - */ - CreationTimeAfter?: Date; - +export interface DescribeHyperParameterTuningJobResponse { /** - *

          A filter that returns only algorithms created before the specified time - * (timestamp).

          + *

          The name of the tuning job.

          */ - CreationTimeBefore?: Date; + HyperParameterTuningJobName: string | undefined; /** - *

          The maximum number of algorithms to return in the response.

          + *

          The + * Amazon Resource Name (ARN) of the tuning job.

          */ - MaxResults?: number; + HyperParameterTuningJobArn: string | undefined; /** - *

          A string in the algorithm name. This filter returns only algorithms whose name - * contains the specified string.

          + *

          The HyperParameterTuningJobConfig object that specifies the + * configuration of the tuning job.

          */ - NameContains?: string; + HyperParameterTuningJobConfig: HyperParameterTuningJobConfig | undefined; /** - *

          If the response to a previous ListAlgorithms request was truncated, the - * response includes a NextToken. To retrieve the next set of algorithms, use - * the token in the next request.

          + *

          The HyperParameterTrainingJobDefinition object that specifies the + * definition of the training jobs that this tuning job launches.

          */ - NextToken?: string; + TrainingJobDefinition?: HyperParameterTrainingJobDefinition; /** - *

          The parameter by which to sort the results. The default is - * CreationTime.

          + *

          A list of the HyperParameterTrainingJobDefinition objects launched + * for this tuning job.

          */ - SortBy?: AlgorithmSortBy | string; + TrainingJobDefinitions?: HyperParameterTrainingJobDefinition[]; /** - *

          The sort order for the results. The default is Ascending.

          + *

          The status of the tuning job: InProgress, Completed, Failed, Stopping, or + * Stopped.

          */ - SortOrder?: SortOrder | string; -} - -export namespace ListAlgorithmsInput { - export const filterSensitiveLog = (obj: ListAlgorithmsInput): any => ({ - ...obj, - }); -} + HyperParameterTuningJobStatus: HyperParameterTuningJobStatus | string | undefined; -export interface ListAlgorithmsOutput { /** - *

          >An array of AlgorithmSummary objects, each of which lists an - * algorithm.

          + *

          The date and time that the tuning job started.

          */ - AlgorithmSummaryList: AlgorithmSummary[] | undefined; + CreationTime: Date | undefined; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * algorithms, use it in the subsequent request.

          + *

          The date and time that the tuning job ended.

          */ - NextToken?: string; -} - -export namespace ListAlgorithmsOutput { - export const filterSensitiveLog = (obj: ListAlgorithmsOutput): any => ({ - ...obj, - }); -} + HyperParameterTuningEndTime?: Date; -export interface ListAppImageConfigsRequest { /** - *

          The maximum number of AppImageConfigs to return in the response. The default value is - * 10.

          + *

          The date and time that the status of the tuning job was modified.

          */ - MaxResults?: number; + LastModifiedTime?: Date; /** - *

          If the previous call to ListImages didn't return the full set of - * AppImageConfigs, the call returns a token for getting the next set of AppImageConfigs.

          + *

          The TrainingJobStatusCounters object that specifies the number of + * training jobs, categorized by status, that this tuning job launched.

          */ - NextToken?: string; + TrainingJobStatusCounters: TrainingJobStatusCounters | undefined; /** - *

          A filter that returns only AppImageConfigs whose name contains the specified string.

          + *

          The ObjectiveStatusCounters object that specifies the number of + * training jobs, categorized by the status of their final objective metric, that this + * tuning job launched.

          */ - NameContains?: string; + ObjectiveStatusCounters: ObjectiveStatusCounters | undefined; /** - *

          A filter that returns only AppImageConfigs created on or before the specified time.

          + *

          A TrainingJobSummary object that describes the training job that + * completed with the best current HyperParameterTuningJobObjective.

          */ - CreationTimeBefore?: Date; + BestTrainingJob?: HyperParameterTrainingJobSummary; /** - *

          A filter that returns only AppImageConfigs created on or after the specified time.

          + *

          If the hyperparameter tuning job is an warm start tuning job with a + * WarmStartType of IDENTICAL_DATA_AND_ALGORITHM, this is the + * TrainingJobSummary for the training job with the best objective + * metric value of all training jobs launched by this tuning job and all parent jobs + * specified for the warm start tuning job.

          */ - CreationTimeAfter?: Date; + OverallBestTrainingJob?: HyperParameterTrainingJobSummary; /** - *

          A filter that returns only AppImageConfigs modified on or before the specified time.

          + *

          The configuration for starting the hyperparameter parameter tuning job using one or + * more previous tuning jobs as a starting point. The results of previous tuning jobs are + * used to inform which combinations of hyperparameters to search over in the new tuning + * job.

          */ - ModifiedTimeBefore?: Date; + WarmStartConfig?: HyperParameterTuningJobWarmStartConfig; /** - *

          A filter that returns only AppImageConfigs modified on or after the specified time.

          + *

          If the tuning job failed, the reason it failed.

          */ - ModifiedTimeAfter?: Date; + FailureReason?: string; +} - /** - *

          The property used to sort results. The default value is CreationTime.

          - */ - SortBy?: AppImageConfigSortKey | string; +export namespace DescribeHyperParameterTuningJobResponse { + export const filterSensitiveLog = (obj: DescribeHyperParameterTuningJobResponse): any => ({ + ...obj, + }); +} +export interface DescribeImageRequest { /** - *

          The sort order. The default value is Descending.

          + *

          The name of the image to describe.

          */ - SortOrder?: SortOrder | string; + ImageName: string | undefined; } -export namespace ListAppImageConfigsRequest { - export const filterSensitiveLog = (obj: ListAppImageConfigsRequest): any => ({ +export namespace DescribeImageRequest { + export const filterSensitiveLog = (obj: DescribeImageRequest): any => ({ ...obj, }); } -export interface ListAppImageConfigsResponse { +export enum ImageStatus { + CREATED = "CREATED", + CREATE_FAILED = "CREATE_FAILED", + CREATING = "CREATING", + DELETE_FAILED = "DELETE_FAILED", + DELETING = "DELETING", + UPDATE_FAILED = "UPDATE_FAILED", + UPDATING = "UPDATING", +} + +export interface DescribeImageResponse { /** - *

          A token for getting the next set of AppImageConfigs, if there are any.

          + *

          When the image was created.

          */ - NextToken?: string; + CreationTime?: Date; /** - *

          A list of AppImageConfigs and their properties.

          + *

          The description of the image.

          */ - AppImageConfigs?: AppImageConfigDetails[]; -} + Description?: string; -export namespace ListAppImageConfigsResponse { - export const filterSensitiveLog = (obj: ListAppImageConfigsResponse): any => ({ - ...obj, - }); -} + /** + *

          The name of the image as displayed.

          + */ + DisplayName?: string; -export interface ListAppsRequest { /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          When a create, update, or delete operation fails, the reason for the failure.

          */ - NextToken?: string; + FailureReason?: string; /** - *

          Returns a list up to a specified limit.

          + *

          The Amazon Resource Name (ARN) of the image.

          */ - MaxResults?: number; + ImageArn?: string; /** - *

          The sort order for the results. The default is Ascending.

          + *

          The name of the image.

          */ - SortOrder?: SortOrder | string; + ImageName?: string; /** - *

          The parameter by which to sort the results. The default is CreationTime.

          + *

          The status of the image.

          */ - SortBy?: AppSortKey | string; + ImageStatus?: ImageStatus | string; /** - *

          A parameter to search for the domain ID.

          + *

          When the image was last modified.

          */ - DomainIdEquals?: string; + LastModifiedTime?: Date; /** - *

          A parameter to search by user profile name.

          + *

          The Amazon Resource Name (ARN) of the IAM role that enables Amazon SageMaker to perform tasks on your behalf.

          */ - UserProfileNameEquals?: string; + RoleArn?: string; } -export namespace ListAppsRequest { - export const filterSensitiveLog = (obj: ListAppsRequest): any => ({ +export namespace DescribeImageResponse { + export const filterSensitiveLog = (obj: DescribeImageResponse): any => ({ ...obj, }); } -export interface ListAppsResponse { +export interface DescribeImageVersionRequest { /** - *

          The list of apps.

          + *

          The name of the image.

          */ - Apps?: AppDetails[]; + ImageName: string | undefined; /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          The version of the image. If not specified, the latest version is described.

          */ - NextToken?: string; + Version?: number; } -export namespace ListAppsResponse { - export const filterSensitiveLog = (obj: ListAppsResponse): any => ({ +export namespace DescribeImageVersionRequest { + export const filterSensitiveLog = (obj: DescribeImageVersionRequest): any => ({ ...obj, }); } -export interface ListAutoMLJobsRequest { - /** - *

          Request a list of jobs, using a filter for time.

          - */ - CreationTimeAfter?: Date; +export enum ImageVersionStatus { + CREATED = "CREATED", + CREATE_FAILED = "CREATE_FAILED", + CREATING = "CREATING", + DELETE_FAILED = "DELETE_FAILED", + DELETING = "DELETING", +} +export interface DescribeImageVersionResponse { /** - *

          Request a list of jobs, using a filter for time.

          + *

          The registry path of the container image on which this image version is based.

          */ - CreationTimeBefore?: Date; + BaseImage?: string; /** - *

          Request a list of jobs, using a filter for time.

          + *

          The registry path of the container image that contains this image version.

          */ - LastModifiedTimeAfter?: Date; + ContainerImage?: string; /** - *

          Request a list of jobs, using a filter for time.

          + *

          When the version was created.

          */ - LastModifiedTimeBefore?: Date; + CreationTime?: Date; /** - *

          Request a list of jobs, using a search filter for name.

          + *

          When a create or delete operation fails, the reason for the failure.

          */ - NameContains?: string; + FailureReason?: string; /** - *

          Request a list of jobs, using a filter for status.

          + *

          The Amazon Resource Name (ARN) of the image the version is based on.

          */ - StatusEquals?: AutoMLJobStatus | string; + ImageArn?: string; /** - *

          The sort order for the results. The default is Descending.

          + *

          The ARN of the version.

          */ - SortOrder?: AutoMLSortOrder | string; + ImageVersionArn?: string; /** - *

          The parameter by which to sort the results. The default is AutoMLJobName.

          + *

          The status of the version.

          */ - SortBy?: AutoMLSortBy | string; + ImageVersionStatus?: ImageVersionStatus | string; /** - *

          Request a list of jobs up to a specified limit.

          + *

          When the version was last modified.

          */ - MaxResults?: number; + LastModifiedTime?: Date; /** - *

          If the previous response was truncated, you receive this token. Use it in your next - * request to receive the next set of results.

          + *

          The version number.

          */ - NextToken?: string; + Version?: number; } -export namespace ListAutoMLJobsRequest { - export const filterSensitiveLog = (obj: ListAutoMLJobsRequest): any => ({ +export namespace DescribeImageVersionResponse { + export const filterSensitiveLog = (obj: DescribeImageVersionResponse): any => ({ ...obj, }); } -export interface ListAutoMLJobsResponse { - /** - *

          Returns a summary list of jobs.

          - */ - AutoMLJobSummaries: AutoMLJobSummary[] | undefined; - +export interface DescribeLabelingJobRequest { /** - *

          If the previous response was truncated, you receive this token. Use it in your next - * request to receive the next set of results.

          + *

          The name of the labeling job to return information for.

          */ - NextToken?: string; + LabelingJobName: string | undefined; } -export namespace ListAutoMLJobsResponse { - export const filterSensitiveLog = (obj: ListAutoMLJobsResponse): any => ({ +export namespace DescribeLabelingJobRequest { + export const filterSensitiveLog = (obj: DescribeLabelingJobRequest): any => ({ ...obj, }); } -export interface ListCandidatesForAutoMLJobRequest { +/** + *

          Provides a breakdown of the number of objects labeled.

          + */ +export interface LabelCounters { /** - *

          List the Candidates created for the job by providing the job's name.

          + *

          The total number of objects labeled.

          */ - AutoMLJobName: string | undefined; + TotalLabeled?: number; /** - *

          List the Candidates for the job and filter by status.

          + *

          The total number of objects labeled by a human worker.

          */ - StatusEquals?: CandidateStatus | string; + HumanLabeled?: number; /** - *

          List the Candidates for the job and filter by candidate name.

          + *

          The total number of objects labeled by automated data labeling.

          */ - CandidateNameEquals?: string; + MachineLabeled?: number; /** - *

          The sort order for the results. The default is Ascending.

          + *

          The total number of objects that could not be labeled due to an error.

          */ - SortOrder?: AutoMLSortOrder | string; + FailedNonRetryableError?: number; /** - *

          The parameter by which to sort the results. The default is Descending.

          + *

          The total number of objects not yet labeled.

          */ - SortBy?: CandidateSortBy | string; + Unlabeled?: number; +} + +export namespace LabelCounters { + export const filterSensitiveLog = (obj: LabelCounters): any => ({ + ...obj, + }); +} +/** + *

          Specifies the location of the output produced by the labeling job.

          + */ +export interface LabelingJobOutput { /** - *

          List the job's Candidates up to a specified limit.

          + *

          The Amazon S3 bucket location of the manifest file for labeled data.

          */ - MaxResults?: number; + OutputDatasetS3Uri: string | undefined; /** - *

          If the previous response was truncated, you receive this token. Use it in your next - * request to receive the next set of results.

          + *

          The Amazon Resource Name (ARN) for the most recent Amazon SageMaker model trained as part of + * automated data labeling.

          */ - NextToken?: string; + FinalActiveLearningModelArn?: string; } -export namespace ListCandidatesForAutoMLJobRequest { - export const filterSensitiveLog = (obj: ListCandidatesForAutoMLJobRequest): any => ({ +export namespace LabelingJobOutput { + export const filterSensitiveLog = (obj: LabelingJobOutput): any => ({ ...obj, }); } -export interface ListCandidatesForAutoMLJobResponse { +export enum LabelingJobStatus { + COMPLETED = "Completed", + FAILED = "Failed", + INITIALIZING = "Initializing", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} + +export interface DescribeLabelingJobResponse { /** - *

          Summaries about the Candidates.

          + *

          The processing status of the labeling job.

          */ - Candidates: AutoMLCandidate[] | undefined; + LabelingJobStatus: LabelingJobStatus | string | undefined; /** - *

          If the previous response was truncated, you receive this token. Use it in your next - * request to receive the next set of results.

          + *

          Provides a breakdown of the number of data objects labeled by humans, the number of + * objects labeled by machine, the number of objects than couldn't be labeled, and the + * total number of objects labeled.

          */ - NextToken?: string; -} - -export namespace ListCandidatesForAutoMLJobResponse { - export const filterSensitiveLog = (obj: ListCandidatesForAutoMLJobResponse): any => ({ - ...obj, - }); -} + LabelCounters: LabelCounters | undefined; -export interface ListCodeRepositoriesInput { /** - *

          A filter that returns only Git repositories that were created after the specified - * time.

          + *

          If the job failed, the reason that it failed.

          */ - CreationTimeAfter?: Date; + FailureReason?: string; /** - *

          A filter that returns only Git repositories that were created before the specified - * time.

          + *

          The date and time that the labeling job was created.

          */ - CreationTimeBefore?: Date; + CreationTime: Date | undefined; /** - *

          A filter that returns only Git repositories that were last modified after the - * specified time.

          + *

          The date and time that the labeling job was last updated.

          */ - LastModifiedTimeAfter?: Date; + LastModifiedTime: Date | undefined; /** - *

          A filter that returns only Git repositories that were last modified before the - * specified time.

          + *

          A unique identifier for work done as part of a labeling job.

          */ - LastModifiedTimeBefore?: Date; + JobReferenceCode: string | undefined; /** - *

          The maximum number of Git repositories to return in the response.

          + *

          The name assigned to the labeling job when it was created.

          */ - MaxResults?: number; + LabelingJobName: string | undefined; /** - *

          A string in the Git repositories name. This filter returns only repositories whose - * name contains the specified string.

          + *

          The Amazon Resource Name (ARN) of the labeling job.

          */ - NameContains?: string; + LabelingJobArn: string | undefined; /** - *

          If the result of a ListCodeRepositoriesOutput request was truncated, the - * response includes a NextToken. To get the next set of Git repositories, use - * the token in the next request.

          + *

          The attribute used as the label in the output manifest file.

          */ - NextToken?: string; + LabelAttributeName?: string; /** - *

          The field to sort results by. The default is Name.

          + *

          Input configuration information for the labeling job, such as the Amazon S3 location of the + * data objects and the location of the manifest file that describes the data + * objects.

          */ - SortBy?: CodeRepositorySortBy | string; + InputConfig: LabelingJobInputConfig | undefined; /** - *

          The sort order for results. The default is Ascending.

          + *

          The location of the job's output data and the AWS Key Management Service key ID for the key used to + * encrypt the output data, if any.

          */ - SortOrder?: CodeRepositorySortOrder | string; -} + OutputConfig: LabelingJobOutputConfig | undefined; -export namespace ListCodeRepositoriesInput { - export const filterSensitiveLog = (obj: ListCodeRepositoriesInput): any => ({ - ...obj, - }); -} + /** + *

          The Amazon Resource Name (ARN) that Amazon SageMaker assumes to perform tasks on your behalf + * during data labeling.

          + */ + RoleArn: string | undefined; -export interface ListCodeRepositoriesOutput { /** - *

          Gets a list of summaries of the Git repositories. Each summary specifies the following - * values for the repository:

          + *

          The S3 location of the JSON file that defines the categories used to label data + * objects. Please note the following label-category limits:

          *
            *
          • - *

            Name

            - *
          • - *
          • - *

            Amazon Resource Name (ARN)

            - *
          • - *
          • - *

            Creation time

            - *
          • - *
          • - *

            Last modified time

            + *

            Semantic segmentation labeling jobs using automated labeling: 20 labels

            *
          • *
          • - *

            Configuration information, including the URL location of the repository and - * the ARN of the AWS Secrets Manager secret that contains the credentials used - * to access the repository.

            + *

            Box bounding labeling jobs (all): 10 labels

            *
          • *
          + *

          The file is a JSON structure in the following format:

          + *

          + * { + *

          + *

          + * "document-version": "2018-11-28" + *

          + *

          + * "labels": [ + *

          + *

          + * { + *

          + *

          + * "label": "label 1" + *

          + *

          + * }, + *

          + *

          + * { + *

          + *

          + * "label": "label 2" + *

          + *

          + * }, + *

          + *

          + * ... + *

          + *

          + * { + *

          + *

          + * "label": "label n" + *

          + *

          + * } + *

          + *

          + * ] + *

          + *

          + * } + *

          */ - CodeRepositorySummaryList: CodeRepositorySummary[] | undefined; + LabelCategoryConfigS3Uri?: string; /** - *

          If the result of a ListCodeRepositoriesOutput request was truncated, the - * response includes a NextToken. To get the next set of Git repositories, use - * the token in the next request.

          + *

          A set of conditions for stopping a labeling job. If any of the conditions are met, the + * job is automatically stopped.

          */ - NextToken?: string; + StoppingConditions?: LabelingJobStoppingConditions; + + /** + *

          Configuration information for automated data labeling.

          + */ + LabelingJobAlgorithmsConfig?: LabelingJobAlgorithmsConfig; + + /** + *

          Configuration information required for human workers to complete a labeling + * task.

          + */ + HumanTaskConfig: HumanTaskConfig | undefined; + + /** + *

          An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

          + */ + Tags?: Tag[]; + + /** + *

          The location of the output produced by the labeling job.

          + */ + LabelingJobOutput?: LabelingJobOutput; } -export namespace ListCodeRepositoriesOutput { - export const filterSensitiveLog = (obj: ListCodeRepositoriesOutput): any => ({ +export namespace DescribeLabelingJobResponse { + export const filterSensitiveLog = (obj: DescribeLabelingJobResponse): any => ({ ...obj, }); } -export enum ListCompilationJobsSortBy { - CREATION_TIME = "CreationTime", - NAME = "Name", - STATUS = "Status", -} - -export interface ListCompilationJobsRequest { +export interface DescribeModelInput { /** - *

          If the result of the previous ListCompilationJobs request was truncated, - * the response includes a NextToken. To retrieve the next set of model - * compilation jobs, use the token in the next request.

          + *

          The name of the model.

          */ - NextToken?: string; + ModelName: string | undefined; +} - /** - *

          The maximum number of model compilation jobs to return in the response.

          - */ - MaxResults?: number; +export namespace DescribeModelInput { + export const filterSensitiveLog = (obj: DescribeModelInput): any => ({ + ...obj, + }); +} +export interface DescribeModelOutput { /** - *

          A filter that returns the model compilation jobs that were created after a specified - * time.

          + *

          Name of the Amazon SageMaker model.

          */ - CreationTimeAfter?: Date; + ModelName: string | undefined; /** - *

          A filter that returns the model compilation jobs that were created before a specified - * time.

          + *

          The location of the primary inference code, associated artifacts, and custom + * environment map that the inference code uses when it is deployed in production. + *

          */ - CreationTimeBefore?: Date; + PrimaryContainer?: ContainerDefinition; /** - *

          A filter that returns the model compilation jobs that were modified after a specified - * time.

          + *

          The containers in the inference pipeline.

          */ - LastModifiedTimeAfter?: Date; + Containers?: ContainerDefinition[]; /** - *

          A filter that returns the model compilation jobs that were modified before a specified - * time.

          + *

          The Amazon Resource Name (ARN) of the IAM role that you specified for the + * model.

          */ - LastModifiedTimeBefore?: Date; + ExecutionRoleArn: string | undefined; /** - *

          A filter that returns the model compilation jobs whose name contains a specified - * string.

          + *

          A VpcConfig object that specifies the VPC that this model has access + * to. For more information, see Protect Endpoints by Using an Amazon Virtual + * Private Cloud + *

          */ - NameContains?: string; + VpcConfig?: VpcConfig; /** - *

          A filter that retrieves model compilation jobs with a specific DescribeCompilationJobResponse$CompilationJobStatus status.

          + *

          A timestamp that shows when the model was created.

          */ - StatusEquals?: CompilationJobStatus | string; + CreationTime: Date | undefined; /** - *

          The field by which to sort results. The default is CreationTime.

          + *

          The Amazon Resource Name (ARN) of the model.

          */ - SortBy?: ListCompilationJobsSortBy | string; + ModelArn: string | undefined; /** - *

          The sort order for results. The default is Ascending.

          + *

          If True, no inbound or outbound network calls can be made to or from the + * model container.

          */ - SortOrder?: SortOrder | string; + EnableNetworkIsolation?: boolean; } -export namespace ListCompilationJobsRequest { - export const filterSensitiveLog = (obj: ListCompilationJobsRequest): any => ({ +export namespace DescribeModelOutput { + export const filterSensitiveLog = (obj: DescribeModelOutput): any => ({ ...obj, }); } -export interface ListCompilationJobsResponse { - /** - *

          An array of CompilationJobSummary objects, each describing a model - * compilation job.

          - */ - CompilationJobSummaries: CompilationJobSummary[] | undefined; - +export interface DescribeModelPackageInput { /** - *

          If the response is truncated, Amazon SageMaker returns this NextToken. To retrieve - * the next set of model compilation jobs, use this token in the next request.

          + *

          The name of the model package to describe.

          */ - NextToken?: string; + ModelPackageName: string | undefined; } -export namespace ListCompilationJobsResponse { - export const filterSensitiveLog = (obj: ListCompilationJobsResponse): any => ({ +export namespace DescribeModelPackageInput { + export const filterSensitiveLog = (obj: DescribeModelPackageInput): any => ({ ...obj, }); } -export interface ListDomainsRequest { +export enum ModelPackageStatus { + COMPLETED = "Completed", + DELETING = "Deleting", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + PENDING = "Pending", +} + +export enum DetailedModelPackageStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + NOT_STARTED = "NotStarted", +} + +/** + *

          Represents the overall status of a model package.

          + */ +export interface ModelPackageStatusItem { /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          The name of the model package for which the overall status is being reported.

          */ - NextToken?: string; + Name: string | undefined; /** - *

          Returns a list up to a specified limit.

          + *

          The current status.

          */ - MaxResults?: number; + Status: DetailedModelPackageStatus | string | undefined; + + /** + *

          if the overall status is Failed, the reason for the failure.

          + */ + FailureReason?: string; } -export namespace ListDomainsRequest { - export const filterSensitiveLog = (obj: ListDomainsRequest): any => ({ +export namespace ModelPackageStatusItem { + export const filterSensitiveLog = (obj: ModelPackageStatusItem): any => ({ ...obj, }); } -export interface ListDomainsResponse { +/** + *

          Specifies the validation and image scan statuses of the model package.

          + */ +export interface ModelPackageStatusDetails { /** - *

          The list of domains.

          + *

          The validation status of the model package.

          */ - Domains?: DomainDetails[]; + ValidationStatuses: ModelPackageStatusItem[] | undefined; /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          The status of the scan of the Docker image container for the model package.

          */ - NextToken?: string; + ImageScanStatuses?: ModelPackageStatusItem[]; } -export namespace ListDomainsResponse { - export const filterSensitiveLog = (obj: ListDomainsResponse): any => ({ +export namespace ModelPackageStatusDetails { + export const filterSensitiveLog = (obj: ModelPackageStatusDetails): any => ({ ...obj, }); } -export enum OrderKey { - Ascending = "Ascending", - Descending = "Descending", -} - -export interface ListEndpointConfigsInput { +export interface DescribeModelPackageOutput { /** - *

          The field to sort results by. The default is CreationTime.

          + *

          The name of the model package being described.

          */ - SortBy?: EndpointConfigSortKey | string; + ModelPackageName: string | undefined; /** - *

          The sort order for results. The default is Descending.

          + *

          If the model is a versioned model, the name of the model group that the versioned + * model belongs to.

          */ - SortOrder?: OrderKey | string; + ModelPackageGroupName?: string; /** - *

          If the result of the previous ListEndpointConfig request was - * truncated, the response includes a NextToken. To retrieve the next set of - * endpoint configurations, use the token in the next request.

          + *

          The version of the model package.

          */ - NextToken?: string; + ModelPackageVersion?: number; /** - *

          The maximum number of training jobs to return in the response.

          + *

          The Amazon Resource Name (ARN) of the model package.

          */ - MaxResults?: number; + ModelPackageArn: string | undefined; /** - *

          A string in the endpoint configuration name. This filter returns only endpoint - * configurations whose name contains the specified string.

          + *

          A brief summary of the model package.

          */ - NameContains?: string; + ModelPackageDescription?: string; /** - *

          A filter that returns only endpoint configurations created before the specified - * time (timestamp).

          + *

          A timestamp specifying when the model package was created.

          */ - CreationTimeBefore?: Date; + CreationTime: Date | undefined; /** - *

          A filter that returns only endpoint configurations with a creation time greater - * than or equal to the specified time (timestamp).

          + *

          Details about inference jobs that can be run with models based on this model + * package.

          */ - CreationTimeAfter?: Date; -} - -export namespace ListEndpointConfigsInput { - export const filterSensitiveLog = (obj: ListEndpointConfigsInput): any => ({ - ...obj, - }); -} + InferenceSpecification?: InferenceSpecification; -export interface ListEndpointConfigsOutput { /** - *

          An array of endpoint configurations.

          + *

          Details about the algorithm that was used to create the model package.

          */ - EndpointConfigs: EndpointConfigSummary[] | undefined; + SourceAlgorithmSpecification?: SourceAlgorithmSpecification; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * endpoint configurations, use it in the subsequent request

          + *

          Configurations for one or more transform jobs that Amazon SageMaker runs to test the model + * package.

          */ - NextToken?: string; -} - -export namespace ListEndpointConfigsOutput { - export const filterSensitiveLog = (obj: ListEndpointConfigsOutput): any => ({ - ...obj, - }); -} + ValidationSpecification?: ModelPackageValidationSpecification; -export interface ListEndpointsInput { /** - *

          Sorts the list of results. The default is CreationTime.

          + *

          The current status of the model package.

          */ - SortBy?: EndpointSortKey | string; + ModelPackageStatus: ModelPackageStatus | string | undefined; /** - *

          The sort order for results. The default is Descending.

          + *

          Details about the current status of the model package.

          */ - SortOrder?: OrderKey | string; + ModelPackageStatusDetails: ModelPackageStatusDetails | undefined; /** - *

          If the result of a ListEndpoints request was truncated, the response - * includes a NextToken. To retrieve the next set of endpoints, use the token - * in the next request.

          + *

          Whether the model package is certified for listing on AWS Marketplace.

          */ - NextToken?: string; + CertifyForMarketplace?: boolean; /** - *

          The maximum number of endpoints to return in the response.

          + *

          The approval status of the model package.

          */ - MaxResults?: number; + ModelApprovalStatus?: ModelApprovalStatus | string; /** - *

          A string in endpoint names. This filter returns only endpoints whose name contains - * the specified string.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - NameContains?: string; + CreatedBy?: UserContext; /** - *

          A filter that returns only endpoints that were created before the specified time - * (timestamp).

          + *

          Metadata properties of the tracking entity, trial, or trial component.

          */ - CreationTimeBefore?: Date; + MetadataProperties?: MetadataProperties; /** - *

          A filter that returns only endpoints with a creation time greater than or equal to - * the specified time (timestamp).

          + *

          Metrics for the model.

          */ - CreationTimeAfter?: Date; + ModelMetrics?: ModelMetrics; /** - *

          A filter that returns only endpoints that were modified before the specified - * timestamp.

          + *

          The last time the model package was modified.

          */ - LastModifiedTimeBefore?: Date; + LastModifiedTime?: Date; /** - *

          A filter that returns only endpoints that were modified after the specified - * timestamp.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - LastModifiedTimeAfter?: Date; + LastModifiedBy?: UserContext; /** - *

          A filter that returns only endpoints with the specified status.

          + *

          A description provided for the model approval.

          */ - StatusEquals?: EndpointStatus | string; + ApprovalDescription?: string; } -export namespace ListEndpointsInput { - export const filterSensitiveLog = (obj: ListEndpointsInput): any => ({ +export namespace DescribeModelPackageOutput { + export const filterSensitiveLog = (obj: DescribeModelPackageOutput): any => ({ ...obj, }); } -export interface ListEndpointsOutput { - /** - *

          An array or endpoint objects.

          - */ - Endpoints: EndpointSummary[] | undefined; - +export interface DescribeModelPackageGroupInput { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * training jobs, use it in the subsequent request.

          + *

          The name of the model group to describe.

          */ - NextToken?: string; + ModelPackageGroupName: string | undefined; } -export namespace ListEndpointsOutput { - export const filterSensitiveLog = (obj: ListEndpointsOutput): any => ({ +export namespace DescribeModelPackageGroupInput { + export const filterSensitiveLog = (obj: DescribeModelPackageGroupInput): any => ({ ...obj, }); } -export enum SortExperimentsBy { - CREATION_TIME = "CreationTime", - NAME = "Name", +export enum ModelPackageGroupStatus { + COMPLETED = "Completed", + DELETE_FAILED = "DeleteFailed", + DELETING = "Deleting", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + PENDING = "Pending", } -export interface ListExperimentsRequest { +export interface DescribeModelPackageGroupOutput { /** - *

          A filter that returns only experiments created after the specified time.

          + *

          The name of the model group.

          */ - CreatedAfter?: Date; + ModelPackageGroupName: string | undefined; /** - *

          A filter that returns only experiments created before the specified time.

          + *

          The Amazon Resource Name (ARN) of the model group.

          */ - CreatedBefore?: Date; + ModelPackageGroupArn: string | undefined; /** - *

          The property used to sort results. The default value is CreationTime.

          + *

          A description of the model group.

          */ - SortBy?: SortExperimentsBy | string; + ModelPackageGroupDescription?: string; /** - *

          The sort order. The default value is Descending.

          + *

          The time that the model group was created.

          */ - SortOrder?: SortOrder | string; + CreationTime: Date | undefined; /** - *

          If the previous call to ListExperiments didn't return the full set of - * experiments, the call returns a token for getting the next set of experiments.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - NextToken?: string; + CreatedBy: UserContext | undefined; /** - *

          The maximum number of experiments to return in the response. The default value is - * 10.

          + *

          The status of the model group.

          */ - MaxResults?: number; + ModelPackageGroupStatus: ModelPackageGroupStatus | string | undefined; } -export namespace ListExperimentsRequest { - export const filterSensitiveLog = (obj: ListExperimentsRequest): any => ({ +export namespace DescribeModelPackageGroupOutput { + export const filterSensitiveLog = (obj: DescribeModelPackageGroupOutput): any => ({ ...obj, }); } -export interface ListExperimentsResponse { - /** - *

          A list of the summaries of your experiments.

          - */ - ExperimentSummaries?: ExperimentSummary[]; - +export interface DescribeMonitoringScheduleRequest { /** - *

          A token for getting the next set of experiments, if there are any.

          + *

          Name of a previously created monitoring schedule.

          */ - NextToken?: string; + MonitoringScheduleName: string | undefined; } -export namespace ListExperimentsResponse { - export const filterSensitiveLog = (obj: ListExperimentsResponse): any => ({ +export namespace DescribeMonitoringScheduleRequest { + export const filterSensitiveLog = (obj: DescribeMonitoringScheduleRequest): any => ({ ...obj, }); } -export interface ListFlowDefinitionsRequest { +export enum ExecutionStatus { + COMPLETED = "Completed", + COMPLETED_WITH_VIOLATIONS = "CompletedWithViolations", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + PENDING = "Pending", + STOPPED = "Stopped", + STOPPING = "Stopping", +} + +/** + *

          Summary of information about the last monitoring job to run.

          + */ +export interface MonitoringExecutionSummary { /** - *

          A filter that returns only flow definitions with a creation time greater than or equal to the specified timestamp.

          + *

          The name of the monitoring schedule.

          */ - CreationTimeAfter?: Date; + MonitoringScheduleName: string | undefined; /** - *

          A filter that returns only flow definitions that were created before the specified timestamp.

          + *

          The time the monitoring job was scheduled.

          */ - CreationTimeBefore?: Date; + ScheduledTime: Date | undefined; /** - *

          An optional value that specifies whether you want the results sorted in Ascending or Descending order.

          + *

          The time at which the monitoring job was created.

          */ - SortOrder?: SortOrder | string; + CreationTime: Date | undefined; /** - *

          A token to resume pagination.

          + *

          A timestamp that indicates the last time the monitoring job was modified.

          */ - NextToken?: string; + LastModifiedTime: Date | undefined; /** - *

          The total number of items to return. If the total number of available items is more than the value specified in MaxResults, then a NextToken will be provided in the output that you can use to resume pagination.

          + *

          The status of the monitoring job.

          */ - MaxResults?: number; -} + MonitoringExecutionStatus: ExecutionStatus | string | undefined; -export namespace ListFlowDefinitionsRequest { - export const filterSensitiveLog = (obj: ListFlowDefinitionsRequest): any => ({ - ...obj, - }); -} + /** + *

          The Amazon Resource Name (ARN) of the monitoring job.

          + */ + ProcessingJobArn?: string; -export interface ListFlowDefinitionsResponse { /** - *

          An array of objects describing the flow definitions.

          + *

          The name of teh endpoint used to run the monitoring job.

          */ - FlowDefinitionSummaries: FlowDefinitionSummary[] | undefined; + EndpointName?: string; /** - *

          A token to resume pagination.

          + *

          Contains the reason a monitoring job failed, if it failed.

          */ - NextToken?: string; + FailureReason?: string; } -export namespace ListFlowDefinitionsResponse { - export const filterSensitiveLog = (obj: ListFlowDefinitionsResponse): any => ({ +export namespace MonitoringExecutionSummary { + export const filterSensitiveLog = (obj: MonitoringExecutionSummary): any => ({ ...obj, }); } -export interface ListHumanTaskUisRequest { +export enum ScheduleStatus { + FAILED = "Failed", + PENDING = "Pending", + SCHEDULED = "Scheduled", + STOPPED = "Stopped", +} + +export interface DescribeMonitoringScheduleResponse { + /** + *

          The Amazon Resource Name (ARN) of the monitoring schedule.

          + */ + MonitoringScheduleArn: string | undefined; + /** - *

          A filter that returns only human task user interfaces with a creation time greater than or equal to the specified timestamp.

          + *

          Name of the monitoring schedule.

          */ - CreationTimeAfter?: Date; + MonitoringScheduleName: string | undefined; /** - *

          A filter that returns only human task user interfaces that were created before the specified timestamp.

          + *

          The status of an monitoring job.

          */ - CreationTimeBefore?: Date; + MonitoringScheduleStatus: ScheduleStatus | string | undefined; /** - *

          An optional value that specifies whether you want the results sorted in Ascending or Descending order.

          + *

          A string, up to one KB in size, that contains the reason a monitoring job failed, if it + * failed.

          */ - SortOrder?: SortOrder | string; + FailureReason?: string; + + /** + *

          The time at which the monitoring job was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          The time at which the monitoring job was last modified.

          + */ + LastModifiedTime: Date | undefined; + + /** + *

          The configuration object that specifies the monitoring schedule and defines the + * monitoring job.

          + */ + MonitoringScheduleConfig: MonitoringScheduleConfig | undefined; /** - *

          A token to resume pagination.

          + *

          The name of the endpoint for the monitoring job.

          */ - NextToken?: string; + EndpointName?: string; /** - *

          The total number of items to return. If the total number of available items is more than the value specified in MaxResults, then a NextToken will be provided in the output that you can use to resume pagination.

          + *

          Describes metadata on the last execution to run, if there was one.

          */ - MaxResults?: number; + LastMonitoringExecutionSummary?: MonitoringExecutionSummary; } -export namespace ListHumanTaskUisRequest { - export const filterSensitiveLog = (obj: ListHumanTaskUisRequest): any => ({ +export namespace DescribeMonitoringScheduleResponse { + export const filterSensitiveLog = (obj: DescribeMonitoringScheduleResponse): any => ({ ...obj, }); } -export interface ListHumanTaskUisResponse { - /** - *

          An array of objects describing the human task user interfaces.

          - */ - HumanTaskUiSummaries: HumanTaskUiSummary[] | undefined; - +export interface DescribeNotebookInstanceInput { /** - *

          A token to resume pagination.

          + *

          The name of the notebook instance that you want information about.

          */ - NextToken?: string; + NotebookInstanceName: string | undefined; } -export namespace ListHumanTaskUisResponse { - export const filterSensitiveLog = (obj: ListHumanTaskUisResponse): any => ({ +export namespace DescribeNotebookInstanceInput { + export const filterSensitiveLog = (obj: DescribeNotebookInstanceInput): any => ({ ...obj, }); } -export interface ListHyperParameterTuningJobsRequest { - /** - *

          If the result of the previous ListHyperParameterTuningJobs request was - * truncated, the response includes a NextToken. To retrieve the next set of - * tuning jobs, use the token in the next request.

          - */ - NextToken?: string; +export enum NotebookInstanceStatus { + Deleting = "Deleting", + Failed = "Failed", + InService = "InService", + Pending = "Pending", + Stopped = "Stopped", + Stopping = "Stopping", + Updating = "Updating", +} +export interface DescribeNotebookInstanceOutput { /** - *

          The - * maximum number of tuning jobs to return. The default value is - * 10.

          + *

          The Amazon Resource Name (ARN) of the notebook instance.

          */ - MaxResults?: number; + NotebookInstanceArn?: string; /** - *

          The - * field - * to sort results by. The default is Name.

          + *

          The name of the Amazon SageMaker notebook instance.

          */ - SortBy?: HyperParameterTuningJobSortByOptions | string; + NotebookInstanceName?: string; /** - *

          The sort - * order - * for results. The default is Ascending.

          + *

          The status of the notebook instance.

          */ - SortOrder?: SortOrder | string; + NotebookInstanceStatus?: NotebookInstanceStatus | string; /** - *

          A string in the tuning job name. This filter returns only tuning jobs whose name - * contains the specified string.

          + *

          If status is Failed, the reason it failed.

          */ - NameContains?: string; + FailureReason?: string; /** - *

          A filter that returns only tuning jobs that were created after the - * specified - * time.

          + *

          The URL that you use to connect to the Jupyter notebook that is running in your + * notebook instance.

          */ - CreationTimeAfter?: Date; + Url?: string; /** - *

          A filter that returns only tuning jobs that were created before the - * specified - * time.

          + *

          The type of ML compute instance running on the notebook instance.

          */ - CreationTimeBefore?: Date; + InstanceType?: _InstanceType | string; /** - *

          A filter that returns only tuning jobs that were modified after the specified - * time.

          + *

          The ID of the VPC subnet.

          */ - LastModifiedTimeAfter?: Date; + SubnetId?: string; /** - *

          A filter that returns only tuning jobs that were modified before the specified - * time.

          + *

          The IDs of the VPC security groups.

          */ - LastModifiedTimeBefore?: Date; + SecurityGroups?: string[]; /** - *

          A filter that returns only tuning jobs with the - * specified - * status.

          + *

          The Amazon Resource Name (ARN) of the IAM role associated with the instance. + *

          */ - StatusEquals?: HyperParameterTuningJobStatus | string; -} - -export namespace ListHyperParameterTuningJobsRequest { - export const filterSensitiveLog = (obj: ListHyperParameterTuningJobsRequest): any => ({ - ...obj, - }); -} + RoleArn?: string; -export interface ListHyperParameterTuningJobsResponse { /** - *

          A list of HyperParameterTuningJobSummary objects that - * describe - * the tuning jobs that the ListHyperParameterTuningJobs - * request returned.

          + *

          The AWS KMS key ID Amazon SageMaker uses to encrypt data when storing it on the ML storage + * volume attached to the instance.

          */ - HyperParameterTuningJobSummaries: HyperParameterTuningJobSummary[] | undefined; + KmsKeyId?: string; /** - *

          If the result of this ListHyperParameterTuningJobs request was truncated, - * the response includes a NextToken. To retrieve the next set of tuning jobs, - * use the token in the next request.

          + *

          The network interface IDs that Amazon SageMaker created at the time of creating the instance. + *

          */ - NextToken?: string; -} - -export namespace ListHyperParameterTuningJobsResponse { - export const filterSensitiveLog = (obj: ListHyperParameterTuningJobsResponse): any => ({ - ...obj, - }); -} + NetworkInterfaceId?: string; -export interface ListImagesRequest { /** - *

          A filter that returns only images created on or after the specified time.

          + *

          A timestamp. Use this parameter to retrieve the time when the notebook instance was + * last modified.

          */ - CreationTimeAfter?: Date; + LastModifiedTime?: Date; /** - *

          A filter that returns only images created on or before the specified time.

          + *

          A timestamp. Use this parameter to return the time when the notebook instance was + * created

          */ - CreationTimeBefore?: Date; + CreationTime?: Date; /** - *

          A filter that returns only images modified on or after the specified time.

          + *

          Returns the name of a notebook instance lifecycle configuration.

          + *

          For information about notebook instance lifestyle configurations, see Step + * 2.1: (Optional) Customize a Notebook Instance + *

          */ - LastModifiedTimeAfter?: Date; + NotebookInstanceLifecycleConfigName?: string; /** - *

          A filter that returns only images modified on or before the specified time.

          + *

          Describes whether Amazon SageMaker provides internet access to the notebook instance. If this + * value is set to Disabled, the notebook instance does not have + * internet access, and cannot connect to Amazon SageMaker training and endpoint services.

          + *

          For more information, see Notebook Instances Are Internet-Enabled by Default.

          */ - LastModifiedTimeBefore?: Date; + DirectInternetAccess?: DirectInternetAccess | string; /** - *

          The maximum number of images to return in the response. The default value is 10.

          + *

          The size, in GB, of the ML storage volume attached to the notebook instance.

          */ - MaxResults?: number; + VolumeSizeInGB?: number; /** - *

          A filter that returns only images whose name contains the specified string.

          + *

          A list of the Elastic Inference (EI) instance types associated with this notebook + * instance. Currently only one EI instance type can be associated with a notebook + * instance. For more information, see Using Elastic Inference in Amazon + * SageMaker.

          */ - NameContains?: string; + AcceleratorTypes?: (NotebookInstanceAcceleratorType | string)[]; /** - *

          If the previous call to ListImages didn't return the full set of images, - * the call returns a token for getting the next set of images.

          + *

          The Git repository associated with the notebook instance as its default code + * repository. This can be either the name of a Git repository stored as a resource in your + * account, or the URL of a Git repository in AWS CodeCommit or in any + * other Git repository. When you open a notebook instance, it opens in the directory that + * contains this repository. For more information, see Associating Git Repositories with Amazon SageMaker + * Notebook Instances.

          */ - NextToken?: string; + DefaultCodeRepository?: string; /** - *

          The property used to sort results. The default value is CREATION_TIME.

          + *

          An array of up to three Git repositories associated with the notebook instance. These + * can be either the names of Git repositories stored as resources in your account, or the + * URL of Git repositories in AWS CodeCommit or in any + * other Git repository. These repositories are cloned at the same level as the default + * repository of your notebook instance. For more information, see Associating Git + * Repositories with Amazon SageMaker Notebook Instances.

          */ - SortBy?: ImageSortBy | string; + AdditionalCodeRepositories?: string[]; /** - *

          The sort order. The default value is DESCENDING.

          + *

          Whether root access is enabled or disabled for users of the notebook instance.

          + * + *

          Lifecycle configurations need root access to be able to set up a notebook + * instance. Because of this, lifecycle configurations associated with a notebook + * instance always run with root access even if you disable root access for + * users.

          + *
          */ - SortOrder?: ImageSortOrder | string; + RootAccess?: RootAccess | string; } -export namespace ListImagesRequest { - export const filterSensitiveLog = (obj: ListImagesRequest): any => ({ +export namespace DescribeNotebookInstanceOutput { + export const filterSensitiveLog = (obj: DescribeNotebookInstanceOutput): any => ({ ...obj, }); } -export interface ListImagesResponse { - /** - *

          A list of images and their properties.

          - */ - Images?: Image[]; - +export interface DescribeNotebookInstanceLifecycleConfigInput { /** - *

          A token for getting the next set of images, if there are any.

          + *

          The name of the lifecycle configuration to describe.

          */ - NextToken?: string; + NotebookInstanceLifecycleConfigName: string | undefined; } -export namespace ListImagesResponse { - export const filterSensitiveLog = (obj: ListImagesResponse): any => ({ +export namespace DescribeNotebookInstanceLifecycleConfigInput { + export const filterSensitiveLog = (obj: DescribeNotebookInstanceLifecycleConfigInput): any => ({ ...obj, }); } -export interface ListImageVersionsRequest { - /** - *

          A filter that returns only versions created on or after the specified time.

          - */ - CreationTimeAfter?: Date; - +export interface DescribeNotebookInstanceLifecycleConfigOutput { /** - *

          A filter that returns only versions created on or before the specified time.

          + *

          The Amazon Resource Name (ARN) of the lifecycle configuration.

          */ - CreationTimeBefore?: Date; + NotebookInstanceLifecycleConfigArn?: string; /** - *

          The name of the image to list the versions of.

          + *

          The name of the lifecycle configuration.

          */ - ImageName: string | undefined; + NotebookInstanceLifecycleConfigName?: string; /** - *

          A filter that returns only versions modified on or after the specified time.

          + *

          The shell script that runs only once, when you create a notebook instance.

          */ - LastModifiedTimeAfter?: Date; + OnCreate?: NotebookInstanceLifecycleHook[]; /** - *

          A filter that returns only versions modified on or before the specified time.

          + *

          The shell script that runs every time you start a notebook instance, including when + * you create the notebook instance.

          */ - LastModifiedTimeBefore?: Date; + OnStart?: NotebookInstanceLifecycleHook[]; /** - *

          The maximum number of versions to return in the response. The default value is 10.

          + *

          A timestamp that tells when the lifecycle configuration was last modified.

          */ - MaxResults?: number; + LastModifiedTime?: Date; /** - *

          If the previous call to ListImageVersions didn't return the full set of - * versions, the call returns a token for getting the next set of versions.

          + *

          A timestamp that tells when the lifecycle configuration was created.

          */ - NextToken?: string; + CreationTime?: Date; +} - /** - *

          The property used to sort results. The default value is CREATION_TIME.

          - */ - SortBy?: ImageVersionSortBy | string; +export namespace DescribeNotebookInstanceLifecycleConfigOutput { + export const filterSensitiveLog = (obj: DescribeNotebookInstanceLifecycleConfigOutput): any => ({ + ...obj, + }); +} +export interface DescribePipelineRequest { /** - *

          The sort order. The default value is DESCENDING.

          + *

          The name of the pipeline to describe.

          */ - SortOrder?: ImageVersionSortOrder | string; + PipelineName: string | undefined; } -export namespace ListImageVersionsRequest { - export const filterSensitiveLog = (obj: ListImageVersionsRequest): any => ({ +export namespace DescribePipelineRequest { + export const filterSensitiveLog = (obj: DescribePipelineRequest): any => ({ ...obj, }); } -export interface ListImageVersionsResponse { +export enum PipelineStatus { + ACTIVE = "Active", +} + +export interface DescribePipelineResponse { /** - *

          A list of versions and their properties.

          + *

          The Amazon Resource Name (ARN) of the pipeline.

          */ - ImageVersions?: ImageVersion[]; + PipelineArn?: string; /** - *

          A token for getting the next set of versions, if there are any.

          + *

          The name of the pipeline.

          */ - NextToken?: string; -} - -export namespace ListImageVersionsResponse { - export const filterSensitiveLog = (obj: ListImageVersionsResponse): any => ({ - ...obj, - }); -} + PipelineName?: string; -export enum SortBy { - CREATION_TIME = "CreationTime", - NAME = "Name", - STATUS = "Status", -} + /** + *

          The display name of the pipeline.

          + */ + PipelineDisplayName?: string; -export interface ListLabelingJobsRequest { /** - *

          A filter that returns only labeling jobs created after the specified time - * (timestamp).

          + *

          The JSON pipeline definition.

          */ - CreationTimeAfter?: Date; + PipelineDefinition?: string; /** - *

          A filter that returns only labeling jobs created before the specified time - * (timestamp).

          + *

          The description of the pipeline.

          */ - CreationTimeBefore?: Date; + PipelineDescription?: string; /** - *

          A filter that returns only labeling jobs modified after the specified time - * (timestamp).

          + *

          The Amazon Resource Name (ARN) that the pipeline uses to execute.

          */ - LastModifiedTimeAfter?: Date; + RoleArn?: string; /** - *

          A filter that returns only labeling jobs modified before the specified time - * (timestamp).

          + *

          The status of the pipeline execution.

          */ - LastModifiedTimeBefore?: Date; + PipelineStatus?: PipelineStatus | string; /** - *

          The maximum number of labeling jobs to return in each page of the response.

          + *

          The time when the pipeline was created.

          */ - MaxResults?: number; + CreationTime?: Date; /** - *

          If the result of the previous ListLabelingJobs request was truncated, the - * response includes a NextToken. To retrieve the next set of labeling jobs, - * use the token in the next request.

          + *

          The time when the pipeline was last modified.

          */ - NextToken?: string; + LastModifiedTime?: Date; /** - *

          A string in the labeling job name. This filter returns only labeling jobs whose name - * contains the specified string.

          + *

          The time when the pipeline was last run.

          */ - NameContains?: string; + LastRunTime?: Date; /** - *

          The field to sort results by. The default is CreationTime.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - SortBy?: SortBy | string; + CreatedBy?: UserContext; /** - *

          The sort order for results. The default is Ascending.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - SortOrder?: SortOrder | string; + LastModifiedBy?: UserContext; +} +export namespace DescribePipelineResponse { + export const filterSensitiveLog = (obj: DescribePipelineResponse): any => ({ + ...obj, + }); +} + +export interface DescribePipelineDefinitionForExecutionRequest { /** - *

          A filter that retrieves only labeling jobs with a specific status.

          + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          */ - StatusEquals?: LabelingJobStatus | string; + PipelineExecutionArn: string | undefined; } -export namespace ListLabelingJobsRequest { - export const filterSensitiveLog = (obj: ListLabelingJobsRequest): any => ({ +export namespace DescribePipelineDefinitionForExecutionRequest { + export const filterSensitiveLog = (obj: DescribePipelineDefinitionForExecutionRequest): any => ({ ...obj, }); } -export interface ListLabelingJobsResponse { +export interface DescribePipelineDefinitionForExecutionResponse { /** - *

          An array of LabelingJobSummary objects, each describing a labeling - * job.

          + *

          The JSON pipeline definition.

          */ - LabelingJobSummaryList?: LabelingJobSummary[]; + PipelineDefinition?: string; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * labeling jobs, use it in the subsequent request.

          + *

          The time when the pipeline was created.

          */ - NextToken?: string; + CreationTime?: Date; } -export namespace ListLabelingJobsResponse { - export const filterSensitiveLog = (obj: ListLabelingJobsResponse): any => ({ +export namespace DescribePipelineDefinitionForExecutionResponse { + export const filterSensitiveLog = (obj: DescribePipelineDefinitionForExecutionResponse): any => ({ ...obj, }); } -export enum ListLabelingJobsForWorkteamSortByOptions { - CREATION_TIME = "CreationTime", +export interface DescribePipelineExecutionRequest { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn: string | undefined; +} + +export namespace DescribePipelineExecutionRequest { + export const filterSensitiveLog = (obj: DescribePipelineExecutionRequest): any => ({ + ...obj, + }); +} + +export enum PipelineExecutionStatus { + EXECUTING = "Executing", + FAILED = "Failed", + STOPPED = "Stopped", + STOPPING = "Stopping", + SUCCEEDED = "Succeeded", } -export interface ListLabelingJobsForWorkteamRequest { +export interface DescribePipelineExecutionResponse { /** - *

          The Amazon Resource Name (ARN) of the work team for which you want to see labeling - * jobs for.

          + *

          The Amazon Resource Name (ARN) of the pipeline.

          */ - WorkteamArn: string | undefined; + PipelineArn?: string; /** - *

          The maximum number of labeling jobs to return in each page of the response.

          + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          */ - MaxResults?: number; + PipelineExecutionArn?: string; /** - *

          If the result of the previous ListLabelingJobsForWorkteam request was - * truncated, the response includes a NextToken. To retrieve the next set of - * labeling jobs, use the token in the next request.

          + *

          The display name of the pipeline execution.

          */ - NextToken?: string; + PipelineExecutionDisplayName?: string; /** - *

          A filter that returns only labeling jobs created after the specified time - * (timestamp).

          + *

          The status of the pipeline execution.

          */ - CreationTimeAfter?: Date; + PipelineExecutionStatus?: PipelineExecutionStatus | string; /** - *

          A filter that returns only labeling jobs created before the specified time - * (timestamp).

          + *

          The description of the pipeline execution.

          */ - CreationTimeBefore?: Date; + PipelineExecutionDescription?: string; /** - *

          A filter the limits jobs to only the ones whose job reference code contains the - * specified string.

          + *

          The time when the pipeline execution was created.

          */ - JobReferenceCodeContains?: string; + CreationTime?: Date; /** - *

          The field to sort results by. The default is CreationTime.

          + *

          The time when the pipeline execution was modified last.

          */ - SortBy?: ListLabelingJobsForWorkteamSortByOptions | string; + LastModifiedTime?: Date; /** - *

          The sort order for results. The default is Ascending.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - SortOrder?: SortOrder | string; + CreatedBy?: UserContext; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; } -export namespace ListLabelingJobsForWorkteamRequest { - export const filterSensitiveLog = (obj: ListLabelingJobsForWorkteamRequest): any => ({ +export namespace DescribePipelineExecutionResponse { + export const filterSensitiveLog = (obj: DescribePipelineExecutionResponse): any => ({ ...obj, }); } -export interface ListLabelingJobsForWorkteamResponse { - /** - *

          An array of LabelingJobSummary objects, each describing a labeling - * job.

          - */ - LabelingJobSummaryList: LabelingJobForWorkteamSummary[] | undefined; - +export interface DescribeProcessingJobRequest { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * labeling jobs, use it in the subsequent request.

          + *

          The name of the processing job. The name must be unique within an AWS Region in the + * AWS account.

          */ - NextToken?: string; + ProcessingJobName: string | undefined; } -export namespace ListLabelingJobsForWorkteamResponse { - export const filterSensitiveLog = (obj: ListLabelingJobsForWorkteamResponse): any => ({ +export namespace DescribeProcessingJobRequest { + export const filterSensitiveLog = (obj: DescribeProcessingJobRequest): any => ({ ...obj, }); } -export enum ModelPackageSortBy { - CREATION_TIME = "CreationTime", - NAME = "Name", +export enum ProcessingJobStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", } -export interface ListModelPackagesInput { +export interface DescribeProcessingJobResponse { /** - *

          A filter that returns only model packages created after the specified time - * (timestamp).

          + *

          The inputs for a processing job.

          */ - CreationTimeAfter?: Date; + ProcessingInputs?: ProcessingInput[]; /** - *

          A filter that returns only model packages created before the specified time - * (timestamp).

          + *

          Output configuration for the processing job.

          */ - CreationTimeBefore?: Date; + ProcessingOutputConfig?: ProcessingOutputConfig; /** - *

          The maximum number of model packages to return in the response.

          + *

          The name of the processing job. The name must be unique within an AWS Region in the + * AWS account.

          */ - MaxResults?: number; + ProcessingJobName: string | undefined; /** - *

          A string in the model package name. This filter returns only model packages whose name - * contains the specified string.

          + *

          Identifies the resources, ML compute instances, and ML storage volumes to deploy for a + * processing job. In distributed training, you specify more than one instance.

          */ - NameContains?: string; + ProcessingResources: ProcessingResources | undefined; /** - *

          If the response to a previous ListModelPackages request was truncated, - * the response includes a NextToken. To retrieve the next set of model - * packages, use the token in the next request.

          + *

          The time limit for how long the processing job is allowed to run.

          */ - NextToken?: string; + StoppingCondition?: ProcessingStoppingCondition; /** - *

          The parameter by which to sort the results. The default is - * CreationTime.

          + *

          Configures the processing job to run a specified container image.

          */ - SortBy?: ModelPackageSortBy | string; + AppSpecification: AppSpecification | undefined; /** - *

          The sort order for the results. The default is Ascending.

          + *

          The environment variables set in the Docker container.

          */ - SortOrder?: SortOrder | string; -} - -export namespace ListModelPackagesInput { - export const filterSensitiveLog = (obj: ListModelPackagesInput): any => ({ - ...obj, - }); -} + Environment?: { [key: string]: string }; -/** - *

          Provides summary information about a model package.

          - */ -export interface ModelPackageSummary { /** - *

          The name of the model package.

          + *

          Networking options for a processing job.

          */ - ModelPackageName: string | undefined; + NetworkConfig?: NetworkConfig; /** - *

          The Amazon Resource Name (ARN) of the model package.

          + *

          The Amazon Resource Name (ARN) of an IAM role that Amazon SageMaker can assume to perform tasks on + * your behalf.

          */ - ModelPackageArn: string | undefined; + RoleArn?: string; /** - *

          A brief description of the model package.

          + *

          The configuration information used to create an experiment.

          */ - ModelPackageDescription?: string; + ExperimentConfig?: ExperimentConfig; /** - *

          A timestamp that shows when the model package was created.

          + *

          The Amazon Resource Name (ARN) of the processing job.

          */ - CreationTime: Date | undefined; + ProcessingJobArn: string | undefined; /** - *

          The overall status of the model package.

          + *

          Provides the status of a processing job.

          */ - ModelPackageStatus: ModelPackageStatus | string | undefined; -} - -export namespace ModelPackageSummary { - export const filterSensitiveLog = (obj: ModelPackageSummary): any => ({ - ...obj, - }); -} + ProcessingJobStatus: ProcessingJobStatus | string | undefined; -export interface ListModelPackagesOutput { /** - *

          An array of ModelPackageSummary objects, each of which lists a model - * package.

          + *

          An optional string, up to one KB in size, that contains metadata from the processing + * container when the processing job exits.

          */ - ModelPackageSummaryList: ModelPackageSummary[] | undefined; + ExitMessage?: string; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * model packages, use it in the subsequent request.

          + *

          A string, up to one KB in size, that contains the reason a processing job failed, if + * it failed.

          */ - NextToken?: string; -} - -export namespace ListModelPackagesOutput { - export const filterSensitiveLog = (obj: ListModelPackagesOutput): any => ({ - ...obj, - }); -} - -export enum ModelSortKey { - CreationTime = "CreationTime", - Name = "Name", -} + FailureReason?: string; -export interface ListModelsInput { /** - *

          Sorts the list of results. The default is CreationTime.

          + *

          The time at which the processing job completed.

          */ - SortBy?: ModelSortKey | string; + ProcessingEndTime?: Date; /** - *

          The sort order for results. The default is Descending.

          + *

          The time at which the processing job started.

          */ - SortOrder?: OrderKey | string; + ProcessingStartTime?: Date; /** - *

          If the response to a previous ListModels request was truncated, the - * response includes a NextToken. To retrieve the next set of models, use the - * token in the next request.

          + *

          The time at which the processing job was last modified.

          */ - NextToken?: string; + LastModifiedTime?: Date; /** - *

          The maximum number of models to return in the response.

          + *

          The time at which the processing job was created.

          */ - MaxResults?: number; + CreationTime: Date | undefined; /** - *

          A string in the training job name. This filter returns only models in the training - * job whose name contains the specified string.

          + *

          The ARN of a monitoring schedule for an endpoint associated with this processing + * job.

          */ - NameContains?: string; + MonitoringScheduleArn?: string; /** - *

          A filter that returns only models created before the specified time - * (timestamp).

          + *

          The ARN of an AutoML job associated with this processing job.

          */ - CreationTimeBefore?: Date; + AutoMLJobArn?: string; /** - *

          A filter that returns only models with a creation time greater than or equal to the - * specified time (timestamp).

          + *

          The ARN of a training job associated with this processing job.

          */ - CreationTimeAfter?: Date; + TrainingJobArn?: string; } -export namespace ListModelsInput { - export const filterSensitiveLog = (obj: ListModelsInput): any => ({ +export namespace DescribeProcessingJobResponse { + export const filterSensitiveLog = (obj: DescribeProcessingJobResponse): any => ({ ...obj, }); } -/** - *

          Provides summary information about a model.

          - */ -export interface ModelSummary { - /** - *

          The name of the model that you want a summary for.

          - */ - ModelName: string | undefined; - - /** - *

          The Amazon Resource Name (ARN) of the model.

          - */ - ModelArn: string | undefined; - +export interface DescribeProjectInput { /** - *

          A timestamp that indicates when the model was created.

          + *

          The name of the project to describe.

          */ - CreationTime: Date | undefined; + ProjectName: string | undefined; } -export namespace ModelSummary { - export const filterSensitiveLog = (obj: ModelSummary): any => ({ +export namespace DescribeProjectInput { + export const filterSensitiveLog = (obj: DescribeProjectInput): any => ({ ...obj, }); } -export interface ListModelsOutput { +export enum ProjectStatus { + CREATE_COMPLETED = "CreateCompleted", + CREATE_FAILED = "CreateFailed", + CREATE_IN_PROGRESS = "CreateInProgress", + DELETE_COMPLETED = "DeleteCompleted", + DELETE_FAILED = "DeleteFailed", + DELETE_IN_PROGRESS = "DeleteInProgress", + PENDING = "Pending", +} + +/** + *

          Details of a provisioned service catalog product. For information about service catalog, + * see What is AWS Service + * Catalog.

          + */ +export interface ServiceCatalogProvisionedProductDetails { /** - *

          An array of ModelSummary objects, each of which lists a - * model.

          + *

          The ID of the provisioned product.

          */ - Models: ModelSummary[] | undefined; + ProvisionedProductId?: string; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * models, use it in the subsequent request.

          + *

          The current status of the product.

          + *
            + *
          • + *

            + * AVAILABLE - Stable state, ready to perform any operation. The most recent operation succeeded and completed.

            + *
          • + *
          • + *

            + * UNDER_CHANGE - Transitive state. Operations performed might not have valid results. Wait for an AVAILABLE status before performing operations.

            + *
          • + *
          • + *

            + * TAINTED - Stable state, ready to perform any operation. The stack has completed the requested operation but is not exactly what was requested. For example, a request to update to a new version failed and the stack rolled back to the current version.

            + *
          • + *
          • + *

            + * ERROR - An unexpected error occurred. The provisioned product exists but the stack is not running. For example, CloudFormation received a parameter value that was not valid and could not launch the stack.

            + *
          • + *
          • + *

            + * PLAN_IN_PROGRESS - Transitive state. The plan operations were performed to provision a new product, but resources have not yet been created. After reviewing the list of resources to be created, execute the plan. Wait for an AVAILABLE status before performing operations.

            + *
          • + *
          */ - NextToken?: string; + ProvisionedProductStatusMessage?: string; } -export namespace ListModelsOutput { - export const filterSensitiveLog = (obj: ListModelsOutput): any => ({ +export namespace ServiceCatalogProvisionedProductDetails { + export const filterSensitiveLog = (obj: ServiceCatalogProvisionedProductDetails): any => ({ ...obj, }); } -export enum MonitoringExecutionSortKey { - CREATION_TIME = "CreationTime", - SCHEDULED_TIME = "ScheduledTime", - STATUS = "Status", -} +export interface DescribeProjectOutput { + /** + *

          The Amazon Resource Name (ARN) of the project.

          + */ + ProjectArn: string | undefined; -export interface ListMonitoringExecutionsRequest { /** - *

          Name of a specific schedule to fetch jobs for.

          + *

          The name of the project.

          */ - MonitoringScheduleName?: string; + ProjectName: string | undefined; /** - *

          Name of a specific endpoint to fetch jobs for.

          + *

          The ID of the project.

          */ - EndpointName?: string; + ProjectId: string | undefined; /** - *

          Whether to sort results by Status, CreationTime, - * ScheduledTime field. The default is CreationTime.

          + *

          The description of the project.

          */ - SortBy?: MonitoringExecutionSortKey | string; + ProjectDescription?: string; /** - *

          Whether to sort the results in Ascending or Descending order. - * The default is Descending.

          + *

          Information used to provision a service catalog product. For information, see What is AWS Service + * Catalog.

          */ - SortOrder?: SortOrder | string; + ServiceCatalogProvisioningDetails: ServiceCatalogProvisioningDetails | undefined; /** - *

          The token returned if the response is truncated. To retrieve the next set of job - * executions, use it in the next request.

          + *

          Information about a provisioned service catalog product.

          */ - NextToken?: string; + ServiceCatalogProvisionedProductDetails?: ServiceCatalogProvisionedProductDetails; /** - *

          The maximum number of jobs to return in the response. The default value is 10.

          + *

          The status of the project.

          */ - MaxResults?: number; + ProjectStatus: ProjectStatus | string | undefined; /** - *

          Filter for jobs scheduled before a specified time.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - ScheduledTimeBefore?: Date; + CreatedBy?: UserContext; /** - *

          Filter for jobs scheduled after a specified time.

          + *

          The time when the project was created.

          */ - ScheduledTimeAfter?: Date; + CreationTime: Date | undefined; +} +export namespace DescribeProjectOutput { + export const filterSensitiveLog = (obj: DescribeProjectOutput): any => ({ + ...obj, + }); +} + +export interface DescribeSubscribedWorkteamRequest { /** - *

          A filter that returns only jobs created before a specified time.

          + *

          The Amazon Resource Name (ARN) of the subscribed work team to describe.

          */ - CreationTimeBefore?: Date; + WorkteamArn: string | undefined; +} + +export namespace DescribeSubscribedWorkteamRequest { + export const filterSensitiveLog = (obj: DescribeSubscribedWorkteamRequest): any => ({ + ...obj, + }); +} +/** + *

          Describes a work team of a vendor that does the a labelling job.

          + */ +export interface SubscribedWorkteam { /** - *

          A filter that returns only jobs created after a specified time.

          + *

          The Amazon Resource Name (ARN) of the vendor that you have subscribed.

          */ - CreationTimeAfter?: Date; + WorkteamArn: string | undefined; + + /** + *

          The title of the service provided by the vendor in the Amazon Marketplace.

          + */ + MarketplaceTitle?: string; /** - *

          A filter that returns only jobs modified after a specified time.

          + *

          The name of the vendor in the Amazon Marketplace.

          */ - LastModifiedTimeBefore?: Date; + SellerName?: string; /** - *

          A filter that returns only jobs modified before a specified time.

          + *

          The description of the vendor from the Amazon Marketplace.

          */ - LastModifiedTimeAfter?: Date; + MarketplaceDescription?: string; /** - *

          A filter that retrieves only jobs with a specific status.

          + *

          Marketplace product listing ID.

          */ - StatusEquals?: ExecutionStatus | string; + ListingId?: string; } -export namespace ListMonitoringExecutionsRequest { - export const filterSensitiveLog = (obj: ListMonitoringExecutionsRequest): any => ({ +export namespace SubscribedWorkteam { + export const filterSensitiveLog = (obj: SubscribedWorkteam): any => ({ ...obj, }); } -export interface ListMonitoringExecutionsResponse { - /** - *

          A JSON array in which each element is a summary for a monitoring execution.

          - */ - MonitoringExecutionSummaries: MonitoringExecutionSummary[] | undefined; - +export interface DescribeSubscribedWorkteamResponse { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of jobs, - * use it in the subsequent reques

          + *

          A Workteam instance that contains information about the work team.

          */ - NextToken?: string; + SubscribedWorkteam: SubscribedWorkteam | undefined; } -export namespace ListMonitoringExecutionsResponse { - export const filterSensitiveLog = (obj: ListMonitoringExecutionsResponse): any => ({ +export namespace DescribeSubscribedWorkteamResponse { + export const filterSensitiveLog = (obj: DescribeSubscribedWorkteamResponse): any => ({ ...obj, }); } -export enum MonitoringScheduleSortKey { - CREATION_TIME = "CreationTime", - NAME = "Name", - STATUS = "Status", -} - -export interface ListMonitoringSchedulesRequest { +export interface DescribeTrainingJobRequest { /** - *

          Name of a specific endpoint to fetch schedules for.

          + *

          The name of the training job.

          */ - EndpointName?: string; + TrainingJobName: string | undefined; +} - /** - *

          Whether to sort results by Status, CreationTime, - * ScheduledTime field. The default is CreationTime.

          - */ - SortBy?: MonitoringScheduleSortKey | string; +export namespace DescribeTrainingJobRequest { + export const filterSensitiveLog = (obj: DescribeTrainingJobRequest): any => ({ + ...obj, + }); +} +/** + *

          The name, value, and date and time of a metric that was emitted to Amazon CloudWatch.

          + */ +export interface MetricData { /** - *

          Whether to sort the results in Ascending or Descending order. - * The default is Descending.

          + *

          The name of the metric.

          */ - SortOrder?: SortOrder | string; + MetricName?: string; /** - *

          The token returned if the response is truncated. To retrieve the next set of job - * executions, use it in the next request.

          + *

          The value of the metric.

          */ - NextToken?: string; + Value?: number; /** - *

          The maximum number of jobs to return in the response. The default value is 10.

          + *

          The date and time that the algorithm emitted the metric.

          */ - MaxResults?: number; + Timestamp?: Date; +} - /** - *

          Filter for monitoring schedules whose name contains a specified string.

          - */ - NameContains?: string; +export namespace MetricData { + export const filterSensitiveLog = (obj: MetricData): any => ({ + ...obj, + }); +} - /** - *

          A filter that returns only monitoring schedules created before a specified time.

          - */ - CreationTimeBefore?: Date; +export enum SecondaryStatus { + COMPLETED = "Completed", + DOWNLOADING = "Downloading", + DOWNLOADING_TRAINING_IMAGE = "DownloadingTrainingImage", + FAILED = "Failed", + INTERRUPTED = "Interrupted", + LAUNCHING_ML_INSTANCES = "LaunchingMLInstances", + MAX_RUNTIME_EXCEEDED = "MaxRuntimeExceeded", + MAX_WAIT_TIME_EXCEEDED = "MaxWaitTimeExceeded", + PREPARING_TRAINING_STACK = "PreparingTrainingStack", + STARTING = "Starting", + STOPPED = "Stopped", + STOPPING = "Stopping", + TRAINING = "Training", + UPDATING = "Updating", + UPLOADING = "Uploading", +} +/** + *

          An array element of DescribeTrainingJobResponse$SecondaryStatusTransitions. It provides + * additional details about a status that the training job has transitioned through. A + * training job can be in one of several states, for example, starting, downloading, + * training, or uploading. Within each state, there are a number of intermediate states. + * For example, within the starting state, Amazon SageMaker could be starting the training job or + * launching the ML instances. These transitional states are referred to as the job's + * secondary + * status. + *

          + *

          + */ +export interface SecondaryStatusTransition { /** - *

          A filter that returns only monitoring schedules created after a specified time.

          + *

          Contains a secondary status information from a training + * job.

          + *

          Status might be one of the following secondary statuses:

          + *
          + *
          InProgress
          + *
          + *
            + *
          • + *

            + * Starting + * - Starting the training job.

            + *
          • + *
          • + *

            + * Downloading - An optional stage for algorithms that + * support File training input mode. It indicates that + * data is being downloaded to the ML storage volumes.

            + *
          • + *
          • + *

            + * Training - Training is in progress.

            + *
          • + *
          • + *

            + * Uploading - Training is complete and the model + * artifacts are being uploaded to the S3 location.

            + *
          • + *
          + *
          + *
          Completed
          + *
          + *
            + *
          • + *

            + * Completed - The training job has completed.

            + *
          • + *
          + *
          + *
          Failed
          + *
          + *
            + *
          • + *

            + * Failed - The training job has failed. The reason for + * the failure is returned in the FailureReason field of + * DescribeTrainingJobResponse.

            + *
          • + *
          + *
          + *
          Stopped
          + *
          + *
            + *
          • + *

            + * MaxRuntimeExceeded - The job stopped because it + * exceeded the maximum allowed runtime.

            + *
          • + *
          • + *

            + * Stopped - The training job has stopped.

            + *
          • + *
          + *
          + *
          Stopping
          + *
          + *
            + *
          • + *

            + * Stopping - Stopping the training job.

            + *
          • + *
          + *
          + *
          + *

          We no longer support the following secondary statuses:

          + *
            + *
          • + *

            + * LaunchingMLInstances + *

            + *
          • + *
          • + *

            + * PreparingTrainingStack + *

            + *
          • + *
          • + *

            + * DownloadingTrainingImage + *

            + *
          • + *
          */ - CreationTimeAfter?: Date; + Status: SecondaryStatus | string | undefined; /** - *

          A filter that returns only monitoring schedules modified before a specified time.

          + *

          A timestamp that shows when the training job transitioned to the current secondary + * status state.

          */ - LastModifiedTimeBefore?: Date; + StartTime: Date | undefined; /** - *

          A filter that returns only monitoring schedules modified after a specified time.

          + *

          A timestamp that shows when the training job transitioned out of this secondary status + * state into another secondary status state or when the training job has ended.

          */ - LastModifiedTimeAfter?: Date; + EndTime?: Date; /** - *

          A filter that returns only monitoring schedules modified before a specified time.

          + *

          A detailed description of the progress within a secondary status. + *

          + *

          Amazon SageMaker provides secondary statuses and status messages that apply to each of + * them:

          + *
          + *
          Starting
          + *
          + *
            + *
          • + *

            Starting the training job.

            + *
          • + *
          • + *

            Launching + * requested ML instances.

            + *
          • + *
          • + *

            Insufficient + * capacity error from EC2 while launching instances, + * retrying!

            + *
          • + *
          • + *

            Launched + * instance was unhealthy, replacing it!

            + *
          • + *
          • + *

            Preparing the instances for training.

            + *
          • + *
          + *
          + *
          Training
          + *
          + *
            + *
          • + *

            Downloading the training image.

            + *
          • + *
          • + *

            Training + * image download completed. Training in + * progress.

            + *
          • + *
          + *
          + *
          + * + *

          Status messages are subject to change. Therefore, we recommend not including them + * in code that programmatically initiates actions. For examples, don't use status + * messages in if statements.

          + *
          + *

          To have an overview of your training job's progress, view + * TrainingJobStatus and SecondaryStatus in DescribeTrainingJob, and StatusMessage together. For + * example, at the start of a training job, you might see the following:

          + *
            + *
          • + *

            + * TrainingJobStatus - InProgress

            + *
          • + *
          • + *

            + * SecondaryStatus - Training

            + *
          • + *
          • + *

            + * StatusMessage - Downloading the training image

            + *
          • + *
          */ - StatusEquals?: ScheduleStatus | string; + StatusMessage?: string; } -export namespace ListMonitoringSchedulesRequest { - export const filterSensitiveLog = (obj: ListMonitoringSchedulesRequest): any => ({ +export namespace SecondaryStatusTransition { + export const filterSensitiveLog = (obj: SecondaryStatusTransition): any => ({ ...obj, }); } -/** - *

          Summarizes the monitoring schedule.

          - */ -export interface MonitoringScheduleSummary { - /** - *

          The name of the monitoring schedule.

          - */ - MonitoringScheduleName: string | undefined; - +export interface DescribeTrainingJobResponse { /** - *

          The Amazon Resource Name (ARN) of the monitoring schedule.

          + *

          Name of the model training job.

          */ - MonitoringScheduleArn: string | undefined; + TrainingJobName: string | undefined; /** - *

          The creation time of the monitoring schedule.

          + *

          The Amazon Resource Name (ARN) of the training job.

          */ - CreationTime: Date | undefined; + TrainingJobArn: string | undefined; /** - *

          The last time the monitoring schedule was modified.

          + *

          The Amazon Resource Name (ARN) of the associated hyperparameter tuning job if the + * training job was launched by a hyperparameter tuning job.

          */ - LastModifiedTime: Date | undefined; + TuningJobArn?: string; /** - *

          The status of the monitoring schedule.

          + *

          The Amazon Resource Name (ARN) of the Amazon SageMaker Ground Truth labeling job that created the + * transform or training job.

          */ - MonitoringScheduleStatus: ScheduleStatus | string | undefined; + LabelingJobArn?: string; /** - *

          The name of the endpoint using the monitoring schedule.

          + *

          The Amazon Resource Name (ARN) of an AutoML job.

          */ - EndpointName?: string; -} - -export namespace MonitoringScheduleSummary { - export const filterSensitiveLog = (obj: MonitoringScheduleSummary): any => ({ - ...obj, - }); -} + AutoMLJobArn?: string; -export interface ListMonitoringSchedulesResponse { /** - *

          A JSON array in which each element is a summary for a monitoring schedule.

          + *

          Information about the Amazon S3 location that is configured for storing model artifacts. + *

          */ - MonitoringScheduleSummaries: MonitoringScheduleSummary[] | undefined; + ModelArtifacts: ModelArtifacts | undefined; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of jobs, - * use it in the subsequent reques

          - */ - NextToken?: string; -} - -export namespace ListMonitoringSchedulesResponse { - export const filterSensitiveLog = (obj: ListMonitoringSchedulesResponse): any => ({ - ...obj, - }); -} - -export enum NotebookInstanceLifecycleConfigSortKey { - CREATION_TIME = "CreationTime", - LAST_MODIFIED_TIME = "LastModifiedTime", - NAME = "Name", -} - -export enum NotebookInstanceLifecycleConfigSortOrder { - ASCENDING = "Ascending", - DESCENDING = "Descending", -} + *

          The status of the + * training + * job.

          + *

          Amazon SageMaker provides the following training job statuses:

          + *
            + *
          • + *

            + * InProgress - The training is in progress.

            + *
          • + *
          • + *

            + * Completed - The training job has completed.

            + *
          • + *
          • + *

            + * Failed - The training job has failed. To see the reason for the + * failure, see the FailureReason field in the response to a + * DescribeTrainingJobResponse call.

            + *
          • + *
          • + *

            + * Stopping - The training job is stopping.

            + *
          • + *
          • + *

            + * Stopped - The training job has stopped.

            + *
          • + *
          + *

          For + * more detailed information, see SecondaryStatus.

          + */ + TrainingJobStatus: TrainingJobStatus | string | undefined; -export interface ListNotebookInstanceLifecycleConfigsInput { /** - *

          If the result of a ListNotebookInstanceLifecycleConfigs request was - * truncated, the response includes a NextToken. To get the next set of - * lifecycle configurations, use the token in the next request.

          + *

          Provides detailed information about the state of the training job. For detailed + * information on the secondary status of the training job, see StatusMessage + * under SecondaryStatusTransition.

          + *

          Amazon SageMaker provides primary statuses and secondary statuses that apply to each of + * them:

          + *
          + *
          InProgress
          + *
          + *
            + *
          • + *

            + * Starting + * - Starting the training job.

            + *
          • + *
          • + *

            + * Downloading - An optional stage for algorithms that + * support File training input mode. It indicates that + * data is being downloaded to the ML storage volumes.

            + *
          • + *
          • + *

            + * Training - Training is in progress.

            + *
          • + *
          • + *

            + * Interrupted - The job stopped because the managed + * spot training instances were interrupted.

            + *
          • + *
          • + *

            + * Uploading - Training is complete and the model + * artifacts are being uploaded to the S3 location.

            + *
          • + *
          + *
          + *
          Completed
          + *
          + *
            + *
          • + *

            + * Completed - The training job has completed.

            + *
          • + *
          + *
          + *
          Failed
          + *
          + *
            + *
          • + *

            + * Failed - The training job has failed. The reason for + * the failure is returned in the FailureReason field of + * DescribeTrainingJobResponse.

            + *
          • + *
          + *
          + *
          Stopped
          + *
          + *
            + *
          • + *

            + * MaxRuntimeExceeded - The job stopped because it + * exceeded the maximum allowed runtime.

            + *
          • + *
          • + *

            + * MaxWaitTimeExceeded - The job stopped because it + * exceeded the maximum allowed wait time.

            + *
          • + *
          • + *

            + * Stopped - The training job has stopped.

            + *
          • + *
          + *
          + *
          Stopping
          + *
          + *
            + *
          • + *

            + * Stopping - Stopping the training job.

            + *
          • + *
          + *
          + *
          + * + * + *

          Valid values for SecondaryStatus are subject to change.

          + *
          + *

          We no longer support the following secondary statuses:

          + *
            + *
          • + *

            + * LaunchingMLInstances + *

            + *
          • + *
          • + *

            + * PreparingTrainingStack + *

            + *
          • + *
          • + *

            + * DownloadingTrainingImage + *

            + *
          • + *
          */ - NextToken?: string; + SecondaryStatus: SecondaryStatus | string | undefined; /** - *

          The maximum number of lifecycle configurations to return in the response.

          + *

          If the training job failed, the reason it failed.

          */ - MaxResults?: number; + FailureReason?: string; /** - *

          Sorts the list of results. The default is CreationTime.

          + *

          Algorithm-specific parameters.

          */ - SortBy?: NotebookInstanceLifecycleConfigSortKey | string; + HyperParameters?: { [key: string]: string }; /** - *

          The sort order for results.

          + *

          Information about the algorithm used for training, and algorithm metadata. + *

          */ - SortOrder?: NotebookInstanceLifecycleConfigSortOrder | string; + AlgorithmSpecification: AlgorithmSpecification | undefined; /** - *

          A string in the lifecycle configuration name. This filter returns only lifecycle - * configurations whose name contains the specified string.

          + *

          The AWS Identity and Access Management (IAM) role configured for the training job.

          */ - NameContains?: string; + RoleArn?: string; /** - *

          A filter that returns only lifecycle configurations that were created before the - * specified time (timestamp).

          + *

          An array of Channel objects that describes each data input channel. + *

          */ - CreationTimeBefore?: Date; + InputDataConfig?: Channel[]; /** - *

          A filter that returns only lifecycle configurations that were created after the - * specified time (timestamp).

          + *

          The S3 path where model artifacts that you configured when creating the job are + * stored. Amazon SageMaker creates subfolders for model artifacts.

          */ - CreationTimeAfter?: Date; + OutputDataConfig?: OutputDataConfig; /** - *

          A filter that returns only lifecycle configurations that were modified before the - * specified time (timestamp).

          + *

          Resources, including ML compute instances and ML storage volumes, that are + * configured for model training.

          */ - LastModifiedTimeBefore?: Date; + ResourceConfig: ResourceConfig | undefined; /** - *

          A filter that returns only lifecycle configurations that were modified after the - * specified time (timestamp).

          + *

          A VpcConfig object that specifies the VPC that this training job has + * access to. For more information, see Protect Training Jobs by Using an Amazon + * Virtual Private Cloud.

          */ - LastModifiedTimeAfter?: Date; -} - -export namespace ListNotebookInstanceLifecycleConfigsInput { - export const filterSensitiveLog = (obj: ListNotebookInstanceLifecycleConfigsInput): any => ({ - ...obj, - }); -} + VpcConfig?: VpcConfig; -/** - *

          Provides a summary of a notebook instance lifecycle configuration.

          - */ -export interface NotebookInstanceLifecycleConfigSummary { /** - *

          The name of the lifecycle configuration.

          + *

          Specifies a limit to how long a model training job can run. It also specifies the + * maximum time to wait for a spot instance. When the job reaches the time limit, Amazon SageMaker ends + * the training job. Use this API to cap model training costs.

          + *

          To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays + * job termination for 120 seconds. Algorithms can use this 120-second window to save the + * model artifacts, so the results of training are not lost.

          */ - NotebookInstanceLifecycleConfigName: string | undefined; + StoppingCondition: StoppingCondition | undefined; /** - *

          The Amazon Resource Name (ARN) of the lifecycle configuration.

          + *

          A timestamp that indicates when the training job was created.

          */ - NotebookInstanceLifecycleConfigArn: string | undefined; + CreationTime: Date | undefined; /** - *

          A timestamp that tells when the lifecycle configuration was created.

          + *

          Indicates the time when the training job starts on training instances. You are + * billed for the time interval between this time and the value of + * TrainingEndTime. The start time in CloudWatch Logs might be later than this time. + * The difference is due to the time it takes to download the training data and to the size + * of the training container.

          */ - CreationTime?: Date; + TrainingStartTime?: Date; /** - *

          A timestamp that tells when the lifecycle configuration was last modified.

          + *

          Indicates the time when the training job ends on training instances. You are billed + * for the time interval between the value of TrainingStartTime and this time. + * For successful jobs and stopped jobs, this is the time after model artifacts are + * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

          */ - LastModifiedTime?: Date; -} - -export namespace NotebookInstanceLifecycleConfigSummary { - export const filterSensitiveLog = (obj: NotebookInstanceLifecycleConfigSummary): any => ({ - ...obj, - }); -} + TrainingEndTime?: Date; -export interface ListNotebookInstanceLifecycleConfigsOutput { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To get the next set of - * lifecycle configurations, use it in the next request.

          + *

          A timestamp that indicates when the status of the training job was last + * modified.

          */ - NextToken?: string; + LastModifiedTime?: Date; /** - *

          An array of NotebookInstanceLifecycleConfiguration objects, each listing - * a lifecycle configuration.

          + *

          A history of all of the secondary statuses that the training job has transitioned + * through.

          */ - NotebookInstanceLifecycleConfigs?: NotebookInstanceLifecycleConfigSummary[]; -} - -export namespace ListNotebookInstanceLifecycleConfigsOutput { - export const filterSensitiveLog = (obj: ListNotebookInstanceLifecycleConfigsOutput): any => ({ - ...obj, - }); -} - -export enum NotebookInstanceSortKey { - CREATION_TIME = "CreationTime", - NAME = "Name", - STATUS = "Status", -} - -export enum NotebookInstanceSortOrder { - ASCENDING = "Ascending", - DESCENDING = "Descending", -} + SecondaryStatusTransitions?: SecondaryStatusTransition[]; -export interface ListNotebookInstancesInput { /** - *

          If the previous call to the ListNotebookInstances is truncated, the - * response includes a NextToken. You can use this token in your subsequent - * ListNotebookInstances request to fetch the next set of notebook - * instances.

          - * - *

          You might specify a filter or a sort order in your request. When response is - * truncated, you must use the same values for the filer and sort order in the next - * request.

          - *
          + *

          A collection of MetricData objects that specify the names, values, and + * dates and times that the training algorithm emitted to Amazon CloudWatch.

          */ - NextToken?: string; + FinalMetricDataList?: MetricData[]; /** - *

          The maximum number of notebook instances to return.

          + *

          If you want to allow inbound or outbound network calls, except for calls between peers + * within a training cluster for distributed training, choose True. If you + * enable network isolation for training jobs that are configured to use a VPC, Amazon SageMaker + * downloads and uploads customer data and model artifacts through the specified VPC, but + * the training container does not have network access.

          */ - MaxResults?: number; + EnableNetworkIsolation?: boolean; /** - *

          The field to sort results by. The default is Name.

          + *

          To encrypt all communications between ML compute instances in distributed training, + * choose True. Encryption provides greater security for distributed training, + * but training might take longer. How long it takes depends on the amount of communication + * between compute instances, especially if you use a deep learning algorithms in + * distributed training.

          */ - SortBy?: NotebookInstanceSortKey | string; + EnableInterContainerTrafficEncryption?: boolean; /** - *

          The sort order for results.

          + *

          A Boolean indicating whether managed spot training is enabled (True) or + * not (False).

          */ - SortOrder?: NotebookInstanceSortOrder | string; + EnableManagedSpotTraining?: boolean; /** - *

          A string in the notebook instances' name. This filter returns only notebook - * instances whose name contains the specified string.

          + *

          Contains information about the output location for managed spot training checkpoint + * data.

          */ - NameContains?: string; + CheckpointConfig?: CheckpointConfig; /** - *

          A filter that returns only notebook instances that were created before the - * specified time (timestamp).

          + *

          The training time in seconds.

          */ - CreationTimeBefore?: Date; + TrainingTimeInSeconds?: number; /** - *

          A filter that returns only notebook instances that were created after the specified - * time (timestamp).

          + *

          The billable time in seconds.

          + *

          You can calculate the savings from using managed spot training using the formula + * (1 - BillableTimeInSeconds / TrainingTimeInSeconds) * 100. For example, + * if BillableTimeInSeconds is 100 and TrainingTimeInSeconds is + * 500, the savings is 80%.

          */ - CreationTimeAfter?: Date; + BillableTimeInSeconds?: number; /** - *

          A filter that returns only notebook instances that were modified before the - * specified time (timestamp).

          + *

          Configuration information for the debug hook parameters, collection configuration, and + * storage paths.

          */ - LastModifiedTimeBefore?: Date; + DebugHookConfig?: DebugHookConfig; /** - *

          A filter that returns only notebook instances that were modified after the - * specified time (timestamp).

          + *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

          + * */ - LastModifiedTimeAfter?: Date; + ExperimentConfig?: ExperimentConfig; /** - *

          A filter that returns only notebook instances with the specified status.

          + *

          Configuration information for debugging rules.

          */ - StatusEquals?: NotebookInstanceStatus | string; + DebugRuleConfigurations?: DebugRuleConfiguration[]; /** - *

          A string in the name of a notebook instances lifecycle configuration associated with - * this notebook instance. This filter returns only notebook instances associated with a - * lifecycle configuration with a name that contains the specified string.

          + *

          Configuration of storage locations for TensorBoard output.

          */ - NotebookInstanceLifecycleConfigNameContains?: string; + TensorBoardOutputConfig?: TensorBoardOutputConfig; /** - *

          A string in the name or URL of a Git repository associated with this notebook - * instance. This filter returns only notebook instances associated with a git repository - * with a name that contains the specified string.

          + *

          Status about the debug rule evaluation.

          */ - DefaultCodeRepositoryContains?: string; + DebugRuleEvaluationStatuses?: DebugRuleEvaluationStatus[]; +} +export namespace DescribeTrainingJobResponse { + export const filterSensitiveLog = (obj: DescribeTrainingJobResponse): any => ({ + ...obj, + }); +} + +export interface DescribeTransformJobRequest { /** - *

          A filter that returns only notebook instances with associated with the specified git - * repository.

          + *

          The name of the transform job that you want to view details of.

          */ - AdditionalCodeRepositoryEquals?: string; + TransformJobName: string | undefined; } -export namespace ListNotebookInstancesInput { - export const filterSensitiveLog = (obj: ListNotebookInstancesInput): any => ({ +export namespace DescribeTransformJobRequest { + export const filterSensitiveLog = (obj: DescribeTransformJobRequest): any => ({ ...obj, }); } -/** - *

          Provides summary information for an Amazon SageMaker notebook instance.

          - */ -export interface NotebookInstanceSummary { - /** - *

          The name of the notebook instance that you want a summary for.

          - */ - NotebookInstanceName: string | undefined; +export enum TransformJobStatus { + COMPLETED = "Completed", + FAILED = "Failed", + IN_PROGRESS = "InProgress", + STOPPED = "Stopped", + STOPPING = "Stopping", +} +export interface DescribeTransformJobResponse { /** - *

          The Amazon Resource Name (ARN) of the notebook instance.

          + *

          The name of the transform job.

          */ - NotebookInstanceArn: string | undefined; + TransformJobName: string | undefined; /** - *

          The status of the notebook instance.

          + *

          The Amazon Resource Name (ARN) of the transform job.

          */ - NotebookInstanceStatus?: NotebookInstanceStatus | string; + TransformJobArn: string | undefined; /** *

          The - * URL that you use to connect to the Jupyter instance running in your notebook instance. - *

          + * status of the transform job. If the transform job failed, the reason + * is returned in the FailureReason field.

          */ - Url?: string; + TransformJobStatus: TransformJobStatus | string | undefined; /** - *

          The type of ML compute instance that the notebook instance is running on.

          + *

          If the transform job failed, FailureReason describes + * why + * it failed. A transform job creates a log file, which includes error + * messages, and stores it + * as + * an Amazon S3 object. For more information, see Log Amazon SageMaker Events with + * Amazon CloudWatch.

          */ - InstanceType?: _InstanceType | string; + FailureReason?: string; /** - *

          A timestamp that shows when the notebook instance was created.

          + *

          The name of the model used in the transform job.

          */ - CreationTime?: Date; + ModelName: string | undefined; /** - *

          A timestamp that shows when the notebook instance was last modified.

          + *

          The + * maximum number + * of + * parallel requests on each instance node + * that can be launched in a transform job. The default value is 1.

          */ - LastModifiedTime?: Date; + MaxConcurrentTransforms?: number; /** - *

          The name of a notebook instance lifecycle configuration associated with this notebook - * instance.

          - *

          For information about notebook instance lifestyle configurations, see Step - * 2.1: (Optional) Customize a Notebook Instance.

          + *

          The timeout and maximum number of retries for processing a transform job + * invocation.

          */ - NotebookInstanceLifecycleConfigName?: string; + ModelClientConfig?: ModelClientConfig; /** - *

          The Git repository associated with the notebook instance as its default code - * repository. This can be either the name of a Git repository stored as a resource in your - * account, or the URL of a Git repository in AWS CodeCommit or in any - * other Git repository. When you open a notebook instance, it opens in the directory that - * contains this repository. For more information, see Associating Git Repositories with Amazon SageMaker - * Notebook Instances.

          + *

          The + * maximum + * payload size, in MB, used in the + * transform job.

          */ - DefaultCodeRepository?: string; + MaxPayloadInMB?: number; /** - *

          An array of up to three Git repositories associated with the notebook instance. These - * can be either the names of Git repositories stored as resources in your account, or the - * URL of Git repositories in AWS CodeCommit or in any - * other Git repository. These repositories are cloned at the same level as the default - * repository of your notebook instance. For more information, see Associating Git - * Repositories with Amazon SageMaker Notebook Instances.

          + *

          Specifies the number of records to include in a mini-batch for an HTTP inference + * request. + * A record + * is a single unit of input data that inference + * can be made on. For example, a single line in a CSV file is a record.

          + *

          To enable the batch strategy, you must set SplitType + * to + * Line, RecordIO, or + * TFRecord.

          */ - AdditionalCodeRepositories?: string[]; -} - -export namespace NotebookInstanceSummary { - export const filterSensitiveLog = (obj: NotebookInstanceSummary): any => ({ - ...obj, - }); -} + BatchStrategy?: BatchStrategy | string; -export interface ListNotebookInstancesOutput { /** - *

          If the response to the previous ListNotebookInstances request was - * truncated, Amazon SageMaker returns this token. To retrieve the next set of notebook instances, use - * the token in the next request.

          + *

          The + * environment variables to set in the Docker container. We support up to 16 key and values + * entries in the map.

          */ - NextToken?: string; + Environment?: { [key: string]: string }; /** - *

          An array of NotebookInstanceSummary objects, one for each notebook - * instance.

          + *

          Describes the dataset to be transformed and the Amazon S3 location where it is + * stored.

          */ - NotebookInstances?: NotebookInstanceSummary[]; -} - -export namespace ListNotebookInstancesOutput { - export const filterSensitiveLog = (obj: ListNotebookInstancesOutput): any => ({ - ...obj, - }); -} + TransformInput: TransformInput | undefined; -export interface ListProcessingJobsRequest { /** - *

          A filter that returns only processing jobs created after the specified time.

          + *

          Identifies the Amazon S3 location where you want Amazon SageMaker to save the results from the + * transform job.

          */ - CreationTimeAfter?: Date; + TransformOutput?: TransformOutput; /** - *

          A filter that returns only processing jobs created after the specified time.

          + *

          Describes + * the resources, including ML instance types and ML instance count, to + * use for the transform job.

          */ - CreationTimeBefore?: Date; + TransformResources: TransformResources | undefined; /** - *

          A filter that returns only processing jobs modified after the specified time.

          + *

          A timestamp that shows when the transform Job was created.

          */ - LastModifiedTimeAfter?: Date; + CreationTime: Date | undefined; /** - *

          A filter that returns only processing jobs modified before the specified time.

          + *

          Indicates when the transform job starts + * on + * ML instances. You are billed for the time interval between this time + * and the value of TransformEndTime.

          */ - LastModifiedTimeBefore?: Date; + TransformStartTime?: Date; /** - *

          A string in the processing job name. This filter returns only processing jobs whose - * name contains the specified string.

          + *

          Indicates when the transform job has been + * + * completed, or has stopped or failed. You are billed for the time + * interval between this time and the value of TransformStartTime.

          */ - NameContains?: string; + TransformEndTime?: Date; /** - *

          A filter that retrieves only processing jobs with a specific status.

          + *

          The Amazon Resource Name (ARN) of the Amazon SageMaker Ground Truth labeling job that created the + * transform or training job.

          */ - StatusEquals?: ProcessingJobStatus | string; + LabelingJobArn?: string; /** - *

          The field to sort results by. The default is CreationTime.

          + *

          The Amazon Resource Name (ARN) of the AutoML transform job.

          */ - SortBy?: SortBy | string; + AutoMLJobArn?: string; /** - *

          The sort order for results. The default is Ascending.

          + *

          The data structure used to specify the data to be used for inference in a batch + * transform job and to associate the data that is relevant to the prediction results in + * the output. The input filter provided allows you to exclude input data that is not + * needed for inference in a batch transform job. The output filter provided allows you to + * include input data relevant to interpreting the predictions in the output from the job. + * For more information, see Associate Prediction + * Results with their Corresponding Input Records.

          */ - SortOrder?: SortOrder | string; + DataProcessing?: DataProcessing; /** - *

          If the result of the previous ListProcessingJobs request was truncated, - * the response includes a NextToken. To retrieve the next set of processing - * jobs, use the token in the next request.

          + *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

          + * */ - NextToken?: string; + ExperimentConfig?: ExperimentConfig; +} + +export namespace DescribeTransformJobResponse { + export const filterSensitiveLog = (obj: DescribeTransformJobResponse): any => ({ + ...obj, + }); +} +export interface DescribeTrialRequest { /** - *

          The maximum number of processing jobs to return in the response.

          + *

          The name of the trial to describe.

          */ - MaxResults?: number; + TrialName: string | undefined; } -export namespace ListProcessingJobsRequest { - export const filterSensitiveLog = (obj: ListProcessingJobsRequest): any => ({ +export namespace DescribeTrialRequest { + export const filterSensitiveLog = (obj: DescribeTrialRequest): any => ({ ...obj, }); } /** - *

          Summary of information about a processing job.

          + *

          The source of the trial.

          */ -export interface ProcessingJobSummary { +export interface TrialSource { /** - *

          The name of the processing job.

          + *

          The Amazon Resource Name (ARN) of the source.

          */ - ProcessingJobName: string | undefined; + SourceArn: string | undefined; + + /** + *

          The source job type.

          + */ + SourceType?: string; +} + +export namespace TrialSource { + export const filterSensitiveLog = (obj: TrialSource): any => ({ + ...obj, + }); +} +export interface DescribeTrialResponse { /** - *

          The Amazon Resource Name (ARN) of the processing job..

          + *

          The name of the trial.

          */ - ProcessingJobArn: string | undefined; + TrialName?: string; /** - *

          The time at which the processing job was created.

          + *

          The Amazon Resource Name (ARN) of the trial.

          */ - CreationTime: Date | undefined; + TrialArn?: string; /** - *

          The time at which the processing job completed.

          + *

          The name of the trial as displayed. If DisplayName isn't specified, + * TrialName is displayed.

          */ - ProcessingEndTime?: Date; + DisplayName?: string; /** - *

          A timestamp that indicates the last time the processing job was modified.

          + *

          The name of the experiment the trial is part of.

          */ - LastModifiedTime?: Date; + ExperimentName?: string; /** - *

          The status of the processing job.

          + *

          The Amazon Resource Name (ARN) of the source and, optionally, the job type.

          */ - ProcessingJobStatus: ProcessingJobStatus | string | undefined; + Source?: TrialSource; /** - *

          A string, up to one KB in size, that contains the reason a processing job failed, if - * it failed.

          + *

          When the trial was created.

          */ - FailureReason?: string; + CreationTime?: Date; /** - *

          An optional string, up to one KB in size, that contains metadata from the processing - * container when the processing job exits.

          + *

          Who created the trial.

          */ - ExitMessage?: string; + CreatedBy?: UserContext; + + /** + *

          When the trial was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          Who last modified the trial.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          Metadata properties of the tracking entity, trial, or trial component.

          + */ + MetadataProperties?: MetadataProperties; } -export namespace ProcessingJobSummary { - export const filterSensitiveLog = (obj: ProcessingJobSummary): any => ({ +export namespace DescribeTrialResponse { + export const filterSensitiveLog = (obj: DescribeTrialResponse): any => ({ ...obj, }); } -export interface ListProcessingJobsResponse { - /** - *

          An array of ProcessingJobSummary objects, each listing a processing - * job.

          - */ - ProcessingJobSummaries: ProcessingJobSummary[] | undefined; - +export interface DescribeTrialComponentRequest { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * processing jobs, use it in the subsequent request.

          + *

          The name of the trial component to describe.

          */ - NextToken?: string; + TrialComponentName: string | undefined; } -export namespace ListProcessingJobsResponse { - export const filterSensitiveLog = (obj: ListProcessingJobsResponse): any => ({ +export namespace DescribeTrialComponentRequest { + export const filterSensitiveLog = (obj: DescribeTrialComponentRequest): any => ({ ...obj, }); } -export interface ListSubscribedWorkteamsRequest { +/** + *

          A summary of the metrics of a trial component.

          + */ +export interface TrialComponentMetricSummary { /** - *

          A string in the work team name. This filter returns only work teams whose name - * contains the specified string.

          + *

          The name of the metric.

          */ - NameContains?: string; + MetricName?: string; /** - *

          If the result of the previous ListSubscribedWorkteams request was - * truncated, the response includes a NextToken. To retrieve the next set of - * labeling jobs, use the token in the next request.

          + *

          The Amazon Resource Name (ARN) of the source.

          */ - NextToken?: string; + SourceArn?: string; /** - *

          The maximum number of work teams to return in each page of the response.

          + *

          When the metric was last updated.

          */ - MaxResults?: number; -} - -export namespace ListSubscribedWorkteamsRequest { - export const filterSensitiveLog = (obj: ListSubscribedWorkteamsRequest): any => ({ - ...obj, - }); -} + TimeStamp?: Date; -export interface ListSubscribedWorkteamsResponse { /** - *

          An array of Workteam objects, each describing a work team.

          + *

          The maximum value of the metric.

          */ - SubscribedWorkteams: SubscribedWorkteam[] | undefined; + Max?: number; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * work teams, use it in the subsequent request.

          + *

          The minimum value of the metric.

          */ - NextToken?: string; -} + Min?: number; -export namespace ListSubscribedWorkteamsResponse { - export const filterSensitiveLog = (obj: ListSubscribedWorkteamsResponse): any => ({ - ...obj, - }); -} + /** + *

          The most recent value of the metric.

          + */ + Last?: number; -export interface ListTagsInput { /** - *

          The Amazon Resource Name (ARN) of the resource whose tags you want to - * retrieve.

          + *

          The number of samples used to generate the metric.

          */ - ResourceArn: string | undefined; + Count?: number; /** - *

          If the response to the previous ListTags request is truncated, Amazon SageMaker - * returns this token. To retrieve the next set of tags, use it in the subsequent request. - *

          + *

          The average value of the metric.

          */ - NextToken?: string; + Avg?: number; /** - *

          Maximum number of tags to return.

          + *

          The standard deviation of the metric.

          */ - MaxResults?: number; + StdDev?: number; } -export namespace ListTagsInput { - export const filterSensitiveLog = (obj: ListTagsInput): any => ({ +export namespace TrialComponentMetricSummary { + export const filterSensitiveLog = (obj: TrialComponentMetricSummary): any => ({ ...obj, }); } -export interface ListTagsOutput { +/** + *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          + */ +export interface TrialComponentSource { /** - *

          An array of Tag objects, each with a tag key and a value.

          + *

          The source ARN.

          */ - Tags?: Tag[]; + SourceArn: string | undefined; /** - *

          If response is truncated, Amazon SageMaker includes a token in the response. You can use this - * token in your subsequent request to fetch next set of tokens.

          + *

          The source job type.

          */ - NextToken?: string; + SourceType?: string; } -export namespace ListTagsOutput { - export const filterSensitiveLog = (obj: ListTagsOutput): any => ({ +export namespace TrialComponentSource { + export const filterSensitiveLog = (obj: TrialComponentSource): any => ({ ...obj, }); } -export interface ListTrainingJobsRequest { +export interface DescribeTrialComponentResponse { /** - *

          If the result of the previous ListTrainingJobs request was truncated, - * the response includes a NextToken. To retrieve the next set of training - * jobs, use the token in the next request.

          + *

          The name of the trial component.

          */ - NextToken?: string; + TrialComponentName?: string; /** - *

          The maximum number of training jobs to return in the response.

          + *

          The Amazon Resource Name (ARN) of the trial component.

          */ - MaxResults?: number; + TrialComponentArn?: string; /** - *

          A filter that returns only training jobs created after the specified time - * (timestamp).

          + *

          The name of the component as displayed. If DisplayName isn't specified, + * TrialComponentName is displayed.

          */ - CreationTimeAfter?: Date; + DisplayName?: string; /** - *

          A filter that returns only training jobs created before the specified time - * (timestamp).

          + *

          The Amazon Resource Name (ARN) of the source and, optionally, the job type.

          */ - CreationTimeBefore?: Date; + Source?: TrialComponentSource; /** - *

          A filter that returns only training jobs modified after the specified time - * (timestamp).

          + *

          The status of the component. States include:

          + *
            + *
          • + *

            InProgress

            + *
          • + *
          • + *

            Completed

            + *
          • + *
          • + *

            Failed

            + *
          • + *
          */ - LastModifiedTimeAfter?: Date; + Status?: TrialComponentStatus; /** - *

          A filter that returns only training jobs modified before the specified time - * (timestamp).

          + *

          When the component started.

          */ - LastModifiedTimeBefore?: Date; + StartTime?: Date; /** - *

          A string in the training job name. This filter returns only training jobs whose - * name contains the specified string.

          + *

          When the component ended.

          */ - NameContains?: string; + EndTime?: Date; /** - *

          A filter that retrieves only training jobs with a specific status.

          + *

          When the component was created.

          */ - StatusEquals?: TrainingJobStatus | string; + CreationTime?: Date; /** - *

          The field to sort results by. The default is CreationTime.

          + *

          Who created the component.

          */ - SortBy?: SortBy | string; + CreatedBy?: UserContext; /** - *

          The sort order for results. The default is Ascending.

          + *

          When the component was last modified.

          */ - SortOrder?: SortOrder | string; -} - -export namespace ListTrainingJobsRequest { - export const filterSensitiveLog = (obj: ListTrainingJobsRequest): any => ({ - ...obj, - }); -} + LastModifiedTime?: Date; -/** - *

          Provides summary information about a training job.

          - */ -export interface TrainingJobSummary { /** - *

          The name of the training job that you want a summary for.

          + *

          Who last modified the component.

          */ - TrainingJobName: string | undefined; + LastModifiedBy?: UserContext; /** - *

          The Amazon Resource Name (ARN) of the training job.

          + *

          The hyperparameters of the component.

          */ - TrainingJobArn: string | undefined; + Parameters?: { [key: string]: TrialComponentParameterValue }; /** - *

          A timestamp that shows when the training job was created.

          + *

          The input artifacts of the component.

          */ - CreationTime: Date | undefined; + InputArtifacts?: { [key: string]: TrialComponentArtifact }; /** - *

          A timestamp that shows when the training job ended. This field is set only if the - * training job has one of the terminal statuses (Completed, - * Failed, or Stopped).

          + *

          The output artifacts of the component.

          */ - TrainingEndTime?: Date; + OutputArtifacts?: { [key: string]: TrialComponentArtifact }; /** - *

          Timestamp when the training job was last modified.

          + *

          Metadata properties of the tracking entity, trial, or trial component.

          */ - LastModifiedTime?: Date; + MetadataProperties?: MetadataProperties; /** - *

          The status of the training job.

          + *

          The metrics for the component.

          */ - TrainingJobStatus: TrainingJobStatus | string | undefined; + Metrics?: TrialComponentMetricSummary[]; } -export namespace TrainingJobSummary { - export const filterSensitiveLog = (obj: TrainingJobSummary): any => ({ +export namespace DescribeTrialComponentResponse { + export const filterSensitiveLog = (obj: DescribeTrialComponentResponse): any => ({ ...obj, + ...(obj.Parameters && { + Parameters: Object.entries(obj.Parameters).reduce( + (acc: any, [key, value]: [string, TrialComponentParameterValue]) => ({ + ...acc, + [key]: TrialComponentParameterValue.filterSensitiveLog(value), + }), + {} + ), + }), }); } -export interface ListTrainingJobsResponse { +export interface DescribeUserProfileRequest { /** - *

          An array of TrainingJobSummary objects, each listing a training - * job.

          + *

          The domain ID.

          */ - TrainingJobSummaries: TrainingJobSummary[] | undefined; + DomainId: string | undefined; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * training jobs, use it in the subsequent request.

          + *

          The user profile name.

          */ - NextToken?: string; + UserProfileName: string | undefined; } -export namespace ListTrainingJobsResponse { - export const filterSensitiveLog = (obj: ListTrainingJobsResponse): any => ({ +export namespace DescribeUserProfileRequest { + export const filterSensitiveLog = (obj: DescribeUserProfileRequest): any => ({ ...obj, }); } -export enum TrainingJobSortByOptions { - CreationTime = "CreationTime", - FinalObjectiveMetricValue = "FinalObjectiveMetricValue", - Name = "Name", - Status = "Status", +export enum UserProfileStatus { + Delete_Failed = "Delete_Failed", + Deleting = "Deleting", + Failed = "Failed", + InService = "InService", + Pending = "Pending", + Update_Failed = "Update_Failed", + Updating = "Updating", } -export interface ListTrainingJobsForHyperParameterTuningJobRequest { +export interface DescribeUserProfileResponse { /** - *

          The name of the tuning job whose training jobs you want to list.

          + *

          The ID of the domain that contains the profile.

          */ - HyperParameterTuningJobName: string | undefined; + DomainId?: string; /** - *

          If the result of the previous ListTrainingJobsForHyperParameterTuningJob - * request was truncated, the response includes a NextToken. To retrieve the - * next set of training jobs, use the token in the next request.

          + *

          The user profile Amazon Resource Name (ARN).

          */ - NextToken?: string; + UserProfileArn?: string; /** - *

          The maximum number of training jobs to return. The default value is 10.

          + *

          The user profile name.

          */ - MaxResults?: number; + UserProfileName?: string; /** - *

          A filter that returns only training jobs with the - * specified - * status.

          + *

          The ID of the user's profile in the Amazon Elastic File System (EFS) volume.

          */ - StatusEquals?: TrainingJobStatus | string; + HomeEfsFileSystemUid?: string; /** - *

          The field to sort - * results - * by. The default is Name.

          - *

          If the value of this field is FinalObjectiveMetricValue, any training - * jobs that did not return an objective metric are not listed.

          + *

          The status.

          */ - SortBy?: TrainingJobSortByOptions | string; + Status?: UserProfileStatus | string; /** - *

          The sort order - * for - * results. The default is Ascending.

          + *

          The last modified time.

          */ - SortOrder?: SortOrder | string; -} - -export namespace ListTrainingJobsForHyperParameterTuningJobRequest { - export const filterSensitiveLog = (obj: ListTrainingJobsForHyperParameterTuningJobRequest): any => ({ - ...obj, - }); -} + LastModifiedTime?: Date; -export interface ListTrainingJobsForHyperParameterTuningJobResponse { /** - *

          A list of TrainingJobSummary objects that - * describe - * the training jobs that the - * ListTrainingJobsForHyperParameterTuningJob request returned.

          + *

          The creation time.

          */ - TrainingJobSummaries: HyperParameterTrainingJobSummary[] | undefined; + CreationTime?: Date; /** - *

          If the result of this ListTrainingJobsForHyperParameterTuningJob request - * was truncated, the response includes a NextToken. To retrieve the next set - * of training jobs, use the token in the next request.

          + *

          The failure reason.

          */ - NextToken?: string; -} + FailureReason?: string; -export namespace ListTrainingJobsForHyperParameterTuningJobResponse { - export const filterSensitiveLog = (obj: ListTrainingJobsForHyperParameterTuningJobResponse): any => ({ - ...obj, - }); -} + /** + *

          The SSO user identifier.

          + */ + SingleSignOnUserIdentifier?: string; -export interface ListTransformJobsRequest { /** - *

          A filter that returns only transform jobs created after the specified time.

          + *

          The SSO user value.

          */ - CreationTimeAfter?: Date; + SingleSignOnUserValue?: string; /** - *

          A filter that returns only transform jobs created before the specified time.

          + *

          A collection of settings.

          */ - CreationTimeBefore?: Date; + UserSettings?: UserSettings; +} +export namespace DescribeUserProfileResponse { + export const filterSensitiveLog = (obj: DescribeUserProfileResponse): any => ({ + ...obj, + }); +} + +export interface DescribeWorkforceRequest { /** - *

          A filter that returns only transform jobs modified after the specified time.

          + *

          The name of the private workforce whose access you want to restrict. + * WorkforceName is automatically set to default when a + * workforce is created and cannot be modified.

          */ - LastModifiedTimeAfter?: Date; + WorkforceName: string | undefined; +} + +export namespace DescribeWorkforceRequest { + export const filterSensitiveLog = (obj: DescribeWorkforceRequest): any => ({ + ...obj, + }); +} +/** + *

          Your OIDC IdP workforce configuration.

          + */ +export interface OidcConfigForResponse { /** - *

          A filter that returns only transform jobs modified before the specified time.

          + *

          The OIDC IdP client ID used to configure your private workforce.

          */ - LastModifiedTimeBefore?: Date; + ClientId?: string; /** - *

          A string in the transform job name. This filter returns only transform jobs whose name - * contains the specified string.

          + *

          The OIDC IdP issuer used to configure your private workforce.

          */ - NameContains?: string; + Issuer?: string; /** - *

          A filter that retrieves only transform jobs with a specific status.

          + *

          The OIDC IdP authorization endpoint used to configure your private workforce.

          */ - StatusEquals?: TransformJobStatus | string; + AuthorizationEndpoint?: string; /** - *

          The field to sort results by. The default is CreationTime.

          + *

          The OIDC IdP token endpoint used to configure your private workforce.

          */ - SortBy?: SortBy | string; + TokenEndpoint?: string; /** - *

          The sort order for results. The default is Descending.

          + *

          The OIDC IdP user information endpoint used to configure your private workforce.

          */ - SortOrder?: SortOrder | string; + UserInfoEndpoint?: string; /** - *

          If the result of the previous ListTransformJobs request was truncated, - * the response includes a NextToken. To retrieve the next set of transform - * jobs, use the token in the next request.

          + *

          The OIDC IdP logout endpoint used to configure your private workforce.

          */ - NextToken?: string; + LogoutEndpoint?: string; /** - *

          The maximum number of - * transform - * jobs to return in the response. The default value is - * 10.

          + *

          The OIDC IdP JSON Web Key Set (Jwks) URI used to configure your private workforce.

          */ - MaxResults?: number; + JwksUri?: string; } -export namespace ListTransformJobsRequest { - export const filterSensitiveLog = (obj: ListTransformJobsRequest): any => ({ +export namespace OidcConfigForResponse { + export const filterSensitiveLog = (obj: OidcConfigForResponse): any => ({ ...obj, }); } /** - *

          Provides a - * summary - * of a transform job. Multiple TransformJobSummary objects are returned as a - * list after in response to a ListTransformJobs call.

          + *

          A single private workforce, which is automatically created when you create your first + * private work team. You can create one private work force in each AWS Region. By default, + * any workforce-related API operation used in a specific region will apply to the + * workforce created in that region. To learn how to create a private workforce, see Create a Private Workforce.

          */ -export interface TransformJobSummary { +export interface Workforce { /** - *

          The name of the transform job.

          + *

          The name of the private workforce.

          */ - TransformJobName: string | undefined; + WorkforceName: string | undefined; /** - *

          The Amazon Resource Name (ARN) of the transform job.

          + *

          The Amazon Resource Name (ARN) of the private workforce.

          */ - TransformJobArn: string | undefined; + WorkforceArn: string | undefined; /** - *

          A timestamp that shows when the transform Job was created.

          + *

          The most recent date that was used to + * successfully add one or more IP address ranges (CIDRs) to a private workforce's + * allow list.

          + */ + LastUpdatedDate?: Date; + + /** + *

          A list of one to ten IP address ranges (CIDRs) to be added to the + * workforce allow list. By default, a workforce isn't restricted to specific IP addresses.

          */ - CreationTime: Date | undefined; + SourceIpConfig?: SourceIpConfig; /** - *

          Indicates when the transform - * job - * ends on compute instances. For successful jobs and stopped jobs, this - * is the exact time - * recorded - * after the results are uploaded. For failed jobs, this is when Amazon SageMaker - * detected that the job failed.

          + *

          The subdomain for your OIDC Identity Provider.

          */ - TransformEndTime?: Date; + SubDomain?: string; /** - *

          Indicates when the transform job was last modified.

          + *

          The configuration of an Amazon Cognito workforce. + * A single Cognito workforce is created using and corresponds to a single + * + * Amazon Cognito user pool.

          */ - LastModifiedTime?: Date; + CognitoConfig?: CognitoConfig; /** - *

          The status of the transform job.

          + *

          The configuration of an OIDC Identity Provider (IdP) private workforce.

          */ - TransformJobStatus: TransformJobStatus | string | undefined; + OidcConfig?: OidcConfigForResponse; /** - *

          If the transform job failed, - * the - * reason it failed.

          + *

          The date that the workforce is created.

          */ - FailureReason?: string; + CreateDate?: Date; } -export namespace TransformJobSummary { - export const filterSensitiveLog = (obj: TransformJobSummary): any => ({ +export namespace Workforce { + export const filterSensitiveLog = (obj: Workforce): any => ({ ...obj, }); } -export interface ListTransformJobsResponse { +export interface DescribeWorkforceResponse { /** - *

          An array of - * TransformJobSummary - * objects.

          + *

          A single private workforce, which is automatically created when you create your first + * private work team. You can create one private work force in each AWS Region. By default, + * any workforce-related API operation used in a specific region will apply to the + * workforce created in that region. To learn how to create a private workforce, see Create a Private Workforce.

          */ - TransformJobSummaries: TransformJobSummary[] | undefined; + Workforce: Workforce | undefined; +} + +export namespace DescribeWorkforceResponse { + export const filterSensitiveLog = (obj: DescribeWorkforceResponse): any => ({ + ...obj, + }); +} +export interface DescribeWorkteamRequest { /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * transform jobs, use it in the next request.

          + *

          The name of the work team to return a description of.

          */ - NextToken?: string; + WorkteamName: string | undefined; } -export namespace ListTransformJobsResponse { - export const filterSensitiveLog = (obj: ListTransformJobsResponse): any => ({ +export namespace DescribeWorkteamRequest { + export const filterSensitiveLog = (obj: DescribeWorkteamRequest): any => ({ ...obj, }); } -export enum SortTrialComponentsBy { - CREATION_TIME = "CreationTime", - NAME = "Name", -} +/** + *

          Provides details about a labeling work team.

          + */ +export interface Workteam { + /** + *

          The name of the work team.

          + */ + WorkteamName: string | undefined; -export interface ListTrialComponentsRequest { /** - *

          A filter that returns only components that are part of the specified experiment. If you - * specify ExperimentName, you can't filter by SourceArn or - * TrialName.

          + *

          A list of MemberDefinition objects that contains objects that identify + * the workers that make up the work team.

          + *

          Workforces can be created using Amazon Cognito or your own OIDC Identity Provider (IdP). + * For private workforces created using Amazon Cognito use + * CognitoMemberDefinition. For workforces created using your own OIDC identity + * provider (IdP) use OidcMemberDefinition.

          */ - ExperimentName?: string; + MemberDefinitions: MemberDefinition[] | undefined; /** - *

          A filter that returns only components that are part of the specified trial. If you specify - * TrialName, you can't filter by ExperimentName or - * SourceArn.

          + *

          The Amazon Resource Name (ARN) that identifies the work team.

          */ - TrialName?: string; + WorkteamArn: string | undefined; /** - *

          A filter that returns only components that have the specified source Amazon Resource Name - * (ARN). If you specify SourceArn, you can't filter by ExperimentName - * or TrialName.

          + *

          The Amazon Resource Name (ARN) of the workforce.

          */ - SourceArn?: string; + WorkforceArn?: string; /** - *

          A filter that returns only components created after the specified time.

          + *

          The Amazon Marketplace identifier for a vendor's work team.

          */ - CreatedAfter?: Date; + ProductListingIds?: string[]; /** - *

          A filter that returns only components created before the specified time.

          + *

          A description of the work team.

          */ - CreatedBefore?: Date; + Description: string | undefined; /** - *

          The property used to sort results. The default value is CreationTime.

          + *

          The URI of the labeling job's user interface. Workers open this URI to start labeling + * your data objects.

          */ - SortBy?: SortTrialComponentsBy | string; + SubDomain?: string; /** - *

          The sort order. The default value is Descending.

          + *

          The date and time that the work team was created (timestamp).

          */ - SortOrder?: SortOrder | string; + CreateDate?: Date; /** - *

          The maximum number of components to return in the response. The default value is - * 10.

          + *

          The date and time that the work team was last updated (timestamp).

          */ - MaxResults?: number; + LastUpdatedDate?: Date; /** - *

          If the previous call to ListTrialComponents didn't return the full set of - * components, the call returns a token for getting the next set of components.

          + *

          Configures SNS notifications of available or expiring work items for work + * teams.

          */ - NextToken?: string; + NotificationConfiguration?: NotificationConfiguration; } -export namespace ListTrialComponentsRequest { - export const filterSensitiveLog = (obj: ListTrialComponentsRequest): any => ({ +export namespace Workteam { + export const filterSensitiveLog = (obj: Workteam): any => ({ ...obj, }); } -/** - *

          A summary of the properties of a trial component. To get all the properties, call the - * DescribeTrialComponent API and provide the - * TrialComponentName.

          - */ -export interface TrialComponentSummary { +export interface DescribeWorkteamResponse { /** - *

          The name of the trial component.

          + *

          A Workteam instance that contains information about the work team. + *

          */ - TrialComponentName?: string; + Workteam: Workteam | undefined; +} - /** - *

          The ARN of the trial component.

          - */ - TrialComponentArn?: string; +export namespace DescribeWorkteamResponse { + export const filterSensitiveLog = (obj: DescribeWorkteamResponse): any => ({ + ...obj, + }); +} +/** + *

          Specifies weight and capacity values for a production variant.

          + */ +export interface DesiredWeightAndCapacity { /** - *

          The name of the component as displayed. If DisplayName isn't specified, - * TrialComponentName is displayed.

          + *

          The name of the + * variant + * to update.

          */ - DisplayName?: string; + VariantName: string | undefined; /** - *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          + *

          The variant's weight.

          */ - TrialComponentSource?: TrialComponentSource; + DesiredWeight?: number; /** - *

          The status of the component. States include:

          - *
            - *
          • - *

            InProgress

            - *
          • - *
          • - *

            Completed

            - *
          • - *
          • - *

            Failed

            - *
          • - *
          + *

          The variant's capacity.

          */ - Status?: TrialComponentStatus; + DesiredInstanceCount?: number; +} - /** - *

          When the component started.

          - */ - StartTime?: Date; +export namespace DesiredWeightAndCapacity { + export const filterSensitiveLog = (obj: DesiredWeightAndCapacity): any => ({ + ...obj, + }); +} - /** - *

          When the component ended.

          - */ - EndTime?: Date; +export interface DisableSagemakerServicecatalogPortfolioInput {} - /** - *

          When the component was created.

          - */ - CreationTime?: Date; +export namespace DisableSagemakerServicecatalogPortfolioInput { + export const filterSensitiveLog = (obj: DisableSagemakerServicecatalogPortfolioInput): any => ({ + ...obj, + }); +} - /** - *

          Who created the component.

          - */ - CreatedBy?: UserContext; +export interface DisableSagemakerServicecatalogPortfolioOutput {} + +export namespace DisableSagemakerServicecatalogPortfolioOutput { + export const filterSensitiveLog = (obj: DisableSagemakerServicecatalogPortfolioOutput): any => ({ + ...obj, + }); +} +export interface DisassociateTrialComponentRequest { /** - *

          When the component was last modified.

          + *

          The name of the component to disassociate from the trial.

          */ - LastModifiedTime?: Date; + TrialComponentName: string | undefined; /** - *

          Who last modified the component.

          + *

          The name of the trial to disassociate from.

          */ - LastModifiedBy?: UserContext; + TrialName: string | undefined; } -export namespace TrialComponentSummary { - export const filterSensitiveLog = (obj: TrialComponentSummary): any => ({ +export namespace DisassociateTrialComponentRequest { + export const filterSensitiveLog = (obj: DisassociateTrialComponentRequest): any => ({ ...obj, }); } -export interface ListTrialComponentsResponse { +export interface DisassociateTrialComponentResponse { /** - *

          A list of the summaries of your trial components.

          + *

          The ARN of the trial component.

          */ - TrialComponentSummaries?: TrialComponentSummary[]; + TrialComponentArn?: string; /** - *

          A token for getting the next set of components, if there are any.

          + *

          The Amazon Resource Name (ARN) of the trial.

          */ - NextToken?: string; + TrialArn?: string; } -export namespace ListTrialComponentsResponse { - export const filterSensitiveLog = (obj: ListTrialComponentsResponse): any => ({ +export namespace DisassociateTrialComponentResponse { + export const filterSensitiveLog = (obj: DisassociateTrialComponentResponse): any => ({ ...obj, }); } -export enum SortTrialsBy { - CREATION_TIME = "CreationTime", - NAME = "Name", -} - -export interface ListTrialsRequest { +/** + *

          The domain's details.

          + */ +export interface DomainDetails { /** - *

          A filter that returns only trials that are part of the specified experiment.

          + *

          The domain's Amazon Resource Name (ARN).

          */ - ExperimentName?: string; + DomainArn?: string; /** - *

          A filter that returns only trials that are associated with the specified trial - * component.

          + *

          The domain ID.

          */ - TrialComponentName?: string; + DomainId?: string; /** - *

          A filter that returns only trials created after the specified time.

          + *

          The domain name.

          */ - CreatedAfter?: Date; + DomainName?: string; /** - *

          A filter that returns only trials created before the specified time.

          + *

          The status.

          */ - CreatedBefore?: Date; + Status?: DomainStatus | string; /** - *

          The property used to sort results. The default value is CreationTime.

          + *

          The creation time.

          */ - SortBy?: SortTrialsBy | string; + CreationTime?: Date; /** - *

          The sort order. The default value is Descending.

          + *

          The last modified time.

          */ - SortOrder?: SortOrder | string; + LastModifiedTime?: Date; /** - *

          The maximum number of trials to return in the response. The default value is 10.

          + *

          The domain's URL.

          */ - MaxResults?: number; + Url?: string; +} - /** - *

          If the previous call to ListTrials didn't return the full set of trials, the - * call returns a token for getting the next set of trials.

          - */ - NextToken?: string; +export namespace DomainDetails { + export const filterSensitiveLog = (obj: DomainDetails): any => ({ + ...obj, + }); } -export namespace ListTrialsRequest { - export const filterSensitiveLog = (obj: ListTrialsRequest): any => ({ +export interface EnableSagemakerServicecatalogPortfolioInput {} + +export namespace EnableSagemakerServicecatalogPortfolioInput { + export const filterSensitiveLog = (obj: EnableSagemakerServicecatalogPortfolioInput): any => ({ + ...obj, + }); +} + +export interface EnableSagemakerServicecatalogPortfolioOutput {} + +export namespace EnableSagemakerServicecatalogPortfolioOutput { + export const filterSensitiveLog = (obj: EnableSagemakerServicecatalogPortfolioOutput): any => ({ ...obj, }); } /** - *

          A summary of the properties of a trial. To get the complete set of properties, call the - * DescribeTrial API and provide the TrialName.

          + *

          A schedule for a model monitoring job. For information about model monitor, see + * Amazon SageMaker Model + * Monitor.

          */ -export interface TrialSummary { +export interface MonitoringSchedule { /** - *

          The Amazon Resource Name (ARN) of the trial.

          + *

          The Amazon Resource Name (ARN) of the monitoring schedule.

          */ - TrialArn?: string; + MonitoringScheduleArn?: string; /** - *

          The name of the trial.

          + *

          The name of the monitoring schedule.

          */ - TrialName?: string; + MonitoringScheduleName?: string; /** - *

          The name of the trial as displayed. If DisplayName isn't specified, - * TrialName is displayed.

          + *

          The status of the monitoring schedule. This can be one of the following values.

          + *
            + *
          • + *

            + * PENDING - The schedule is pending being created.

            + *
          • + *
          • + *

            + * FAILED - The schedule failed.

            + *
          • + *
          • + *

            + * SCHEDULED - The schedule was successfully created.

            + *
          • + *
          • + *

            + * STOPPED - The schedule was stopped.

            + *
          • + *
          */ - DisplayName?: string; + MonitoringScheduleStatus?: ScheduleStatus | string; /** - *

          The source of the trial.

          + *

          If the monitoring schedule failed, the reason it failed.

          */ - TrialSource?: TrialSource; + FailureReason?: string; /** - *

          When the trial was created.

          + *

          The time that the monitoring schedule was created.

          */ CreationTime?: Date; /** - *

          When the trial was last modified.

          + *

          The last time the monitoring schedule was changed.

          */ LastModifiedTime?: Date; -} -export namespace TrialSummary { - export const filterSensitiveLog = (obj: TrialSummary): any => ({ - ...obj, - }); -} + /** + *

          Configures the monitoring schedule and defines the monitoring job.

          + */ + MonitoringScheduleConfig?: MonitoringScheduleConfig; -export interface ListTrialsResponse { /** - *

          A list of the summaries of your trials.

          + *

          The endpoint that hosts the model being monitored.

          */ - TrialSummaries?: TrialSummary[]; + EndpointName?: string; /** - *

          A token for getting the next set of trials, if there are any.

          + *

          Summary of information about the last monitoring job to run.

          */ - NextToken?: string; + LastMonitoringExecutionSummary?: MonitoringExecutionSummary; + + /** + *

          A list of the tags associated with the monitoring schedlue. For more information, see Tagging AWS + * resources in the AWS General Reference Guide.

          + */ + Tags?: Tag[]; } -export namespace ListTrialsResponse { - export const filterSensitiveLog = (obj: ListTrialsResponse): any => ({ +export namespace MonitoringSchedule { + export const filterSensitiveLog = (obj: MonitoringSchedule): any => ({ ...obj, }); } -export enum UserProfileSortKey { - CreationTime = "CreationTime", - LastModifiedTime = "LastModifiedTime", -} - -export interface ListUserProfilesRequest { +/** + *

          A hosted endpoint for real-time inference.

          + */ +export interface Endpoint { /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          The name of the endpoint.

          */ - NextToken?: string; + EndpointName: string | undefined; /** - *

          Returns a list up to a specified limit.

          + *

          The Amazon Resource Name (ARN) of the endpoint.

          */ - MaxResults?: number; + EndpointArn: string | undefined; /** - *

          The sort order for the results. The default is Ascending.

          + *

          The endpoint configuration associated with the endpoint.

          */ - SortOrder?: SortOrder | string; + EndpointConfigName: string | undefined; /** - *

          The parameter by which to sort the results. The default is CreationTime.

          + *

          A list of the production variants hosted on the endpoint. Each production variant is a + * model.

          */ - SortBy?: UserProfileSortKey | string; + ProductionVariants?: ProductionVariantSummary[]; /** - *

          A parameter by which to filter the results.

          + *

          */ - DomainIdEquals?: string; + DataCaptureConfig?: DataCaptureConfigSummary; /** - *

          A parameter by which to filter the results.

          + *

          The status of the endpoint.

          */ - UserProfileNameContains?: string; -} - -export namespace ListUserProfilesRequest { - export const filterSensitiveLog = (obj: ListUserProfilesRequest): any => ({ - ...obj, - }); -} + EndpointStatus: EndpointStatus | string | undefined; -/** - *

          The user profile details.

          - */ -export interface UserProfileDetails { /** - *

          The domain ID.

          + *

          If the endpoint failed, the reason it failed.

          */ - DomainId?: string; + FailureReason?: string; /** - *

          The user profile name.

          + *

          The time that the endpoint was created.

          */ - UserProfileName?: string; + CreationTime: Date | undefined; /** - *

          The status.

          + *

          The last time the endpoint was modified.

          */ - Status?: UserProfileStatus | string; + LastModifiedTime: Date | undefined; /** - *

          The creation time.

          + *

          A list of monitoring schedules for the endpoint. For information about model + * monitoring, see Amazon SageMaker Model Monitor.

          */ - CreationTime?: Date; + MonitoringSchedules?: MonitoringSchedule[]; /** - *

          The last modified time.

          + *

          A list of the tags associated with the endpoint. For more information, see Tagging AWS + * resources in the AWS General Reference Guide.

          */ - LastModifiedTime?: Date; + Tags?: Tag[]; } -export namespace UserProfileDetails { - export const filterSensitiveLog = (obj: UserProfileDetails): any => ({ +export namespace Endpoint { + export const filterSensitiveLog = (obj: Endpoint): any => ({ ...obj, }); } -export interface ListUserProfilesResponse { +export enum EndpointConfigSortKey { + CreationTime = "CreationTime", + Name = "Name", +} + +/** + *

          Provides summary information for an endpoint configuration.

          + */ +export interface EndpointConfigSummary { /** - *

          The list of user profiles.

          + *

          The name of the endpoint configuration.

          */ - UserProfiles?: UserProfileDetails[]; + EndpointConfigName: string | undefined; /** - *

          If the previous response was truncated, you will receive this token. - * Use it in your next request to receive the next set of results.

          + *

          The Amazon Resource Name (ARN) of the endpoint configuration.

          */ - NextToken?: string; + EndpointConfigArn: string | undefined; + + /** + *

          A timestamp that shows when the endpoint configuration was created.

          + */ + CreationTime: Date | undefined; } -export namespace ListUserProfilesResponse { - export const filterSensitiveLog = (obj: ListUserProfilesResponse): any => ({ +export namespace EndpointConfigSummary { + export const filterSensitiveLog = (obj: EndpointConfigSummary): any => ({ ...obj, }); } -export enum ListWorkforcesSortByOptions { - CreateDate = "CreateDate", +export enum EndpointSortKey { + CreationTime = "CreationTime", Name = "Name", + Status = "Status", } -export interface ListWorkforcesRequest { +/** + *

          Provides summary information for an endpoint.

          + */ +export interface EndpointSummary { /** - *

          Sort workforces using the workforce name or creation date.

          + *

          The name of the endpoint.

          */ - SortBy?: ListWorkforcesSortByOptions | string; + EndpointName: string | undefined; /** - *

          Sort workforces in ascending or descending order.

          + *

          The Amazon Resource Name (ARN) of the endpoint.

          */ - SortOrder?: SortOrder | string; + EndpointArn: string | undefined; /** - *

          A filter you can use to search for workforces using part of the workforce name.

          + *

          A timestamp that shows when the endpoint was created.

          */ - NameContains?: string; + CreationTime: Date | undefined; /** - *

          A token to resume pagination.

          + *

          A timestamp that shows when the endpoint was last modified.

          */ - NextToken?: string; + LastModifiedTime: Date | undefined; /** - *

          The maximum number of workforces returned in the response.

          + *

          The status of the endpoint.

          + *
            + *
          • + *

            + * OutOfService: Endpoint is not available to take incoming + * requests.

            + *
          • + *
          • + *

            + * Creating: CreateEndpoint is executing.

            + *
          • + *
          • + *

            + * Updating: UpdateEndpoint or UpdateEndpointWeightsAndCapacities is executing.

            + *
          • + *
          • + *

            + * SystemUpdating: Endpoint is undergoing maintenance and cannot be + * updated or deleted or re-scaled until it has completed. This maintenance + * operation does not change any customer-specified values such as VPC config, KMS + * encryption, model, instance type, or instance count.

            + *
          • + *
          • + *

            + * RollingBack: Endpoint fails to scale up or down or change its + * variant weight and is in the process of rolling back to its previous + * configuration. Once the rollback completes, endpoint returns to an + * InService status. This transitional status only applies to an + * endpoint that has autoscaling enabled and is undergoing variant weight or + * capacity changes as part of an UpdateEndpointWeightsAndCapacities call or when the UpdateEndpointWeightsAndCapacities operation is called + * explicitly.

            + *
          • + *
          • + *

            + * InService: Endpoint is available to process incoming + * requests.

            + *
          • + *
          • + *

            + * Deleting: DeleteEndpoint is executing.

            + *
          • + *
          • + *

            + * Failed: Endpoint could not be created, updated, or re-scaled. Use + * DescribeEndpointOutput$FailureReason for information about + * the failure. DeleteEndpoint is the only operation that can be + * performed on a failed endpoint.

            + *
          • + *
          + *

          To get a list of endpoints with a specified status, use the ListEndpointsInput$StatusEquals filter.

          */ - MaxResults?: number; + EndpointStatus: EndpointStatus | string | undefined; } -export namespace ListWorkforcesRequest { - export const filterSensitiveLog = (obj: ListWorkforcesRequest): any => ({ +export namespace EndpointSummary { + export const filterSensitiveLog = (obj: EndpointSummary): any => ({ ...obj, }); } -export interface ListWorkforcesResponse { +/** + *

          The properties of an experiment as returned by the Search API.

          + */ +export interface Experiment { /** - *

          A list containing information about your workforce.

          + *

          The name of the experiment.

          */ - Workforces: Workforce[] | undefined; + ExperimentName?: string; /** - *

          A token to resume pagination.

          + *

          The Amazon Resource Name (ARN) of the experiment.

          */ - NextToken?: string; -} - -export namespace ListWorkforcesResponse { - export const filterSensitiveLog = (obj: ListWorkforcesResponse): any => ({ - ...obj, - }); -} - -export enum ListWorkteamsSortByOptions { - CreateDate = "CreateDate", - Name = "Name", -} + ExperimentArn?: string; -export interface ListWorkteamsRequest { /** - *

          The field to sort results by. The default is CreationTime.

          + *

          The name of the experiment as displayed. If DisplayName isn't specified, + * ExperimentName is displayed.

          */ - SortBy?: ListWorkteamsSortByOptions | string; + DisplayName?: string; /** - *

          The sort order for results. The default is Ascending.

          + *

          The source of the experiment.

          */ - SortOrder?: SortOrder | string; + Source?: ExperimentSource; /** - *

          A string in the work team's name. This filter returns only work teams whose name - * contains the specified string.

          + *

          The description of the experiment.

          */ - NameContains?: string; + Description?: string; /** - *

          If the result of the previous ListWorkteams request was truncated, the - * response includes a NextToken. To retrieve the next set of labeling jobs, - * use the token in the next request.

          + *

          When the experiment was created.

          */ - NextToken?: string; + CreationTime?: Date; /** - *

          The maximum number of work teams to return in each page of the response.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - MaxResults?: number; -} + CreatedBy?: UserContext; -export namespace ListWorkteamsRequest { - export const filterSensitiveLog = (obj: ListWorkteamsRequest): any => ({ - ...obj, - }); -} + /** + *

          When the experiment was last modified.

          + */ + LastModifiedTime?: Date; -export interface ListWorkteamsResponse { /** - *

          An array of Workteam objects, each describing a work team.

          + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          */ - Workteams: Workteam[] | undefined; + LastModifiedBy?: UserContext; /** - *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of - * work teams, use it in the subsequent request.

          + *

          The list of tags that are associated with the experiment. You can use Search API to search on the tags.

          */ - NextToken?: string; + Tags?: Tag[]; } -export namespace ListWorkteamsResponse { - export const filterSensitiveLog = (obj: ListWorkteamsResponse): any => ({ +export namespace Experiment { + export const filterSensitiveLog = (obj: Experiment): any => ({ ...obj, }); } /** - *

          A list of nested Filter objects. A resource must satisfy the conditions - * of all filters to be included in the results returned from the Search API.

          - *

          For example, to filter on a training job's InputDataConfig property with a - * specific channel name and S3Uri prefix, define the following filters:

          - *
            - *
          • - *

            - * '{Name:"InputDataConfig.ChannelName", "Operator":"Equals", "Value":"train"}', - *

            - *
          • - *
          • - *

            - * '{Name:"InputDataConfig.DataSource.S3DataSource.S3Uri", "Operator":"Contains", - * "Value":"mybucket/catdata"}' - *

            - *
          • - *
          + *

          A summary of the properties of an experiment. To get the complete set of properties, call + * the DescribeExperiment API and provide the + * ExperimentName.

          */ -export interface NestedFilters { +export interface ExperimentSummary { + /** + *

          The Amazon Resource Name (ARN) of the experiment.

          + */ + ExperimentArn?: string; + + /** + *

          The name of the experiment.

          + */ + ExperimentName?: string; + + /** + *

          The name of the experiment as displayed. If DisplayName isn't specified, + * ExperimentName is displayed.

          + */ + DisplayName?: string; + + /** + *

          The source of the experiment.

          + */ + ExperimentSource?: ExperimentSource; + /** - *

          The name of the property to use in the nested filters. The value must match a listed property name, - * such as InputDataConfig.

          + *

          When the experiment was created.

          */ - NestedPropertyName: string | undefined; + CreationTime?: Date; /** - *

          A list of filters. Each filter acts on a property. Filters must contain at least one - * Filters value. For example, a NestedFilters call might - * include a filter on the PropertyName parameter of the - * InputDataConfig property: - * InputDataConfig.DataSource.S3DataSource.S3Uri.

          + *

          When the experiment was last modified.

          */ - Filters: Filter[] | undefined; + LastModifiedTime?: Date; } -export namespace NestedFilters { - export const filterSensitiveLog = (obj: NestedFilters): any => ({ +export namespace ExperimentSummary { + export const filterSensitiveLog = (obj: ExperimentSummary): any => ({ ...obj, }); } /** - *

          The trial that a trial component is associated with and the experiment the trial is part - * of. A component might not be associated with a trial. A component can be associated with - * multiple trials.

          + *

          Amazon SageMaker Feature Store stores features in a collection called Feature Group. + * A Feature Group can be visualized as a table which has rows, + * with a unique identifier for each row where each column in the table is a feature. + * In principle, a Feature Group is composed of features and values per features.

          */ -export interface Parent { +export interface FeatureGroup { + /** + *

          The Amazon Resource Name (ARN) of a FeatureGroup.

          + */ + FeatureGroupArn?: string; + + /** + *

          The name of the FeatureGroup.

          + */ + FeatureGroupName?: string; + + /** + *

          The name of the Feature whose value uniquely identifies a + * Record defined in the FeatureGroup + * FeatureDefinitions.

          + */ + RecordIdentifierFeatureName?: string; + /** - *

          The name of the trial.

          + *

          The name of the feature that stores the EventTime of a Record in a + * FeatureGroup.

          + *

          A EventTime is point in time when a new event + * occurs that corresponds to the creation or update of a Record in + * FeatureGroup. All Records in the FeatureGroup + * must have a corresponding EventTime.

          */ - TrialName?: string; + EventTimeFeatureName?: string; /** - *

          The name of the experiment.

          + *

          A list of Features. Each Feature must include a + * FeatureName and a FeatureType.

          + *

          Valid FeatureTypes are Integral, Fractional and + * String.

          + *

          + * FeatureNames cannot be any of the following: is_deleted, + * write_time, api_invocation_time.

          + *

          You can create up to 2,500 FeatureDefinitions per + * FeatureGroup.

          */ - ExperimentName?: string; -} + FeatureDefinitions?: FeatureDefinition[]; -export namespace Parent { - export const filterSensitiveLog = (obj: Parent): any => ({ - ...obj, - }); -} + /** + *

          The time a FeatureGroup was created.

          + */ + CreationTime?: Date; -/** - *

          An Amazon SageMaker processing job that is used to analyze data and evaluate models. For more information, - * see Process - * Data and Evaluate Models.

          - */ -export interface ProcessingJob { /** - *

          For each input, data is downloaded from S3 into the processing container before the - * processing job begins running if "S3InputMode" is set to File.

          + *

          Use this to specify the AWS Key Management Service (KMS) Key ID, or + * KMSKeyId, for at rest data encryption. You can turn + * OnlineStore on or off by specifying the EnableOnlineStore flag + * at General Assembly; the default value is False.

          */ - ProcessingInputs?: ProcessingInput[]; + OnlineStoreConfig?: OnlineStoreConfig; /** - *

          The output configuration for the processing job.

          + *

          The configuration of an OfflineStore.

          + *

          Provide an OfflineStoreConfig in a request to + * CreateFeatureGroup to create an OfflineStore.

          + *

          To encrypt an OfflineStore using at rest data encryption, specify AWS Key + * Management Service (KMS) key ID, or KMSKeyId, in + * S3StorageConfig.

          */ - ProcessingOutputConfig?: ProcessingOutputConfig; + OfflineStoreConfig?: OfflineStoreConfig; /** - *

          The name of the processing job.

          + *

          The Amazon Resource Name (ARN) of the IAM execution role used to create the feature + * group.

          */ - ProcessingJobName?: string; + RoleArn?: string; /** - *

          Identifies the resources, ML compute instances, and ML storage volumes to deploy for a - * processing job. In distributed training, you specify more than one instance.

          + *

          A FeatureGroup status.

          */ - ProcessingResources?: ProcessingResources; + FeatureGroupStatus?: FeatureGroupStatus | string; /** - *

          Specifies a time limit for how long the processing job is allowed to run.

          + *

          The status of OfflineStore.

          */ - StoppingCondition?: ProcessingStoppingCondition; + OfflineStoreStatus?: OfflineStoreStatus; /** - *

          Configuration to run a processing job in a specified container image.

          + *

          The reason that the FeatureGroup failed to + * be replicated in the OfflineStore. This is + * failure may be due to a failure to create a FeatureGroup in + * or delete a FeatureGroup from the OfflineStore.

          */ - AppSpecification?: AppSpecification; + FailureReason?: string; /** - *

          Sets the environment variables in the Docker container.

          + *

          A free form description of a FeatureGroup.

          */ - Environment?: { [key: string]: string }; + Description?: string; /** - *

          Networking options for a job, such as network traffic encryption between containers, - * whether to allow inbound and outbound network calls to and from containers, and the VPC - * subnets and security groups to use for VPC-enabled jobs.

          + *

          Tags used to define a FeatureGroup.

          */ - NetworkConfig?: NetworkConfig; + Tags?: Tag[]; +} + +export namespace FeatureGroup { + export const filterSensitiveLog = (obj: FeatureGroup): any => ({ + ...obj, + }); +} + +export enum FeatureGroupSortBy { + CREATION_TIME = "CreationTime", + FEATURE_GROUP_STATUS = "FeatureGroupStatus", + NAME = "Name", + OFFLINE_STORE_STATUS = "OfflineStoreStatus", +} + +export enum FeatureGroupSortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} +/** + *

          The name, Arn, CreationTime, FeatureGroup values, + * LastUpdatedTime and EnableOnlineStorage status of a + * FeatureGroup.

          + */ +export interface FeatureGroupSummary { /** - *

          The ARN of the role used to create the processing job.

          + *

          The name of FeatureGroup.

          */ - RoleArn?: string; + FeatureGroupName: string | undefined; /** - *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

          - * + *

          Unique identifier for the FeatureGroup.

          */ - ExperimentConfig?: ExperimentConfig; + FeatureGroupArn: string | undefined; /** - *

          The ARN of the processing job.

          + *

          A timestamp indicating the time of creation time of the FeatureGroup.

          */ - ProcessingJobArn?: string; + CreationTime: Date | undefined; /** - *

          The status of the processing job.

          + *

          The status of a FeatureGroup. The status can be any of the following: + * Creating, Created, CreateFail, + * Deleting or DetailFail.

          */ - ProcessingJobStatus?: ProcessingJobStatus | string; + FeatureGroupStatus?: FeatureGroupStatus | string; /** - *

          A string, up to one KB in size, that contains metadata from the processing - * container when the processing job exits.

          + *

          Notifies you if replicating data into the OfflineStore has failed. Returns + * either: Active or Blocked.

          */ - ExitMessage?: string; + OfflineStoreStatus?: OfflineStoreStatus; +} + +export namespace FeatureGroupSummary { + export const filterSensitiveLog = (obj: FeatureGroupSummary): any => ({ + ...obj, + }); +} + +export enum Operator { + CONTAINS = "Contains", + EQUALS = "Equals", + EXISTS = "Exists", + GREATER_THAN = "GreaterThan", + GREATER_THAN_OR_EQUAL_TO = "GreaterThanOrEqualTo", + IN = "In", + LESS_THAN = "LessThan", + LESS_THAN_OR_EQUAL_TO = "LessThanOrEqualTo", + NOT_EQUALS = "NotEquals", + NOT_EXISTS = "NotExists", +} +/** + *

          A conditional statement for a search expression that includes a resource property, a + * Boolean operator, and a value. Resources that match the statement are returned in the + * results from the Search API.

          + * + *

          If you specify a Value, but not an Operator, Amazon SageMaker uses the + * equals operator.

          + *

          In search, there are several property types:

          + *
          + *
          Metrics
          + *
          + *

          To define a metric filter, enter a value using the form + * "Metrics.", where is + * a metric name. For example, the following filter searches for training jobs + * with an "accuracy" metric greater than + * "0.9":

          + *

          + * { + *

          + *

          + * "Name": "Metrics.accuracy", + *

          + *

          + * "Operator": "GreaterThan", + *

          + *

          + * "Value": "0.9" + *

          + *

          + * } + *

          + *
          + *
          HyperParameters
          + *
          + *

          To define a hyperparameter filter, enter a value with the form + * "HyperParameters.". Decimal hyperparameter + * values are treated as a decimal in a comparison if the specified + * Value is also a decimal value. If the specified + * Value is an integer, the decimal hyperparameter values are + * treated as integers. For example, the following filter is satisfied by + * training jobs with a "learning_rate" hyperparameter that is + * less than "0.5":

          + *

          + * { + *

          + *

          + * "Name": "HyperParameters.learning_rate", + *

          + *

          + * "Operator": "LessThan", + *

          + *

          + * "Value": "0.5" + *

          + *

          + * } + *

          + *
          + *
          Tags
          + *
          + *

          To define a tag filter, enter a value with the form + * Tags..

          + *
          + *
          + */ +export interface Filter { /** - *

          A string, up to one KB in size, that contains the reason a processing job failed, if - * it failed.

          + *

          A resource property name. For example, TrainingJobName. For + * valid property names, see SearchRecord. + * You must specify a valid property for the resource.

          */ - FailureReason?: string; + Name: string | undefined; /** - *

          The time that the processing job ended.

          + *

          A Boolean binary operator that is used to evaluate the filter. The operator field + * contains one of the following values:

          + *
          + *
          Equals
          + *
          + *

          The value of Name equals Value.

          + *
          + *
          NotEquals
          + *
          + *

          The value of Name doesn't equal Value.

          + *
          + *
          Exists
          + *
          + *

          The Name property exists.

          + *
          + *
          NotExists
          + *
          + *

          The Name property does not exist.

          + *
          + *
          GreaterThan
          + *
          + *

          The value of Name is greater than Value. + * Not supported for text properties.

          + *
          + *
          GreaterThanOrEqualTo
          + *
          + *

          The value of Name is greater than or equal to Value. + * Not supported for text properties.

          + *
          + *
          LessThan
          + *
          + *

          The value of Name is less than Value. + * Not supported for text properties.

          + *
          + *
          LessThanOrEqualTo
          + *
          + *

          The value of Name is less than or equal to Value. + * Not supported for text properties.

          + *
          + *
          In
          + *
          + *

          The value of Name is one of the comma delimited strings in + * Value. Only supported for text properties.

          + *
          + *
          Contains
          + *
          + *

          The value of Name contains the string Value. + * Only supported for text properties.

          + *

          A SearchExpression can include the Contains operator + * multiple times when the value of Name is one of the following:

          + *
            + *
          • + *

            + * Experiment.DisplayName + *

            + *
          • + *
          • + *

            + * Experiment.ExperimentName + *

            + *
          • + *
          • + *

            + * Experiment.Tags + *

            + *
          • + *
          • + *

            + * Trial.DisplayName + *

            + *
          • + *
          • + *

            + * Trial.TrialName + *

            + *
          • + *
          • + *

            + * Trial.Tags + *

            + *
          • + *
          • + *

            + * TrialComponent.DisplayName + *

            + *
          • + *
          • + *

            + * TrialComponent.TrialComponentName + *

            + *
          • + *
          • + *

            + * TrialComponent.Tags + *

            + *
          • + *
          • + *

            + * TrialComponent.InputArtifacts + *

            + *
          • + *
          • + *

            + * TrialComponent.OutputArtifacts + *

            + *
          • + *
          + *

          A SearchExpression can include only one Contains operator + * for all other values of Name. In these cases, if you include multiple + * Contains operators in the SearchExpression, the result is + * the following error message: "'CONTAINS' operator usage limit of 1 + * exceeded."

          + *
          + *
          */ - ProcessingEndTime?: Date; + Operator?: Operator | string; /** - *

          The time that the processing job started.

          + *

          A value used with Name and Operator to determine which + * resources satisfy the filter's condition. For numerical properties, Value + * must be an integer or floating-point decimal. For timestamp properties, + * Value must be an ISO 8601 date-time string of the following format: + * YYYY-mm-dd'T'HH:MM:SS.

          */ - ProcessingStartTime?: Date; + Value?: string; +} - /** - *

          The time the processing job was last modified.

          - */ - LastModifiedTime?: Date; +export namespace Filter { + export const filterSensitiveLog = (obj: Filter): any => ({ + ...obj, + }); +} +/** + *

          Contains summary information about the flow definition.

          + */ +export interface FlowDefinitionSummary { /** - *

          The time the processing job was created.

          + *

          The name of the flow definition.

          */ - CreationTime?: Date; + FlowDefinitionName: string | undefined; /** - *

          The ARN of a monitoring schedule for an endpoint associated with this processing - * job.

          + *

          The Amazon Resource Name (ARN) of the flow definition.

          */ - MonitoringScheduleArn?: string; + FlowDefinitionArn: string | undefined; /** - *

          The Amazon Resource Name (ARN) of the AutoML job associated with this processing job.

          + *

          The status of the flow definition. Valid values:

          */ - AutoMLJobArn?: string; + FlowDefinitionStatus: FlowDefinitionStatus | string | undefined; /** - *

          The ARN of the training job associated with this processing job.

          + *

          The timestamp when SageMaker created the flow definition.

          */ - TrainingJobArn?: string; + CreationTime: Date | undefined; /** - *

          An array of key-value pairs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management - * User Guide.

          + *

          The reason why the flow definition creation failed. A failure reason is returned only when the flow definition status is Failed.

          */ - Tags?: Tag[]; + FailureReason?: string; } -export namespace ProcessingJob { - export const filterSensitiveLog = (obj: ProcessingJob): any => ({ +export namespace FlowDefinitionSummary { + export const filterSensitiveLog = (obj: FlowDefinitionSummary): any => ({ ...obj, }); } -/** - *

          Contains input values for a task.

          - */ -export interface RenderableTask { +export interface GetModelPackageGroupPolicyInput { /** - *

          A JSON object that contains values for the variables defined in the template. It is - * made available to the template under the substitution variable task.input. - * For example, if you define a variable task.input.text in your template, you - * can supply the variable in the JSON object as "text": "sample text".

          + *

          The name of the model group for which to get the resource policy.

          */ - Input: string | undefined; + ModelPackageGroupName: string | undefined; } -export namespace RenderableTask { - export const filterSensitiveLog = (obj: RenderableTask): any => ({ +export namespace GetModelPackageGroupPolicyInput { + export const filterSensitiveLog = (obj: GetModelPackageGroupPolicyInput): any => ({ ...obj, }); } -/** - *

          A description of an error that occurred while rendering the template.

          - */ -export interface RenderingError { - /** - *

          A unique identifier for a specific class of errors.

          - */ - Code: string | undefined; - +export interface GetModelPackageGroupPolicyOutput { /** - *

          A human-readable message describing the error.

          + *

          The resource policy for the model group.

          */ - Message: string | undefined; + ResourcePolicy: string | undefined; } -export namespace RenderingError { - export const filterSensitiveLog = (obj: RenderingError): any => ({ +export namespace GetModelPackageGroupPolicyOutput { + export const filterSensitiveLog = (obj: GetModelPackageGroupPolicyOutput): any => ({ ...obj, }); } -export interface RenderUiTemplateRequest { - /** - *

          A Template object containing the worker UI template to render.

          - */ - UiTemplate?: UiTemplate; - - /** - *

          A RenderableTask object containing a representative task to - * render.

          - */ - Task: RenderableTask | undefined; - - /** - *

          The Amazon Resource Name (ARN) that has access to the S3 objects that are used by the - * template.

          - */ - RoleArn: string | undefined; - - /** - *

          The HumanTaskUiArn of the worker UI that you want to render. Do not - * provide a HumanTaskUiArn if you use the UiTemplate - * parameter.

          - *

          See a list of available Human Ui Amazon Resource Names (ARNs) in UiConfig.

          - */ - HumanTaskUiArn?: string; -} +export interface GetSagemakerServicecatalogPortfolioStatusInput {} -export namespace RenderUiTemplateRequest { - export const filterSensitiveLog = (obj: RenderUiTemplateRequest): any => ({ +export namespace GetSagemakerServicecatalogPortfolioStatusInput { + export const filterSensitiveLog = (obj: GetSagemakerServicecatalogPortfolioStatusInput): any => ({ ...obj, }); } -export interface RenderUiTemplateResponse { - /** - *

          A Liquid template that renders the HTML for the worker UI.

          - */ - RenderedContent: string | undefined; +export enum SagemakerServicecatalogStatus { + DISABLED = "Disabled", + ENABLED = "Enabled", +} +export interface GetSagemakerServicecatalogPortfolioStatusOutput { /** - *

          A list of one or more RenderingError objects if any were encountered - * while rendering the template. If there were no errors, the list is empty.

          + *

          Whether Service Catalog is enabled or disabled in SageMaker.

          */ - Errors: RenderingError[] | undefined; + Status?: SagemakerServicecatalogStatus | string; } -export namespace RenderUiTemplateResponse { - export const filterSensitiveLog = (obj: RenderUiTemplateResponse): any => ({ +export namespace GetSagemakerServicecatalogPortfolioStatusOutput { + export const filterSensitiveLog = (obj: GetSagemakerServicecatalogPortfolioStatusOutput): any => ({ ...obj, }); } -export enum SearchSortOrder { - ASCENDING = "Ascending", - DESCENDING = "Descending", +export enum ResourceType { + ENDPOINT = "Endpoint", + EXPERIMENT = "Experiment", + EXPERIMENT_TRIAL = "ExperimentTrial", + EXPERIMENT_TRIAL_COMPONENT = "ExperimentTrialComponent", + FEATURE_GROUP = "FeatureGroup", + MODEL_PACKAGE = "ModelPackage", + MODEL_PACKAGE_GROUP = "ModelPackageGroup", + PIPELINE = "Pipeline", + PIPELINE_EXECUTION = "PipelineExecution", + TRAINING_JOB = "TrainingJob", } /** - *

          Contains information about a training job.

          + *

          Part of the SuggestionQuery type. Specifies a hint for retrieving property + * names that begin with the specified text.

          */ -export interface TrainingJob { - /** - *

          The name of the training job.

          - */ - TrainingJobName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the training job.

          - */ - TrainingJobArn?: string; - - /** - *

          The Amazon Resource Name (ARN) of the associated hyperparameter tuning job if the - * training job was launched by a hyperparameter tuning job.

          - */ - TuningJobArn?: string; - - /** - *

          The Amazon Resource Name (ARN) of the labeling job.

          - */ - LabelingJobArn?: string; - - /** - *

          The Amazon Resource Name (ARN) of the job.

          - */ - AutoMLJobArn?: string; - +export interface PropertyNameQuery { /** - *

          Information about the Amazon S3 location that is configured for storing model - * artifacts.

          + *

          Text that begins a property's name.

          */ - ModelArtifacts?: ModelArtifacts; + PropertyNameHint: string | undefined; +} - /** - *

          The status of the - * training - * job.

          - *

          Training job statuses are:

          - *
            - *
          • - *

            - * InProgress - The training is in progress.

            - *
          • - *
          • - *

            - * Completed - The training job has completed.

            - *
          • - *
          • - *

            - * Failed - The training job has failed. To see the reason for the - * failure, see the FailureReason field in the response to a - * DescribeTrainingJobResponse call.

            - *
          • - *
          • - *

            - * Stopping - The training job is stopping.

            - *
          • - *
          • - *

            - * Stopped - The training job has stopped.

            - *
          • - *
          - *

          For - * more detailed information, see SecondaryStatus.

          - */ - TrainingJobStatus?: TrainingJobStatus | string; +export namespace PropertyNameQuery { + export const filterSensitiveLog = (obj: PropertyNameQuery): any => ({ + ...obj, + }); +} +/** + *

          Specified in the GetSearchSuggestions request. + * Limits the property names that are included in the response.

          + */ +export interface SuggestionQuery { /** - *

          Provides detailed information about the state of the training job. For detailed - * information about the secondary status of the training job, see - * StatusMessage under SecondaryStatusTransition.

          - *

          Amazon SageMaker provides primary statuses and secondary statuses that apply to each of - * them:

          - *
          - *
          InProgress
          - *
          - *
            - *
          • - *

            - * Starting - * - Starting the training job.

            - *
          • - *
          • - *

            - * Downloading - An optional stage for algorithms that - * support File training input mode. It indicates that - * data is being downloaded to the ML storage volumes.

            - *
          • - *
          • - *

            - * Training - Training is in progress.

            - *
          • - *
          • - *

            - * Uploading - Training is complete and the model - * artifacts are being uploaded to the S3 location.

            - *
          • - *
          - *
          - *
          Completed
          - *
          - *
            - *
          • - *

            - * Completed - The training job has completed.

            - *
          • - *
          - *
          - *
          Failed
          - *
          - *
            - *
          • - *

            - * Failed - The training job has failed. The reason for - * the failure is returned in the FailureReason field of - * DescribeTrainingJobResponse.

            - *
          • - *
          - *
          - *
          Stopped
          - *
          - *
            - *
          • - *

            - * MaxRuntimeExceeded - The job stopped because it - * exceeded the maximum allowed runtime.

            - *
          • - *
          • - *

            - * Stopped - The training job has stopped.

            - *
          • - *
          - *
          - *
          Stopping
          - *
          - *
            - *
          • - *

            - * Stopping - Stopping the training job.

            - *
          • - *
          - *
          - *
          - * - *

          Valid values for SecondaryStatus are subject to change.

          - *
          - *

          We no longer support the following secondary statuses:

          - *
            - *
          • - *

            - * LaunchingMLInstances - *

            - *
          • - *
          • - *

            - * PreparingTrainingStack - *

            - *
          • - *
          • - *

            - * DownloadingTrainingImage - *

            - *
          • - *
          + *

          Defines a property name hint. Only property + * names that begin with the specified hint are included in the response.

          */ - SecondaryStatus?: SecondaryStatus | string; + PropertyNameQuery?: PropertyNameQuery; +} - /** - *

          If the training job failed, the reason it failed.

          - */ - FailureReason?: string; +export namespace SuggestionQuery { + export const filterSensitiveLog = (obj: SuggestionQuery): any => ({ + ...obj, + }); +} +export interface GetSearchSuggestionsRequest { /** - *

          Algorithm-specific parameters.

          + *

          The name of the Amazon SageMaker resource to search for.

          */ - HyperParameters?: { [key: string]: string }; + Resource: ResourceType | string | undefined; /** - *

          Information about the algorithm used for training, and algorithm metadata.

          + *

          Limits the property names that are included in the response.

          */ - AlgorithmSpecification?: AlgorithmSpecification; + SuggestionQuery?: SuggestionQuery; +} + +export namespace GetSearchSuggestionsRequest { + export const filterSensitiveLog = (obj: GetSearchSuggestionsRequest): any => ({ + ...obj, + }); +} +/** + *

          A property name returned from a GetSearchSuggestions call that specifies + * a value in the PropertyNameQuery field.

          + */ +export interface PropertyNameSuggestion { /** - *

          The AWS Identity and Access Management (IAM) role configured for the training job.

          + *

          A suggested property name based on what you entered in the search textbox in the Amazon SageMaker + * console.

          */ - RoleArn?: string; + PropertyName?: string; +} + +export namespace PropertyNameSuggestion { + export const filterSensitiveLog = (obj: PropertyNameSuggestion): any => ({ + ...obj, + }); +} +export interface GetSearchSuggestionsResponse { /** - *

          An array of Channel objects that describes each data input - * channel.

          + *

          A list of property names for a Resource that match a + * SuggestionQuery.

          */ - InputDataConfig?: Channel[]; + PropertyNameSuggestions?: PropertyNameSuggestion[]; +} + +export namespace GetSearchSuggestionsResponse { + export const filterSensitiveLog = (obj: GetSearchSuggestionsResponse): any => ({ + ...obj, + }); +} +/** + *

          Specifies configuration details for a Git repository when the repository is + * updated.

          + */ +export interface GitConfigForUpdate { /** - *

          The S3 path where model artifacts that you configured when creating the job are - * stored. Amazon SageMaker creates subfolders for model artifacts.

          + *

          The Amazon Resource Name (ARN) of the AWS Secrets Manager secret that contains the + * credentials used to access the git repository. The secret must have a staging label of + * AWSCURRENT and must be in the following format:

          + *

          + * {"username": UserName, "password": + * Password} + *

          */ - OutputDataConfig?: OutputDataConfig; + SecretArn?: string; +} + +export namespace GitConfigForUpdate { + export const filterSensitiveLog = (obj: GitConfigForUpdate): any => ({ + ...obj, + }); +} +/** + *

          Container for human task user interface information.

          + */ +export interface HumanTaskUiSummary { /** - *

          Resources, including ML compute instances and ML storage volumes, that are configured - * for model training.

          + *

          The name of the human task user interface.

          */ - ResourceConfig?: ResourceConfig; + HumanTaskUiName: string | undefined; /** - *

          A VpcConfig object that specifies the VPC that this training job has - * access to. For more information, see Protect Training Jobs by Using an Amazon - * Virtual Private Cloud.

          + *

          The Amazon Resource Name (ARN) of the human task user interface.

          */ - VpcConfig?: VpcConfig; + HumanTaskUiArn: string | undefined; /** - *

          Specifies a limit to how long a model training job can run. When the job reaches the - * time limit, Amazon SageMaker ends the training job. Use this API to cap model training costs.

          - *

          To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays - * job termination for 120 seconds. Algorithms can use this 120-second window to save the - * model artifacts, so the results of training are not lost.

          + *

          A timestamp when SageMaker created the human task user interface.

          */ - StoppingCondition?: StoppingCondition; + CreationTime: Date | undefined; +} + +export namespace HumanTaskUiSummary { + export const filterSensitiveLog = (obj: HumanTaskUiSummary): any => ({ + ...obj, + }); +} + +export enum HyperParameterTuningJobSortByOptions { + CreationTime = "CreationTime", + Name = "Name", + Status = "Status", +} +/** + *

          Provides summary information about a hyperparameter tuning job.

          + */ +export interface HyperParameterTuningJobSummary { /** - *

          A timestamp that indicates when the training job was created.

          + *

          The name of the tuning job.

          */ - CreationTime?: Date; + HyperParameterTuningJobName: string | undefined; /** - *

          Indicates the time when the training job starts on training instances. You are billed - * for the time interval between this time and the value of TrainingEndTime. - * The start time in CloudWatch Logs might be later than this time. The difference is due to the time - * it takes to download the training data and to the size of the training container.

          + *

          The + * Amazon + * Resource Name (ARN) of the tuning job.

          */ - TrainingStartTime?: Date; + HyperParameterTuningJobArn: string | undefined; /** - *

          Indicates the time when the training job ends on training instances. You are billed - * for the time interval between the value of TrainingStartTime and this time. - * For successful jobs and stopped jobs, this is the time after model artifacts are - * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

          + *

          The status of the + * tuning + * job.

          */ - TrainingEndTime?: Date; + HyperParameterTuningJobStatus: HyperParameterTuningJobStatus | string | undefined; /** - *

          A timestamp that indicates when the status of the training job was last - * modified.

          + *

          Specifies the search strategy hyperparameter tuning uses to choose which + * hyperparameters to + * use + * for each iteration. Currently, the only valid value is + * Bayesian.

          */ - LastModifiedTime?: Date; + Strategy: HyperParameterTuningJobStrategyType | string | undefined; /** - *

          A history of all of the secondary statuses that the training job has transitioned - * through.

          + *

          The date and time that the tuning job was created.

          */ - SecondaryStatusTransitions?: SecondaryStatusTransition[]; + CreationTime: Date | undefined; /** - *

          A list of final metric values that are set when the training job completes. Used only - * if the training job was configured to use metrics.

          + *

          The date and time that the tuning job ended.

          */ - FinalMetricDataList?: MetricData[]; + HyperParameterTuningEndTime?: Date; /** - *

          If the TrainingJob was created with network isolation, the value is set - * to true. If network isolation is enabled, nodes can't communicate beyond - * the VPC they run in.

          + *

          The date and time that the tuning job was + * modified.

          */ - EnableNetworkIsolation?: boolean; + LastModifiedTime?: Date; /** - *

          To encrypt all communications between ML compute instances in distributed training, - * choose True. Encryption provides greater security for distributed training, - * but training might take longer. How long it takes depends on the amount of communication - * between compute instances, especially if you use a deep learning algorithm in - * distributed training.

          + *

          The TrainingJobStatusCounters object that specifies the numbers of + * training jobs, categorized by status, that this tuning job launched.

          */ - EnableInterContainerTrafficEncryption?: boolean; + TrainingJobStatusCounters: TrainingJobStatusCounters | undefined; /** - *

          When true, enables managed spot training using Amazon EC2 Spot instances to run - * training jobs instead of on-demand instances. For more information, see Managed Spot Training.

          + *

          The ObjectiveStatusCounters object that specifies the numbers of + * training jobs, categorized by objective metric status, that this tuning job + * launched.

          */ - EnableManagedSpotTraining?: boolean; + ObjectiveStatusCounters: ObjectiveStatusCounters | undefined; /** - *

          Contains information about the output location for managed spot training checkpoint - * data.

          + *

          The ResourceLimits object that specifies the maximum number of + * training jobs and parallel training jobs allowed for this tuning job.

          */ - CheckpointConfig?: CheckpointConfig; + ResourceLimits?: ResourceLimits; +} + +export namespace HyperParameterTuningJobSummary { + export const filterSensitiveLog = (obj: HyperParameterTuningJobSummary): any => ({ + ...obj, + }); +} +/** + *

          A SageMaker image. A SageMaker image represents a set of container images that are derived from + * a common base container image. Each of these container images is represented by a SageMaker + * ImageVersion.

          + */ +export interface Image { /** - *

          The training time in seconds.

          + *

          When the image was created.

          */ - TrainingTimeInSeconds?: number; + CreationTime: Date | undefined; /** - *

          The billable time in seconds.

          + *

          The description of the image.

          */ - BillableTimeInSeconds?: number; + Description?: string; /** - *

          Configuration information for the debug hook parameters, collection configuration, and - * storage paths.

          + *

          The name of the image as displayed.

          */ - DebugHookConfig?: DebugHookConfig; + DisplayName?: string; /** - *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

          - * + *

          When a create, update, or delete operation fails, the reason for the failure.

          */ - ExperimentConfig?: ExperimentConfig; + FailureReason?: string; /** - *

          Information about the debug rule configuration.

          + *

          The Amazon Resource Name (ARN) of the image.

          */ - DebugRuleConfigurations?: DebugRuleConfiguration[]; + ImageArn: string | undefined; /** - *

          Configuration of storage locations for TensorBoard output.

          + *

          The name of the image.

          */ - TensorBoardOutputConfig?: TensorBoardOutputConfig; + ImageName: string | undefined; /** - *

          Information about the evaluation status of the rules for the training job.

          + *

          The status of the image.

          */ - DebugRuleEvaluationStatuses?: DebugRuleEvaluationStatus[]; + ImageStatus: ImageStatus | string | undefined; /** - *

          An array of key-value pairs. For more information, see Using - * Cost Allocation Tags in the AWS Billing and Cost Management User - * Guide.

          + *

          When the image was last modified.

          */ - Tags?: Tag[]; + LastModifiedTime: Date | undefined; } -export namespace TrainingJob { - export const filterSensitiveLog = (obj: TrainingJob): any => ({ +export namespace Image { + export const filterSensitiveLog = (obj: Image): any => ({ ...obj, }); } -/** - *

          A short summary of a trial component.

          - */ -export interface TrialComponentSimpleSummary { +export enum ImageSortBy { + CREATION_TIME = "CREATION_TIME", + IMAGE_NAME = "IMAGE_NAME", + LAST_MODIFIED_TIME = "LAST_MODIFIED_TIME", +} + +export enum ImageSortOrder { + ASCENDING = "ASCENDING", + DESCENDING = "DESCENDING", +} + +/** + *

          A version of a SageMaker Image. A version represents an existing container + * image.

          + */ +export interface ImageVersion { + /** + *

          When the version was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          When a create or delete operation fails, the reason for the failure.

          + */ + FailureReason?: string; + /** - *

          The name of the trial component.

          + *

          The Amazon Resource Name (ARN) of the image the version is based on.

          */ - TrialComponentName?: string; + ImageArn: string | undefined; /** - *

          The Amazon Resource Name (ARN) of the trial component.

          + *

          The ARN of the version.

          */ - TrialComponentArn?: string; + ImageVersionArn: string | undefined; /** - *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          + *

          The status of the version.

          */ - TrialComponentSource?: TrialComponentSource; + ImageVersionStatus: ImageVersionStatus | string | undefined; /** - *

          When the component was created.

          + *

          When the version was last modified.

          */ - CreationTime?: Date; + LastModifiedTime: Date | undefined; /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          + *

          The version number.

          */ - CreatedBy?: UserContext; + Version: number | undefined; } -export namespace TrialComponentSimpleSummary { - export const filterSensitiveLog = (obj: TrialComponentSimpleSummary): any => ({ +export namespace ImageVersion { + export const filterSensitiveLog = (obj: ImageVersion): any => ({ ...obj, }); } +export enum ImageVersionSortBy { + CREATION_TIME = "CREATION_TIME", + LAST_MODIFIED_TIME = "LAST_MODIFIED_TIME", + VERSION = "VERSION", +} + +export enum ImageVersionSortOrder { + ASCENDING = "ASCENDING", + DESCENDING = "DESCENDING", +} + /** - *

          The properties of a trial as returned by the Search API.

          + *

          Provides counts for human-labeled tasks in the labeling job.

          */ -export interface Trial { - /** - *

          The name of the trial.

          - */ - TrialName?: string; - +export interface LabelCountersForWorkteam { /** - *

          The Amazon Resource Name (ARN) of the trial.

          + *

          The total number of data objects labeled by a human worker.

          */ - TrialArn?: string; + HumanLabeled?: number; /** - *

          The name of the trial as displayed. If DisplayName isn't specified, - * TrialName is displayed.

          + *

          The total number of data objects that need to be labeled by a human worker.

          */ - DisplayName?: string; + PendingHuman?: number; /** - *

          The name of the experiment the trial is part of.

          + *

          The total number of tasks in the labeling job.

          */ - ExperimentName?: string; + Total?: number; +} - /** - *

          The source of the trial.

          - */ - Source?: TrialSource; +export namespace LabelCountersForWorkteam { + export const filterSensitiveLog = (obj: LabelCountersForWorkteam): any => ({ + ...obj, + }); +} +/** + *

          Provides summary information for a work team.

          + */ +export interface LabelingJobForWorkteamSummary { /** - *

          When the trial was created.

          + *

          The name of the labeling job that the work team is assigned to.

          */ - CreationTime?: Date; + LabelingJobName?: string; /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          + *

          A unique identifier for a labeling job. You can use this to refer to a specific + * labeling job.

          */ - CreatedBy?: UserContext; + JobReferenceCode: string | undefined; /** - *

          Who last modified the trial.

          + *

          */ - LastModifiedTime?: Date; + WorkRequesterAccountId: string | undefined; /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          + *

          The date and time that the labeling job was created.

          */ - LastModifiedBy?: UserContext; + CreationTime: Date | undefined; /** - *

          The list of tags that are associated with the trial. You can use Search - * API to search on the tags.

          + *

          Provides information about the progress of a labeling job.

          */ - Tags?: Tag[]; + LabelCounters?: LabelCountersForWorkteam; /** - *

          A list of the components associated with the trial. For each component, a summary of the - * component's properties is included.

          + *

          The configured number of workers per data object.

          */ - TrialComponentSummaries?: TrialComponentSimpleSummary[]; + NumberOfHumanWorkersPerDataObject?: number; } -export namespace Trial { - export const filterSensitiveLog = (obj: Trial): any => ({ +export namespace LabelingJobForWorkteamSummary { + export const filterSensitiveLog = (obj: LabelingJobForWorkteamSummary): any => ({ ...obj, }); } /** - *

          A batch transform job. For information about SageMaker batch transform, see Use Batch - * Transform.

          + *

          Provides summary information about a labeling job.

          */ -export interface TransformJob { +export interface LabelingJobSummary { /** - *

          The name of the transform job.

          + *

          The name of the labeling job.

          */ - TransformJobName?: string; + LabelingJobName: string | undefined; /** - *

          The Amazon Resource Name (ARN) of the transform job.

          + *

          The Amazon Resource Name (ARN) assigned to the labeling job when it was + * created.

          */ - TransformJobArn?: string; + LabelingJobArn: string | undefined; /** - *

          The status of the transform job.

          - *

          Transform job statuses are:

          - *
            - *
          • - *

            - * InProgress - The job is in progress.

            - *
          • - *
          • - *

            - * Completed - The job has completed.

            - *
          • - *
          • - *

            - * Failed - The transform job has failed. To see the reason for the failure, - * see the FailureReason field in the response to a - * DescribeTransformJob call.

            - *
          • - *
          • - *

            - * Stopping - The transform job is stopping.

            - *
          • - *
          • - *

            - * Stopped - The transform job has stopped.

            - *
          • - *
          + *

          The date and time that the job was created (timestamp).

          */ - TransformJobStatus?: TransformJobStatus | string; + CreationTime: Date | undefined; /** - *

          If the transform job failed, the reason it failed.

          + *

          The date and time that the job was last modified (timestamp).

          */ - FailureReason?: string; + LastModifiedTime: Date | undefined; /** - *

          The name of the model associated with the transform job.

          + *

          The current status of the labeling job.

          */ - ModelName?: string; + LabelingJobStatus: LabelingJobStatus | string | undefined; /** - *

          The maximum number of parallel requests that can be sent to each instance in a transform - * job. If MaxConcurrentTransforms is set to 0 or left unset, SageMaker checks the - * optional execution-parameters to determine the settings for your chosen algorithm. If the - * execution-parameters endpoint is not enabled, the default value is 1. For built-in algorithms, - * you don't need to set a value for MaxConcurrentTransforms.

          + *

          Counts showing the progress of the labeling job.

          */ - MaxConcurrentTransforms?: number; + LabelCounters: LabelCounters | undefined; /** - *

          Configures the timeout and maximum number of retries for processing a transform job - * invocation.

          + *

          The Amazon Resource Name (ARN) of the work team assigned to the job.

          */ - ModelClientConfig?: ModelClientConfig; + WorkteamArn: string | undefined; /** - *

          The maximum allowed size of the payload, in MB. A payload is the data portion of a record - * (without metadata). The value in MaxPayloadInMB must be greater than, or equal - * to, the size of a single record. To estimate the size of a record in MB, divide the size of - * your dataset by the number of records. To ensure that the records fit within the maximum - * payload size, we recommend using a slightly larger value. The default value is 6 MB. For cases - * where the payload might be arbitrarily large and is transmitted using HTTP chunked encoding, - * set the value to 0. This feature works only in supported algorithms. Currently, SageMaker built-in - * algorithms do not support HTTP chunked encoding.

          + *

          The Amazon Resource Name (ARN) of a Lambda function. The function is run before each + * data object is sent to a worker.

          */ - MaxPayloadInMB?: number; + PreHumanTaskLambdaArn: string | undefined; /** - *

          Specifies the number of records to include in a mini-batch for an HTTP inference request. - * A record is a single unit of input data that inference can be made on. For example, a single - * line in a CSV file is a record.

          + *

          The Amazon Resource Name (ARN) of the Lambda function used to consolidate the + * annotations from individual workers into a label for a data object. For more + * information, see Annotation + * Consolidation.

          */ - BatchStrategy?: BatchStrategy | string; + AnnotationConsolidationLambdaArn?: string; /** - *

          The environment variables to set in the Docker container. We support up to 16 key and - * values entries in the map.

          + *

          If the LabelingJobStatus field is Failed, this field + * contains a description of the error.

          */ - Environment?: { [key: string]: string }; + FailureReason?: string; /** - *

          Describes the input source of a transform job and the way the transform job consumes - * it.

          + *

          The location of the output produced by the labeling job.

          */ - TransformInput?: TransformInput; + LabelingJobOutput?: LabelingJobOutput; /** - *

          Describes the results of a transform job.

          + *

          Input configuration for the labeling job.

          */ - TransformOutput?: TransformOutput; + InputConfig?: LabelingJobInputConfig; +} - /** - *

          Describes the resources, including ML instance types and ML instance count, to use for - * transform job.

          - */ - TransformResources?: TransformResources; +export namespace LabelingJobSummary { + export const filterSensitiveLog = (obj: LabelingJobSummary): any => ({ + ...obj, + }); +} + +export enum SortActionsBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} +export enum SortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} + +export interface ListActionsRequest { /** - *

          A timestamp that shows when the transform Job was created.

          + *

          A filter that returns only actions with the specified source URI.

          */ - CreationTime?: Date; + SourceUri?: string; /** - *

          Indicates when the transform job starts on ML instances. You are billed for the time - * interval between this time and the value of TransformEndTime.

          + *

          A filter that returns only actions of the specified type.

          */ - TransformStartTime?: Date; + ActionType?: string; /** - *

          Indicates when the transform job has been completed, or has stopped or failed. You are - * billed for the time interval between this time and the value of - * TransformStartTime.

          + *

          A filter that returns only actions created on or after the specified time.

          */ - TransformEndTime?: Date; + CreatedAfter?: Date; /** - *

          The Amazon Resource Name (ARN) of the labeling job that created the transform job.

          + *

          A filter that returns only actions created on or before the specified time.

          */ - LabelingJobArn?: string; + CreatedBefore?: Date; /** - *

          The Amazon Resource Name (ARN) of the AutoML job that created the transform job.

          + *

          The property used to sort results. The default value is CreationTime.

          */ - AutoMLJobArn?: string; + SortBy?: SortActionsBy | string; /** - *

          The data structure used to specify the data to be used for inference in a batch - * transform job and to associate the data that is relevant to the prediction results in - * the output. The input filter provided allows you to exclude input data that is not - * needed for inference in a batch transform job. The output filter provided allows you to - * include input data relevant to interpreting the predictions in the output from the job. - * For more information, see Associate Prediction - * Results with their Corresponding Input Records.

          + *

          The sort order. The default value is Descending.

          */ - DataProcessing?: DataProcessing; + SortOrder?: SortOrder | string; /** - *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when - * you call the following APIs:

          - * + *

          If the previous call to ListActions didn't return the full set of actions, + * the call returns a token for getting the next set of actions.

          */ - ExperimentConfig?: ExperimentConfig; + NextToken?: string; /** - *

          A list of tags associated with the transform job.

          + *

          The maximum number of actions to return in the response. The default value is 10.

          */ - Tags?: Tag[]; + MaxResults?: number; } -export namespace TransformJob { - export const filterSensitiveLog = (obj: TransformJob): any => ({ +export namespace ListActionsRequest { + export const filterSensitiveLog = (obj: ListActionsRequest): any => ({ ...obj, }); } -/** - *

          Detailed information about the source of a trial component. Either - * ProcessingJob or TrainingJob is returned.

          - */ -export interface TrialComponentSourceDetail { - /** - *

          The Amazon Resource Name (ARN) of the source.

          - */ - SourceArn?: string; - - /** - *

          Information about a training job that's the source of a trial component.

          - */ - TrainingJob?: TrainingJob; - +export interface ListActionsResponse { /** - *

          Information about a processing job that's the source of a trial component.

          + *

          A list of actions and their properties.

          */ - ProcessingJob?: ProcessingJob; + ActionSummaries?: ActionSummary[]; /** - *

          Information about a transform job that's the source of a trial component.

          + *

          A token for getting the next set of actions, if there are any.

          */ - TransformJob?: TransformJob; + NextToken?: string; } -export namespace TrialComponentSourceDetail { - export const filterSensitiveLog = (obj: TrialComponentSourceDetail): any => ({ +export namespace ListActionsResponse { + export const filterSensitiveLog = (obj: ListActionsResponse): any => ({ ...obj, }); } -/** - *

          The properties of a trial component as returned by the Search - * API.

          - */ -export interface TrialComponent { - /** - *

          The name of the trial component.

          - */ - TrialComponentName?: string; - - /** - *

          The name of the component as displayed. If DisplayName isn't specified, - * TrialComponentName is displayed.

          - */ - DisplayName?: string; - - /** - *

          The Amazon Resource Name (ARN) of the trial component.

          - */ - TrialComponentArn?: string; - - /** - *

          The Amazon Resource Name (ARN) and job type of the source of the component.

          - */ - Source?: TrialComponentSource; - +export interface ListAlgorithmsInput { /** - *

          The status of the trial component.

          + *

          A filter that returns only algorithms created after the specified time + * (timestamp).

          */ - Status?: TrialComponentStatus; + CreationTimeAfter?: Date; /** - *

          When the component started.

          + *

          A filter that returns only algorithms created before the specified time + * (timestamp).

          */ - StartTime?: Date; + CreationTimeBefore?: Date; /** - *

          When the component ended.

          + *

          The maximum number of algorithms to return in the response.

          */ - EndTime?: Date; + MaxResults?: number; /** - *

          When the component was created.

          + *

          A string in the algorithm name. This filter returns only algorithms whose name + * contains the specified string.

          */ - CreationTime?: Date; + NameContains?: string; /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          + *

          If the response to a previous ListAlgorithms request was truncated, the + * response includes a NextToken. To retrieve the next set of algorithms, use + * the token in the next request.

          */ - CreatedBy?: UserContext; + NextToken?: string; /** - *

          When the component was last modified.

          + *

          The parameter by which to sort the results. The default is + * CreationTime.

          */ - LastModifiedTime?: Date; + SortBy?: AlgorithmSortBy | string; /** - *

          Information about the user who created or modified an experiment, trial, or trial - * component.

          + *

          The sort order for the results. The default is Ascending.

          */ - LastModifiedBy?: UserContext; + SortOrder?: SortOrder | string; +} + +export namespace ListAlgorithmsInput { + export const filterSensitiveLog = (obj: ListAlgorithmsInput): any => ({ + ...obj, + }); +} +export interface ListAlgorithmsOutput { /** - *

          The hyperparameters of the component.

          + *

          >An array of AlgorithmSummary objects, each of which lists an + * algorithm.

          */ - Parameters?: { [key: string]: TrialComponentParameterValue }; + AlgorithmSummaryList: AlgorithmSummary[] | undefined; /** - *

          The input artifacts of the component.

          + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * algorithms, use it in the subsequent request.

          */ - InputArtifacts?: { [key: string]: TrialComponentArtifact }; + NextToken?: string; +} +export namespace ListAlgorithmsOutput { + export const filterSensitiveLog = (obj: ListAlgorithmsOutput): any => ({ + ...obj, + }); +} + +export interface ListAppImageConfigsRequest { /** - *

          The output artifacts of the component.

          + *

          The maximum number of AppImageConfigs to return in the response. The default value is + * 10.

          */ - OutputArtifacts?: { [key: string]: TrialComponentArtifact }; + MaxResults?: number; /** - *

          The metrics for the component.

          + *

          If the previous call to ListImages didn't return the full set of + * AppImageConfigs, the call returns a token for getting the next set of AppImageConfigs.

          */ - Metrics?: TrialComponentMetricSummary[]; + NextToken?: string; /** - *

          Details of the source of the component.

          + *

          A filter that returns only AppImageConfigs whose name contains the specified string.

          */ - SourceDetail?: TrialComponentSourceDetail; + NameContains?: string; /** - *

          The list of tags that are associated with the component. You can use Search API to search on the tags.

          + *

          A filter that returns only AppImageConfigs created on or before the specified time.

          */ - Tags?: Tag[]; + CreationTimeBefore?: Date; /** - *

          An array of the parents of the component. A parent is a trial the component is associated - * with and the experiment the trial is part of. A component might not have any parents.

          + *

          A filter that returns only AppImageConfigs created on or after the specified time.

          */ - Parents?: Parent[]; -} - -export namespace TrialComponent { - export const filterSensitiveLog = (obj: TrialComponent): any => ({ - ...obj, - }); -} + CreationTimeAfter?: Date; -/** - *

          A single resource returned as part of the Search API response.

          - */ -export interface SearchRecord { /** - *

          The properties of a training job.

          + *

          A filter that returns only AppImageConfigs modified on or before the specified time.

          */ - TrainingJob?: TrainingJob; + ModifiedTimeBefore?: Date; /** - *

          The properties of an experiment.

          + *

          A filter that returns only AppImageConfigs modified on or after the specified time.

          */ - Experiment?: Experiment; + ModifiedTimeAfter?: Date; /** - *

          The properties of a trial.

          + *

          The property used to sort results. The default value is CreationTime.

          */ - Trial?: Trial; + SortBy?: AppImageConfigSortKey | string; /** - *

          The properties of a trial component.

          + *

          The sort order. The default value is Descending.

          */ - TrialComponent?: TrialComponent; + SortOrder?: SortOrder | string; } -export namespace SearchRecord { - export const filterSensitiveLog = (obj: SearchRecord): any => ({ +export namespace ListAppImageConfigsRequest { + export const filterSensitiveLog = (obj: ListAppImageConfigsRequest): any => ({ ...obj, }); } -export interface SearchResponse { +export interface ListAppImageConfigsResponse { /** - *

          A list of SearchRecord objects.

          + *

          A token for getting the next set of AppImageConfigs, if there are any.

          */ - Results?: SearchRecord[]; + NextToken?: string; /** - *

          If the result of the previous Search request was truncated, the response - * includes a NextToken. To retrieve the next set of results, use the token in the next - * request.

          + *

          A list of AppImageConfigs and their properties.

          */ - NextToken?: string; + AppImageConfigs?: AppImageConfigDetails[]; } -export namespace SearchResponse { - export const filterSensitiveLog = (obj: SearchResponse): any => ({ +export namespace ListAppImageConfigsResponse { + export const filterSensitiveLog = (obj: ListAppImageConfigsResponse): any => ({ ...obj, }); } -export interface StartMonitoringScheduleRequest { +export interface ListAppsRequest { /** - *

          The name of the schedule to start.

          + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          */ - MonitoringScheduleName: string | undefined; -} - -export namespace StartMonitoringScheduleRequest { - export const filterSensitiveLog = (obj: StartMonitoringScheduleRequest): any => ({ - ...obj, - }); -} + NextToken?: string; -export interface StartNotebookInstanceInput { /** - *

          The name of the notebook instance to start.

          + *

          Returns a list up to a specified limit.

          */ - NotebookInstanceName: string | undefined; -} + MaxResults?: number; -export namespace StartNotebookInstanceInput { - export const filterSensitiveLog = (obj: StartNotebookInstanceInput): any => ({ - ...obj, - }); -} + /** + *

          The sort order for the results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; -export interface StopAutoMLJobRequest { /** - *

          The name of the object you are requesting.

          + *

          The parameter by which to sort the results. The default is CreationTime.

          */ - AutoMLJobName: string | undefined; -} + SortBy?: AppSortKey | string; -export namespace StopAutoMLJobRequest { - export const filterSensitiveLog = (obj: StopAutoMLJobRequest): any => ({ - ...obj, - }); -} + /** + *

          A parameter to search for the domain ID.

          + */ + DomainIdEquals?: string; -export interface StopCompilationJobRequest { /** - *

          The name of the model compilation job to stop.

          + *

          A parameter to search by user profile name.

          */ - CompilationJobName: string | undefined; + UserProfileNameEquals?: string; } -export namespace StopCompilationJobRequest { - export const filterSensitiveLog = (obj: StopCompilationJobRequest): any => ({ +export namespace ListAppsRequest { + export const filterSensitiveLog = (obj: ListAppsRequest): any => ({ ...obj, }); } -export interface StopHyperParameterTuningJobRequest { +export interface ListAppsResponse { /** - *

          The name of the tuning job to stop.

          + *

          The list of apps.

          */ - HyperParameterTuningJobName: string | undefined; -} - -export namespace StopHyperParameterTuningJobRequest { - export const filterSensitiveLog = (obj: StopHyperParameterTuningJobRequest): any => ({ - ...obj, - }); -} + Apps?: AppDetails[]; -export interface StopLabelingJobRequest { /** - *

          The name of the labeling job to stop.

          + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          */ - LabelingJobName: string | undefined; + NextToken?: string; } -export namespace StopLabelingJobRequest { - export const filterSensitiveLog = (obj: StopLabelingJobRequest): any => ({ +export namespace ListAppsResponse { + export const filterSensitiveLog = (obj: ListAppsResponse): any => ({ ...obj, }); } -export interface StopMonitoringScheduleRequest { - /** - *

          The name of the schedule to stop.

          - */ - MonitoringScheduleName: string | undefined; +export enum SortArtifactsBy { + CREATION_TIME = "CreationTime", } -export namespace StopMonitoringScheduleRequest { - export const filterSensitiveLog = (obj: StopMonitoringScheduleRequest): any => ({ - ...obj, - }); -} +export interface ListArtifactsRequest { + /** + *

          A filter that returns only artifacts with the specified source URI.

          + */ + SourceUri?: string; -export interface StopNotebookInstanceInput { /** - *

          The name of the notebook instance to terminate.

          + *

          A filter that returns only artifacts of the specified type.

          */ - NotebookInstanceName: string | undefined; -} + ArtifactType?: string; -export namespace StopNotebookInstanceInput { - export const filterSensitiveLog = (obj: StopNotebookInstanceInput): any => ({ - ...obj, - }); -} + /** + *

          A filter that returns only artifacts created on or after the specified time.

          + */ + CreatedAfter?: Date; -export interface StopProcessingJobRequest { /** - *

          The name of the processing job to stop.

          + *

          A filter that returns only artifacts created on or before the specified time.

          */ - ProcessingJobName: string | undefined; -} + CreatedBefore?: Date; -export namespace StopProcessingJobRequest { - export const filterSensitiveLog = (obj: StopProcessingJobRequest): any => ({ - ...obj, - }); -} + /** + *

          The property used to sort results. The default value is CreationTime.

          + */ + SortBy?: SortArtifactsBy | string; -export interface StopTrainingJobRequest { /** - *

          The name of the training job to stop.

          + *

          The sort order. The default value is Descending.

          */ - TrainingJobName: string | undefined; -} + SortOrder?: SortOrder | string; -export namespace StopTrainingJobRequest { - export const filterSensitiveLog = (obj: StopTrainingJobRequest): any => ({ - ...obj, - }); -} + /** + *

          If the previous call to ListArtifacts didn't return the full set of artifacts, + * the call returns a token for getting the next set of artifacts.

          + */ + NextToken?: string; -export interface StopTransformJobRequest { /** - *

          The name of the transform job to stop.

          + *

          The maximum number of artifacts to return in the response. The default value is 10.

          */ - TransformJobName: string | undefined; + MaxResults?: number; } -export namespace StopTransformJobRequest { - export const filterSensitiveLog = (obj: StopTransformJobRequest): any => ({ +export namespace ListArtifactsRequest { + export const filterSensitiveLog = (obj: ListArtifactsRequest): any => ({ ...obj, }); } -export interface UpdateAppImageConfigRequest { +export interface ListArtifactsResponse { /** - *

          The name of the AppImageConfig to update.

          + *

          A list of artifacts and their properties.

          */ - AppImageConfigName: string | undefined; + ArtifactSummaries?: ArtifactSummary[]; /** - *

          The new KernelGateway app to run on the image.

          + *

          A token for getting the next set of artifacts, if there are any.

          */ - KernelGatewayImageConfig?: KernelGatewayImageConfig; + NextToken?: string; } -export namespace UpdateAppImageConfigRequest { - export const filterSensitiveLog = (obj: UpdateAppImageConfigRequest): any => ({ +export namespace ListArtifactsResponse { + export const filterSensitiveLog = (obj: ListArtifactsResponse): any => ({ ...obj, }); } -export interface UpdateAppImageConfigResponse { - /** - *

          The Amazon Resource Name (ARN) for the AppImageConfig.

          - */ - AppImageConfigArn?: string; -} - -export namespace UpdateAppImageConfigResponse { - export const filterSensitiveLog = (obj: UpdateAppImageConfigResponse): any => ({ - ...obj, - }); +export enum SortAssociationsBy { + CREATION_TIME = "CreationTime", + DESTINATION_ARN = "DestinationArn", + DESTINATION_TYPE = "DestinationType", + SOURCE_ARN = "SourceArn", + SOURCE_TYPE = "SourceType", } -export interface UpdateCodeRepositoryInput { +export interface ListAssociationsRequest { /** - *

          The name of the Git repository to update.

          + *

          A filter that returns only associations with the specified source ARN.

          */ - CodeRepositoryName: string | undefined; + SourceArn?: string; /** - *

          The configuration of the git repository, including the URL and the Amazon Resource - * Name (ARN) of the AWS Secrets Manager secret that contains the credentials used to - * access the repository. The secret must have a staging label of AWSCURRENT - * and must be in the following format:

          - *

          - * {"username": UserName, "password": - * Password} - *

          + *

          A filter that returns only associations with the specified destination Amazon Resource Name (ARN).

          */ - GitConfig?: GitConfigForUpdate; -} - -export namespace UpdateCodeRepositoryInput { - export const filterSensitiveLog = (obj: UpdateCodeRepositoryInput): any => ({ - ...obj, - }); -} + DestinationArn?: string; -export interface UpdateCodeRepositoryOutput { /** - *

          The ARN of the Git repository.

          + *

          A filter that returns only associations with the specified source type.

          */ - CodeRepositoryArn: string | undefined; -} + SourceType?: string; -export namespace UpdateCodeRepositoryOutput { - export const filterSensitiveLog = (obj: UpdateCodeRepositoryOutput): any => ({ - ...obj, - }); -} + /** + *

          A filter that returns only associations with the specified destination type.

          + */ + DestinationType?: string; -export interface UpdateDomainRequest { /** - *

          The ID of the domain to be updated.

          + *

          A filter that returns only associations of the specified type.

          */ - DomainId: string | undefined; + AssociationType?: AssociationEdgeType | string; /** - *

          A collection of settings.

          + *

          A filter that returns only associations created on or after the specified time.

          */ - DefaultUserSettings?: UserSettings; -} + CreatedAfter?: Date; -export namespace UpdateDomainRequest { - export const filterSensitiveLog = (obj: UpdateDomainRequest): any => ({ - ...obj, - }); -} + /** + *

          A filter that returns only associations created on or before the specified time.

          + */ + CreatedBefore?: Date; -export interface UpdateDomainResponse { /** - *

          The Amazon Resource Name (ARN) of the domain.

          + *

          The property used to sort results. The default value is CreationTime.

          */ - DomainArn?: string; -} + SortBy?: SortAssociationsBy | string; -export namespace UpdateDomainResponse { - export const filterSensitiveLog = (obj: UpdateDomainResponse): any => ({ - ...obj, - }); -} + /** + *

          The sort order. The default value is Descending.

          + */ + SortOrder?: SortOrder | string; -export enum VariantPropertyType { - DataCaptureConfig = "DataCaptureConfig", - DesiredInstanceCount = "DesiredInstanceCount", - DesiredWeight = "DesiredWeight", -} + /** + *

          If the previous call to ListAssociations didn't return the full set of associations, + * the call returns a token for getting the next set of associations.

          + */ + NextToken?: string; -/** - *

          Specifies a production variant property type for an Endpoint.

          - *

          If you are updating an endpoint with the UpdateEndpointInput$RetainAllVariantProperties option set to - * true, the VariantProperty objects listed in UpdateEndpointInput$ExcludeRetainedVariantProperties override the - * existing variant properties of the endpoint.

          - */ -export interface VariantProperty { /** - *

          The type of variant property. The supported values are:

          - * + *

          The maximum number of associations to return in the response. The default value is 10.

          */ - VariantPropertyType: VariantPropertyType | string | undefined; + MaxResults?: number; } -export namespace VariantProperty { - export const filterSensitiveLog = (obj: VariantProperty): any => ({ +export namespace ListAssociationsRequest { + export const filterSensitiveLog = (obj: ListAssociationsRequest): any => ({ ...obj, }); } diff --git a/clients/client-sagemaker/models/models_2.ts b/clients/client-sagemaker/models/models_2.ts index d4da232cdd0d..65ae77ae76fb 100644 --- a/clients/client-sagemaker/models/models_2.ts +++ b/clients/client-sagemaker/models/models_2.ts @@ -1,31 +1,6139 @@ import { + ActionStatus, + AlgorithmSpecification, + AppSpecification, + AssociationSummary, + AutoMLCandidate, + AutoMLJobStatus, + AutoMLJobSummary, + AutoMLSortBy, + AutoMLSortOrder, + BatchStrategy, BooleanOperator, - MemberDefinition, + CacheHitResult, + CandidateSortBy, + CandidateStatus, + Channel, + CheckpointConfig, + CodeRepositorySortBy, + CodeRepositorySortOrder, + CodeRepositorySummary, + CompilationJobStatus, + CompilationJobSummary, + ConditionStepMetadata, + ContextSummary, + InferenceSpecification, + KernelGatewayImageConfig, + MetadataProperties, + ModelApprovalStatus, + ModelMetrics, + ModelPackageValidationSpecification, MonitoringScheduleConfig, + NetworkConfig, NotebookInstanceAcceleratorType, NotebookInstanceLifecycleHook, - NotificationConfiguration, - OidcConfig, + OutputDataConfig, + ResourceConfig, RootAccess, - SourceIpConfig, - TrialComponentArtifact, - TrialComponentParameterValue, - TrialComponentStatus, + SourceAlgorithmSpecification, + StoppingCondition, + Tag, + TransformInput, + TransformOutput, + TransformResources, + UiTemplate, + UserContext, UserSettings, + VpcConfig, _InstanceType, } from "./models_0"; import { + DataProcessing, + DebugHookConfig, + DebugRuleConfiguration, + DebugRuleEvaluationStatus, + DeploymentConfig, DesiredWeightAndCapacity, + DomainDetails, + Endpoint, + EndpointConfigSortKey, + EndpointConfigSummary, + EndpointSortKey, + EndpointStatus, + EndpointSummary, + ExecutionStatus, + Experiment, + ExperimentConfig, + ExperimentSummary, + FeatureGroup, + FeatureGroupSortBy, + FeatureGroupSortOrder, + FeatureGroupStatus, + FeatureGroupSummary, Filter, - NestedFilters, + FlowDefinitionSummary, + GitConfigForUpdate, + HumanTaskUiSummary, + HyperParameterTrainingJobSummary, + HyperParameterTuningJobSortByOptions, + HyperParameterTuningJobStatus, + HyperParameterTuningJobSummary, + Image, + ImageSortBy, + ImageSortOrder, + ImageVersion, + ImageVersionSortBy, + ImageVersionSortOrder, + LabelingJobForWorkteamSummary, + LabelingJobStatus, + LabelingJobSummary, + MemberDefinition, + MetricData, + ModelArtifacts, + ModelClientConfig, + ModelPackageGroupStatus, + ModelPackageStatus, + ModelPackageStatusDetails, + MonitoringExecutionSummary, + NotebookInstanceStatus, + NotificationConfiguration, + OfflineStoreStatusValue, + OidcConfig, + PipelineExecutionStatus, + PipelineStatus, + ProcessingInput, + ProcessingJobStatus, + ProcessingOutputConfig, + ProcessingResources, + ProcessingStoppingCondition, + ProjectStatus, ResourceType, - SearchSortOrder, - VariantProperty, + ScheduleStatus, + SecondaryStatus, + SecondaryStatusTransition, + SortOrder, + SourceIpConfig, + SubscribedWorkteam, + TensorBoardOutputConfig, + TrainingJobStatus, + TransformJobStatus, + TrialComponentArtifact, + TrialComponentMetricSummary, + TrialComponentParameterValue, + TrialComponentSource, + TrialComponentStatus, + TrialSource, + UserProfileStatus, Workforce, Workteam, } from "./models_1"; import { SENSITIVE_STRING } from "@aws-sdk/smithy-client"; +export interface ListAssociationsResponse { + /** + *

          A list of associations and their properties.

          + */ + AssociationSummaries?: AssociationSummary[]; + + /** + *

          A token for getting the next set of associations, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListAssociationsResponse { + export const filterSensitiveLog = (obj: ListAssociationsResponse): any => ({ + ...obj, + }); +} + +export interface ListAutoMLJobsRequest { + /** + *

          Request a list of jobs, using a filter for time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          Request a list of jobs, using a filter for time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          Request a list of jobs, using a filter for time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          Request a list of jobs, using a filter for time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          Request a list of jobs, using a search filter for name.

          + */ + NameContains?: string; + + /** + *

          Request a list of jobs, using a filter for status.

          + */ + StatusEquals?: AutoMLJobStatus | string; + + /** + *

          The sort order for the results. The default is Descending.

          + */ + SortOrder?: AutoMLSortOrder | string; + + /** + *

          The parameter by which to sort the results. The default is AutoMLJobName.

          + */ + SortBy?: AutoMLSortBy | string; + + /** + *

          Request a list of jobs up to a specified limit.

          + */ + MaxResults?: number; + + /** + *

          If the previous response was truncated, you receive this token. Use it in your next + * request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListAutoMLJobsRequest { + export const filterSensitiveLog = (obj: ListAutoMLJobsRequest): any => ({ + ...obj, + }); +} + +export interface ListAutoMLJobsResponse { + /** + *

          Returns a summary list of jobs.

          + */ + AutoMLJobSummaries: AutoMLJobSummary[] | undefined; + + /** + *

          If the previous response was truncated, you receive this token. Use it in your next + * request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListAutoMLJobsResponse { + export const filterSensitiveLog = (obj: ListAutoMLJobsResponse): any => ({ + ...obj, + }); +} + +export interface ListCandidatesForAutoMLJobRequest { + /** + *

          List the Candidates created for the job by providing the job's name.

          + */ + AutoMLJobName: string | undefined; + + /** + *

          List the Candidates for the job and filter by status.

          + */ + StatusEquals?: CandidateStatus | string; + + /** + *

          List the Candidates for the job and filter by candidate name.

          + */ + CandidateNameEquals?: string; + + /** + *

          The sort order for the results. The default is Ascending.

          + */ + SortOrder?: AutoMLSortOrder | string; + + /** + *

          The parameter by which to sort the results. The default is Descending.

          + */ + SortBy?: CandidateSortBy | string; + + /** + *

          List the job's Candidates up to a specified limit.

          + */ + MaxResults?: number; + + /** + *

          If the previous response was truncated, you receive this token. Use it in your next + * request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListCandidatesForAutoMLJobRequest { + export const filterSensitiveLog = (obj: ListCandidatesForAutoMLJobRequest): any => ({ + ...obj, + }); +} + +export interface ListCandidatesForAutoMLJobResponse { + /** + *

          Summaries about the Candidates.

          + */ + Candidates: AutoMLCandidate[] | undefined; + + /** + *

          If the previous response was truncated, you receive this token. Use it in your next + * request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListCandidatesForAutoMLJobResponse { + export const filterSensitiveLog = (obj: ListCandidatesForAutoMLJobResponse): any => ({ + ...obj, + }); +} + +export interface ListCodeRepositoriesInput { + /** + *

          A filter that returns only Git repositories that were created after the specified + * time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only Git repositories that were created before the specified + * time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only Git repositories that were last modified after the + * specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only Git repositories that were last modified before the + * specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          The maximum number of Git repositories to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in the Git repositories name. This filter returns only repositories whose + * name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          If the result of a ListCodeRepositoriesOutput request was truncated, the + * response includes a NextToken. To get the next set of Git repositories, use + * the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The field to sort results by. The default is Name.

          + */ + SortBy?: CodeRepositorySortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: CodeRepositorySortOrder | string; +} + +export namespace ListCodeRepositoriesInput { + export const filterSensitiveLog = (obj: ListCodeRepositoriesInput): any => ({ + ...obj, + }); +} + +export interface ListCodeRepositoriesOutput { + /** + *

          Gets a list of summaries of the Git repositories. Each summary specifies the following + * values for the repository:

          + *
            + *
          • + *

            Name

            + *
          • + *
          • + *

            Amazon Resource Name (ARN)

            + *
          • + *
          • + *

            Creation time

            + *
          • + *
          • + *

            Last modified time

            + *
          • + *
          • + *

            Configuration information, including the URL location of the repository and + * the ARN of the AWS Secrets Manager secret that contains the credentials used + * to access the repository.

            + *
          • + *
          + */ + CodeRepositorySummaryList: CodeRepositorySummary[] | undefined; + + /** + *

          If the result of a ListCodeRepositoriesOutput request was truncated, the + * response includes a NextToken. To get the next set of Git repositories, use + * the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListCodeRepositoriesOutput { + export const filterSensitiveLog = (obj: ListCodeRepositoriesOutput): any => ({ + ...obj, + }); +} + +export enum ListCompilationJobsSortBy { + CREATION_TIME = "CreationTime", + NAME = "Name", + STATUS = "Status", +} + +export interface ListCompilationJobsRequest { + /** + *

          If the result of the previous ListCompilationJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of model + * compilation jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of model compilation jobs to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A filter that returns the model compilation jobs that were created after a specified + * time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns the model compilation jobs that were created before a specified + * time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns the model compilation jobs that were modified after a specified + * time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns the model compilation jobs that were modified before a specified + * time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns the model compilation jobs whose name contains a specified + * string.

          + */ + NameContains?: string; + + /** + *

          A filter that retrieves model compilation jobs with a specific DescribeCompilationJobResponse$CompilationJobStatus status.

          + */ + StatusEquals?: CompilationJobStatus | string; + + /** + *

          The field by which to sort results. The default is CreationTime.

          + */ + SortBy?: ListCompilationJobsSortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListCompilationJobsRequest { + export const filterSensitiveLog = (obj: ListCompilationJobsRequest): any => ({ + ...obj, + }); +} + +export interface ListCompilationJobsResponse { + /** + *

          An array of CompilationJobSummary objects, each describing a model + * compilation job.

          + */ + CompilationJobSummaries: CompilationJobSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this NextToken. To retrieve + * the next set of model compilation jobs, use this token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListCompilationJobsResponse { + export const filterSensitiveLog = (obj: ListCompilationJobsResponse): any => ({ + ...obj, + }); +} + +export enum SortContextsBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListContextsRequest { + /** + *

          A filter that returns only contexts with the specified source URI.

          + */ + SourceUri?: string; + + /** + *

          A filter that returns only contexts of the specified type.

          + */ + ContextType?: string; + + /** + *

          A filter that returns only contexts created on or after the specified time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns only contexts created on or before the specified time.

          + */ + CreatedBefore?: Date; + + /** + *

          The property used to sort results. The default value is CreationTime.

          + */ + SortBy?: SortContextsBy | string; + + /** + *

          The sort order. The default value is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the previous call to ListContexts didn't return the full set of contexts, + * the call returns a token for getting the next set of contexts.

          + */ + NextToken?: string; + + /** + *

          The maximum number of contexts to return in the response. The default value is 10.

          + */ + MaxResults?: number; +} + +export namespace ListContextsRequest { + export const filterSensitiveLog = (obj: ListContextsRequest): any => ({ + ...obj, + }); +} + +export interface ListContextsResponse { + /** + *

          A list of contexts and their properties.

          + */ + ContextSummaries?: ContextSummary[]; + + /** + *

          A token for getting the next set of contexts, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListContextsResponse { + export const filterSensitiveLog = (obj: ListContextsResponse): any => ({ + ...obj, + }); +} + +export interface ListDomainsRequest { + /** + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          + */ + NextToken?: string; + + /** + *

          Returns a list up to a specified limit.

          + */ + MaxResults?: number; +} + +export namespace ListDomainsRequest { + export const filterSensitiveLog = (obj: ListDomainsRequest): any => ({ + ...obj, + }); +} + +export interface ListDomainsResponse { + /** + *

          The list of domains.

          + */ + Domains?: DomainDetails[]; + + /** + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListDomainsResponse { + export const filterSensitiveLog = (obj: ListDomainsResponse): any => ({ + ...obj, + }); +} + +export enum OrderKey { + Ascending = "Ascending", + Descending = "Descending", +} + +export interface ListEndpointConfigsInput { + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: EndpointConfigSortKey | string; + + /** + *

          The sort order for results. The default is Descending.

          + */ + SortOrder?: OrderKey | string; + + /** + *

          If the result of the previous ListEndpointConfig request was + * truncated, the response includes a NextToken. To retrieve the next set of + * endpoint configurations, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of training jobs to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in the endpoint configuration name. This filter returns only endpoint + * configurations whose name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only endpoint configurations created before the specified + * time (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only endpoint configurations with a creation time greater + * than or equal to the specified time (timestamp).

          + */ + CreationTimeAfter?: Date; +} + +export namespace ListEndpointConfigsInput { + export const filterSensitiveLog = (obj: ListEndpointConfigsInput): any => ({ + ...obj, + }); +} + +export interface ListEndpointConfigsOutput { + /** + *

          An array of endpoint configurations.

          + */ + EndpointConfigs: EndpointConfigSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * endpoint configurations, use it in the subsequent request

          + */ + NextToken?: string; +} + +export namespace ListEndpointConfigsOutput { + export const filterSensitiveLog = (obj: ListEndpointConfigsOutput): any => ({ + ...obj, + }); +} + +export interface ListEndpointsInput { + /** + *

          Sorts the list of results. The default is CreationTime.

          + */ + SortBy?: EndpointSortKey | string; + + /** + *

          The sort order for results. The default is Descending.

          + */ + SortOrder?: OrderKey | string; + + /** + *

          If the result of a ListEndpoints request was truncated, the response + * includes a NextToken. To retrieve the next set of endpoints, use the token + * in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of endpoints to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in endpoint names. This filter returns only endpoints whose name contains + * the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only endpoints that were created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only endpoints with a creation time greater than or equal to + * the specified time (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only endpoints that were modified before the specified + * timestamp.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only endpoints that were modified after the specified + * timestamp.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only endpoints with the specified status.

          + */ + StatusEquals?: EndpointStatus | string; +} + +export namespace ListEndpointsInput { + export const filterSensitiveLog = (obj: ListEndpointsInput): any => ({ + ...obj, + }); +} + +export interface ListEndpointsOutput { + /** + *

          An array or endpoint objects.

          + */ + Endpoints: EndpointSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * training jobs, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListEndpointsOutput { + export const filterSensitiveLog = (obj: ListEndpointsOutput): any => ({ + ...obj, + }); +} + +export enum SortExperimentsBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListExperimentsRequest { + /** + *

          A filter that returns only experiments created after the specified time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns only experiments created before the specified time.

          + */ + CreatedBefore?: Date; + + /** + *

          The property used to sort results. The default value is CreationTime.

          + */ + SortBy?: SortExperimentsBy | string; + + /** + *

          The sort order. The default value is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the previous call to ListExperiments didn't return the full set of + * experiments, the call returns a token for getting the next set of experiments.

          + */ + NextToken?: string; + + /** + *

          The maximum number of experiments to return in the response. The default value is + * 10.

          + */ + MaxResults?: number; +} + +export namespace ListExperimentsRequest { + export const filterSensitiveLog = (obj: ListExperimentsRequest): any => ({ + ...obj, + }); +} + +export interface ListExperimentsResponse { + /** + *

          A list of the summaries of your experiments.

          + */ + ExperimentSummaries?: ExperimentSummary[]; + + /** + *

          A token for getting the next set of experiments, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListExperimentsResponse { + export const filterSensitiveLog = (obj: ListExperimentsResponse): any => ({ + ...obj, + }); +} + +export interface ListFeatureGroupsRequest { + /** + *

          A string that partially matches one or more FeatureGroups names. Filters + * FeatureGroups by name.

          + */ + NameContains?: string; + + /** + *

          A FeatureGroup status. Filters by FeatureGroup status.

          + */ + FeatureGroupStatusEquals?: FeatureGroupStatus | string; + + /** + *

          An OfflineStore status. Filters by OfflineStore status.

          + */ + OfflineStoreStatusEquals?: OfflineStoreStatusValue | string; + + /** + *

          Use this parameter to search for FeatureGroupss created after a specific + * date and time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          Use this parameter to search for FeatureGroupss created before a specific + * date and time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          The order in which feature groups are listed.

          + */ + SortOrder?: FeatureGroupSortOrder | string; + + /** + *

          The value on which the feature group list is sorted.

          + */ + SortBy?: FeatureGroupSortBy | string; + + /** + *

          The maximum number of results returned by ListFeatureGroups.

          + */ + MaxResults?: number; + + /** + *

          A token to resume pagination of ListFeatureGroups results.

          + */ + NextToken?: string; +} + +export namespace ListFeatureGroupsRequest { + export const filterSensitiveLog = (obj: ListFeatureGroupsRequest): any => ({ + ...obj, + }); +} + +export interface ListFeatureGroupsResponse { + /** + *

          A summary of feature groups.

          + */ + FeatureGroupSummaries: FeatureGroupSummary[] | undefined; + + /** + *

          A token to resume pagination of ListFeatureGroups results.

          + */ + NextToken: string | undefined; +} + +export namespace ListFeatureGroupsResponse { + export const filterSensitiveLog = (obj: ListFeatureGroupsResponse): any => ({ + ...obj, + }); +} + +export interface ListFlowDefinitionsRequest { + /** + *

          A filter that returns only flow definitions with a creation time greater than or equal to the specified timestamp.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only flow definitions that were created before the specified timestamp.

          + */ + CreationTimeBefore?: Date; + + /** + *

          An optional value that specifies whether you want the results sorted in Ascending or Descending order.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; + + /** + *

          The total number of items to return. If the total number of available items is more than the value specified in MaxResults, then a NextToken will be provided in the output that you can use to resume pagination.

          + */ + MaxResults?: number; +} + +export namespace ListFlowDefinitionsRequest { + export const filterSensitiveLog = (obj: ListFlowDefinitionsRequest): any => ({ + ...obj, + }); +} + +export interface ListFlowDefinitionsResponse { + /** + *

          An array of objects describing the flow definitions.

          + */ + FlowDefinitionSummaries: FlowDefinitionSummary[] | undefined; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; +} + +export namespace ListFlowDefinitionsResponse { + export const filterSensitiveLog = (obj: ListFlowDefinitionsResponse): any => ({ + ...obj, + }); +} + +export interface ListHumanTaskUisRequest { + /** + *

          A filter that returns only human task user interfaces with a creation time greater than or equal to the specified timestamp.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only human task user interfaces that were created before the specified timestamp.

          + */ + CreationTimeBefore?: Date; + + /** + *

          An optional value that specifies whether you want the results sorted in Ascending or Descending order.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; + + /** + *

          The total number of items to return. If the total number of available items is more than the value specified in MaxResults, then a NextToken will be provided in the output that you can use to resume pagination.

          + */ + MaxResults?: number; +} + +export namespace ListHumanTaskUisRequest { + export const filterSensitiveLog = (obj: ListHumanTaskUisRequest): any => ({ + ...obj, + }); +} + +export interface ListHumanTaskUisResponse { + /** + *

          An array of objects describing the human task user interfaces.

          + */ + HumanTaskUiSummaries: HumanTaskUiSummary[] | undefined; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; +} + +export namespace ListHumanTaskUisResponse { + export const filterSensitiveLog = (obj: ListHumanTaskUisResponse): any => ({ + ...obj, + }); +} + +export interface ListHyperParameterTuningJobsRequest { + /** + *

          If the result of the previous ListHyperParameterTuningJobs request was + * truncated, the response includes a NextToken. To retrieve the next set of + * tuning jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The + * maximum number of tuning jobs to return. The default value is + * 10.

          + */ + MaxResults?: number; + + /** + *

          The + * field + * to sort results by. The default is Name.

          + */ + SortBy?: HyperParameterTuningJobSortByOptions | string; + + /** + *

          The sort + * order + * for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A string in the tuning job name. This filter returns only tuning jobs whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only tuning jobs that were created after the + * specified + * time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only tuning jobs that were created before the + * specified + * time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only tuning jobs that were modified after the specified + * time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only tuning jobs that were modified before the specified + * time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only tuning jobs with the + * specified + * status.

          + */ + StatusEquals?: HyperParameterTuningJobStatus | string; +} + +export namespace ListHyperParameterTuningJobsRequest { + export const filterSensitiveLog = (obj: ListHyperParameterTuningJobsRequest): any => ({ + ...obj, + }); +} + +export interface ListHyperParameterTuningJobsResponse { + /** + *

          A list of HyperParameterTuningJobSummary objects that + * describe + * the tuning jobs that the ListHyperParameterTuningJobs + * request returned.

          + */ + HyperParameterTuningJobSummaries: HyperParameterTuningJobSummary[] | undefined; + + /** + *

          If the result of this ListHyperParameterTuningJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of tuning jobs, + * use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListHyperParameterTuningJobsResponse { + export const filterSensitiveLog = (obj: ListHyperParameterTuningJobsResponse): any => ({ + ...obj, + }); +} + +export interface ListImagesRequest { + /** + *

          A filter that returns only images created on or after the specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only images created on or before the specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only images modified on or after the specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only images modified on or before the specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          The maximum number of images to return in the response. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          A filter that returns only images whose name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          If the previous call to ListImages didn't return the full set of images, + * the call returns a token for getting the next set of images.

          + */ + NextToken?: string; + + /** + *

          The property used to sort results. The default value is CREATION_TIME.

          + */ + SortBy?: ImageSortBy | string; + + /** + *

          The sort order. The default value is DESCENDING.

          + */ + SortOrder?: ImageSortOrder | string; +} + +export namespace ListImagesRequest { + export const filterSensitiveLog = (obj: ListImagesRequest): any => ({ + ...obj, + }); +} + +export interface ListImagesResponse { + /** + *

          A list of images and their properties.

          + */ + Images?: Image[]; + + /** + *

          A token for getting the next set of images, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListImagesResponse { + export const filterSensitiveLog = (obj: ListImagesResponse): any => ({ + ...obj, + }); +} + +export interface ListImageVersionsRequest { + /** + *

          A filter that returns only versions created on or after the specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only versions created on or before the specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          The name of the image to list the versions of.

          + */ + ImageName: string | undefined; + + /** + *

          A filter that returns only versions modified on or after the specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only versions modified on or before the specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          The maximum number of versions to return in the response. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          If the previous call to ListImageVersions didn't return the full set of + * versions, the call returns a token for getting the next set of versions.

          + */ + NextToken?: string; + + /** + *

          The property used to sort results. The default value is CREATION_TIME.

          + */ + SortBy?: ImageVersionSortBy | string; + + /** + *

          The sort order. The default value is DESCENDING.

          + */ + SortOrder?: ImageVersionSortOrder | string; +} + +export namespace ListImageVersionsRequest { + export const filterSensitiveLog = (obj: ListImageVersionsRequest): any => ({ + ...obj, + }); +} + +export interface ListImageVersionsResponse { + /** + *

          A list of versions and their properties.

          + */ + ImageVersions?: ImageVersion[]; + + /** + *

          A token for getting the next set of versions, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListImageVersionsResponse { + export const filterSensitiveLog = (obj: ListImageVersionsResponse): any => ({ + ...obj, + }); +} + +export enum SortBy { + CREATION_TIME = "CreationTime", + NAME = "Name", + STATUS = "Status", +} + +export interface ListLabelingJobsRequest { + /** + *

          A filter that returns only labeling jobs created after the specified time + * (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only labeling jobs created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only labeling jobs modified after the specified time + * (timestamp).

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only labeling jobs modified before the specified time + * (timestamp).

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          The maximum number of labeling jobs to return in each page of the response.

          + */ + MaxResults?: number; + + /** + *

          If the result of the previous ListLabelingJobs request was truncated, the + * response includes a NextToken. To retrieve the next set of labeling jobs, + * use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          A string in the labeling job name. This filter returns only labeling jobs whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: SortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A filter that retrieves only labeling jobs with a specific status.

          + */ + StatusEquals?: LabelingJobStatus | string; +} + +export namespace ListLabelingJobsRequest { + export const filterSensitiveLog = (obj: ListLabelingJobsRequest): any => ({ + ...obj, + }); +} + +export interface ListLabelingJobsResponse { + /** + *

          An array of LabelingJobSummary objects, each describing a labeling + * job.

          + */ + LabelingJobSummaryList?: LabelingJobSummary[]; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * labeling jobs, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListLabelingJobsResponse { + export const filterSensitiveLog = (obj: ListLabelingJobsResponse): any => ({ + ...obj, + }); +} + +export enum ListLabelingJobsForWorkteamSortByOptions { + CREATION_TIME = "CreationTime", +} + +export interface ListLabelingJobsForWorkteamRequest { + /** + *

          The Amazon Resource Name (ARN) of the work team for which you want to see labeling + * jobs for.

          + */ + WorkteamArn: string | undefined; + + /** + *

          The maximum number of labeling jobs to return in each page of the response.

          + */ + MaxResults?: number; + + /** + *

          If the result of the previous ListLabelingJobsForWorkteam request was + * truncated, the response includes a NextToken. To retrieve the next set of + * labeling jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          A filter that returns only labeling jobs created after the specified time + * (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only labeling jobs created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter the limits jobs to only the ones whose job reference code contains the + * specified string.

          + */ + JobReferenceCodeContains?: string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: ListLabelingJobsForWorkteamSortByOptions | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListLabelingJobsForWorkteamRequest { + export const filterSensitiveLog = (obj: ListLabelingJobsForWorkteamRequest): any => ({ + ...obj, + }); +} + +export interface ListLabelingJobsForWorkteamResponse { + /** + *

          An array of LabelingJobSummary objects, each describing a labeling + * job.

          + */ + LabelingJobSummaryList: LabelingJobForWorkteamSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * labeling jobs, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListLabelingJobsForWorkteamResponse { + export const filterSensitiveLog = (obj: ListLabelingJobsForWorkteamResponse): any => ({ + ...obj, + }); +} + +export enum ModelPackageGroupSortBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListModelPackageGroupsInput { + /** + *

          A filter that returns only model groups created after the specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only model groups created before the specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          The maximum number of results to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in the model group name. This filter returns only model groups whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          If the result of the previous ListModelPackageGroups request was + * truncated, the response includes a NextToken. To retrieve the next set of + * model groups, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: ModelPackageGroupSortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListModelPackageGroupsInput { + export const filterSensitiveLog = (obj: ListModelPackageGroupsInput): any => ({ + ...obj, + }); +} + +/** + *

          Summary information about a model group.

          + */ +export interface ModelPackageGroupSummary { + /** + *

          The name of the model group.

          + */ + ModelPackageGroupName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the model group.

          + */ + ModelPackageGroupArn: string | undefined; + + /** + *

          A description of the model group.

          + */ + ModelPackageGroupDescription?: string; + + /** + *

          The time that the model group was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          The status of the model group.

          + */ + ModelPackageGroupStatus: ModelPackageGroupStatus | string | undefined; +} + +export namespace ModelPackageGroupSummary { + export const filterSensitiveLog = (obj: ModelPackageGroupSummary): any => ({ + ...obj, + }); +} + +export interface ListModelPackageGroupsOutput { + /** + *

          A list of summaries of the model groups in your AWS account.

          + */ + ModelPackageGroupSummaryList: ModelPackageGroupSummary[] | undefined; + + /** + *

          If the response is truncated, SageMaker returns this token. To retrieve the next set + * of model groups, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListModelPackageGroupsOutput { + export const filterSensitiveLog = (obj: ListModelPackageGroupsOutput): any => ({ + ...obj, + }); +} + +export enum ModelPackageType { + BOTH = "Both", + UNVERSIONED = "Unversioned", + VERSIONED = "Versioned", +} + +export enum ModelPackageSortBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListModelPackagesInput { + /** + *

          A filter that returns only model packages created after the specified time + * (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only model packages created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          The maximum number of model packages to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in the model package name. This filter returns only model packages whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only the model packages with the specified approval + * status.

          + */ + ModelApprovalStatus?: ModelApprovalStatus | string; + + /** + *

          A filter that returns only model versions that belong to the specified model group.

          + */ + ModelPackageGroupName?: string; + + /** + *

          A filter that returns onlyl the model packages of the specified type. This can be one + * of the following values.

          + *
            + *
          • + *

            + * VERSIONED - List only versioned models.

            + *
          • + *
          • + *

            + * UNVERSIONED - List only unversioined models.

            + *
          • + *
          • + *

            + * BOTH - List both versioned and unversioned models.

            + *
          • + *
          + */ + ModelPackageType?: ModelPackageType | string; + + /** + *

          If the response to a previous ListModelPackages request was truncated, + * the response includes a NextToken. To retrieve the next set of model + * packages, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The parameter by which to sort the results. The default is + * CreationTime.

          + */ + SortBy?: ModelPackageSortBy | string; + + /** + *

          The sort order for the results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListModelPackagesInput { + export const filterSensitiveLog = (obj: ListModelPackagesInput): any => ({ + ...obj, + }); +} + +/** + *

          Provides summary information about a model package.

          + */ +export interface ModelPackageSummary { + /** + *

          The name of the model package.

          + */ + ModelPackageName: string | undefined; + + /** + *

          If the model package is a versioned model, the model group that the versioned model + * belongs to.

          + */ + ModelPackageGroupName?: string; + + /** + *

          If the model package is a versioned model, the version of the model.

          + */ + ModelPackageVersion?: number; + + /** + *

          The Amazon Resource Name (ARN) of the model package.

          + */ + ModelPackageArn: string | undefined; + + /** + *

          A brief description of the model package.

          + */ + ModelPackageDescription?: string; + + /** + *

          A timestamp that shows when the model package was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          The overall status of the model package.

          + */ + ModelPackageStatus: ModelPackageStatus | string | undefined; + + /** + *

          The approval status of the model. This can be one of the following values.

          + *
            + *
          • + *

            + * APPROVED - The model is approved

            + *
          • + *
          • + *

            + * REJECTED - The model is rejected.

            + *
          • + *
          • + *

            + * PENDING_MANUAL_APPROVAL - The model is waiting for manual + * approval.

            + *
          • + *
          + */ + ModelApprovalStatus?: ModelApprovalStatus | string; +} + +export namespace ModelPackageSummary { + export const filterSensitiveLog = (obj: ModelPackageSummary): any => ({ + ...obj, + }); +} + +export interface ListModelPackagesOutput { + /** + *

          An array of ModelPackageSummary objects, each of which lists a model + * package.

          + */ + ModelPackageSummaryList: ModelPackageSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * model packages, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListModelPackagesOutput { + export const filterSensitiveLog = (obj: ListModelPackagesOutput): any => ({ + ...obj, + }); +} + +export enum ModelSortKey { + CreationTime = "CreationTime", + Name = "Name", +} + +export interface ListModelsInput { + /** + *

          Sorts the list of results. The default is CreationTime.

          + */ + SortBy?: ModelSortKey | string; + + /** + *

          The sort order for results. The default is Descending.

          + */ + SortOrder?: OrderKey | string; + + /** + *

          If the response to a previous ListModels request was truncated, the + * response includes a NextToken. To retrieve the next set of models, use the + * token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of models to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A string in the training job name. This filter returns only models in the training + * job whose name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only models created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only models with a creation time greater than or equal to the + * specified time (timestamp).

          + */ + CreationTimeAfter?: Date; +} + +export namespace ListModelsInput { + export const filterSensitiveLog = (obj: ListModelsInput): any => ({ + ...obj, + }); +} + +/** + *

          Provides summary information about a model.

          + */ +export interface ModelSummary { + /** + *

          The name of the model that you want a summary for.

          + */ + ModelName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the model.

          + */ + ModelArn: string | undefined; + + /** + *

          A timestamp that indicates when the model was created.

          + */ + CreationTime: Date | undefined; +} + +export namespace ModelSummary { + export const filterSensitiveLog = (obj: ModelSummary): any => ({ + ...obj, + }); +} + +export interface ListModelsOutput { + /** + *

          An array of ModelSummary objects, each of which lists a + * model.

          + */ + Models: ModelSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * models, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListModelsOutput { + export const filterSensitiveLog = (obj: ListModelsOutput): any => ({ + ...obj, + }); +} + +export enum MonitoringExecutionSortKey { + CREATION_TIME = "CreationTime", + SCHEDULED_TIME = "ScheduledTime", + STATUS = "Status", +} + +export interface ListMonitoringExecutionsRequest { + /** + *

          Name of a specific schedule to fetch jobs for.

          + */ + MonitoringScheduleName?: string; + + /** + *

          Name of a specific endpoint to fetch jobs for.

          + */ + EndpointName?: string; + + /** + *

          Whether to sort results by Status, CreationTime, + * ScheduledTime field. The default is CreationTime.

          + */ + SortBy?: MonitoringExecutionSortKey | string; + + /** + *

          Whether to sort the results in Ascending or Descending order. + * The default is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          The token returned if the response is truncated. To retrieve the next set of job + * executions, use it in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of jobs to return in the response. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          Filter for jobs scheduled before a specified time.

          + */ + ScheduledTimeBefore?: Date; + + /** + *

          Filter for jobs scheduled after a specified time.

          + */ + ScheduledTimeAfter?: Date; + + /** + *

          A filter that returns only jobs created before a specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only jobs created after a specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only jobs modified after a specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only jobs modified before a specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that retrieves only jobs with a specific status.

          + */ + StatusEquals?: ExecutionStatus | string; +} + +export namespace ListMonitoringExecutionsRequest { + export const filterSensitiveLog = (obj: ListMonitoringExecutionsRequest): any => ({ + ...obj, + }); +} + +export interface ListMonitoringExecutionsResponse { + /** + *

          A JSON array in which each element is a summary for a monitoring execution.

          + */ + MonitoringExecutionSummaries: MonitoringExecutionSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of jobs, + * use it in the subsequent reques

          + */ + NextToken?: string; +} + +export namespace ListMonitoringExecutionsResponse { + export const filterSensitiveLog = (obj: ListMonitoringExecutionsResponse): any => ({ + ...obj, + }); +} + +export enum MonitoringScheduleSortKey { + CREATION_TIME = "CreationTime", + NAME = "Name", + STATUS = "Status", +} + +export interface ListMonitoringSchedulesRequest { + /** + *

          Name of a specific endpoint to fetch schedules for.

          + */ + EndpointName?: string; + + /** + *

          Whether to sort results by Status, CreationTime, + * ScheduledTime field. The default is CreationTime.

          + */ + SortBy?: MonitoringScheduleSortKey | string; + + /** + *

          Whether to sort the results in Ascending or Descending order. + * The default is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          The token returned if the response is truncated. To retrieve the next set of job + * executions, use it in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of jobs to return in the response. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          Filter for monitoring schedules whose name contains a specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only monitoring schedules created before a specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only monitoring schedules created after a specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only monitoring schedules modified before a specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only monitoring schedules modified after a specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only monitoring schedules modified before a specified time.

          + */ + StatusEquals?: ScheduleStatus | string; +} + +export namespace ListMonitoringSchedulesRequest { + export const filterSensitiveLog = (obj: ListMonitoringSchedulesRequest): any => ({ + ...obj, + }); +} + +/** + *

          Summarizes the monitoring schedule.

          + */ +export interface MonitoringScheduleSummary { + /** + *

          The name of the monitoring schedule.

          + */ + MonitoringScheduleName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the monitoring schedule.

          + */ + MonitoringScheduleArn: string | undefined; + + /** + *

          The creation time of the monitoring schedule.

          + */ + CreationTime: Date | undefined; + + /** + *

          The last time the monitoring schedule was modified.

          + */ + LastModifiedTime: Date | undefined; + + /** + *

          The status of the monitoring schedule.

          + */ + MonitoringScheduleStatus: ScheduleStatus | string | undefined; + + /** + *

          The name of the endpoint using the monitoring schedule.

          + */ + EndpointName?: string; +} + +export namespace MonitoringScheduleSummary { + export const filterSensitiveLog = (obj: MonitoringScheduleSummary): any => ({ + ...obj, + }); +} + +export interface ListMonitoringSchedulesResponse { + /** + *

          A JSON array in which each element is a summary for a monitoring schedule.

          + */ + MonitoringScheduleSummaries: MonitoringScheduleSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of jobs, + * use it in the subsequent reques

          + */ + NextToken?: string; +} + +export namespace ListMonitoringSchedulesResponse { + export const filterSensitiveLog = (obj: ListMonitoringSchedulesResponse): any => ({ + ...obj, + }); +} + +export enum NotebookInstanceLifecycleConfigSortKey { + CREATION_TIME = "CreationTime", + LAST_MODIFIED_TIME = "LastModifiedTime", + NAME = "Name", +} + +export enum NotebookInstanceLifecycleConfigSortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} + +export interface ListNotebookInstanceLifecycleConfigsInput { + /** + *

          If the result of a ListNotebookInstanceLifecycleConfigs request was + * truncated, the response includes a NextToken. To get the next set of + * lifecycle configurations, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of lifecycle configurations to return in the response.

          + */ + MaxResults?: number; + + /** + *

          Sorts the list of results. The default is CreationTime.

          + */ + SortBy?: NotebookInstanceLifecycleConfigSortKey | string; + + /** + *

          The sort order for results.

          + */ + SortOrder?: NotebookInstanceLifecycleConfigSortOrder | string; + + /** + *

          A string in the lifecycle configuration name. This filter returns only lifecycle + * configurations whose name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only lifecycle configurations that were created before the + * specified time (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only lifecycle configurations that were created after the + * specified time (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only lifecycle configurations that were modified before the + * specified time (timestamp).

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only lifecycle configurations that were modified after the + * specified time (timestamp).

          + */ + LastModifiedTimeAfter?: Date; +} + +export namespace ListNotebookInstanceLifecycleConfigsInput { + export const filterSensitiveLog = (obj: ListNotebookInstanceLifecycleConfigsInput): any => ({ + ...obj, + }); +} + +/** + *

          Provides a summary of a notebook instance lifecycle configuration.

          + */ +export interface NotebookInstanceLifecycleConfigSummary { + /** + *

          The name of the lifecycle configuration.

          + */ + NotebookInstanceLifecycleConfigName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the lifecycle configuration.

          + */ + NotebookInstanceLifecycleConfigArn: string | undefined; + + /** + *

          A timestamp that tells when the lifecycle configuration was created.

          + */ + CreationTime?: Date; + + /** + *

          A timestamp that tells when the lifecycle configuration was last modified.

          + */ + LastModifiedTime?: Date; +} + +export namespace NotebookInstanceLifecycleConfigSummary { + export const filterSensitiveLog = (obj: NotebookInstanceLifecycleConfigSummary): any => ({ + ...obj, + }); +} + +export interface ListNotebookInstanceLifecycleConfigsOutput { + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To get the next set of + * lifecycle configurations, use it in the next request.

          + */ + NextToken?: string; + + /** + *

          An array of NotebookInstanceLifecycleConfiguration objects, each listing + * a lifecycle configuration.

          + */ + NotebookInstanceLifecycleConfigs?: NotebookInstanceLifecycleConfigSummary[]; +} + +export namespace ListNotebookInstanceLifecycleConfigsOutput { + export const filterSensitiveLog = (obj: ListNotebookInstanceLifecycleConfigsOutput): any => ({ + ...obj, + }); +} + +export enum NotebookInstanceSortKey { + CREATION_TIME = "CreationTime", + NAME = "Name", + STATUS = "Status", +} + +export enum NotebookInstanceSortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} + +export interface ListNotebookInstancesInput { + /** + *

          If the previous call to the ListNotebookInstances is truncated, the + * response includes a NextToken. You can use this token in your subsequent + * ListNotebookInstances request to fetch the next set of notebook + * instances.

          + * + *

          You might specify a filter or a sort order in your request. When response is + * truncated, you must use the same values for the filer and sort order in the next + * request.

          + *
          + */ + NextToken?: string; + + /** + *

          The maximum number of notebook instances to return.

          + */ + MaxResults?: number; + + /** + *

          The field to sort results by. The default is Name.

          + */ + SortBy?: NotebookInstanceSortKey | string; + + /** + *

          The sort order for results.

          + */ + SortOrder?: NotebookInstanceSortOrder | string; + + /** + *

          A string in the notebook instances' name. This filter returns only notebook + * instances whose name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that returns only notebook instances that were created before the + * specified time (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only notebook instances that were created after the specified + * time (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only notebook instances that were modified before the + * specified time (timestamp).

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A filter that returns only notebook instances that were modified after the + * specified time (timestamp).

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only notebook instances with the specified status.

          + */ + StatusEquals?: NotebookInstanceStatus | string; + + /** + *

          A string in the name of a notebook instances lifecycle configuration associated with + * this notebook instance. This filter returns only notebook instances associated with a + * lifecycle configuration with a name that contains the specified string.

          + */ + NotebookInstanceLifecycleConfigNameContains?: string; + + /** + *

          A string in the name or URL of a Git repository associated with this notebook + * instance. This filter returns only notebook instances associated with a git repository + * with a name that contains the specified string.

          + */ + DefaultCodeRepositoryContains?: string; + + /** + *

          A filter that returns only notebook instances with associated with the specified git + * repository.

          + */ + AdditionalCodeRepositoryEquals?: string; +} + +export namespace ListNotebookInstancesInput { + export const filterSensitiveLog = (obj: ListNotebookInstancesInput): any => ({ + ...obj, + }); +} + +/** + *

          Provides summary information for an Amazon SageMaker notebook instance.

          + */ +export interface NotebookInstanceSummary { + /** + *

          The name of the notebook instance that you want a summary for.

          + */ + NotebookInstanceName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the notebook instance.

          + */ + NotebookInstanceArn: string | undefined; + + /** + *

          The status of the notebook instance.

          + */ + NotebookInstanceStatus?: NotebookInstanceStatus | string; + + /** + *

          The + * URL that you use to connect to the Jupyter instance running in your notebook instance. + *

          + */ + Url?: string; + + /** + *

          The type of ML compute instance that the notebook instance is running on.

          + */ + InstanceType?: _InstanceType | string; + + /** + *

          A timestamp that shows when the notebook instance was created.

          + */ + CreationTime?: Date; + + /** + *

          A timestamp that shows when the notebook instance was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The name of a notebook instance lifecycle configuration associated with this notebook + * instance.

          + *

          For information about notebook instance lifestyle configurations, see Step + * 2.1: (Optional) Customize a Notebook Instance.

          + */ + NotebookInstanceLifecycleConfigName?: string; + + /** + *

          The Git repository associated with the notebook instance as its default code + * repository. This can be either the name of a Git repository stored as a resource in your + * account, or the URL of a Git repository in AWS CodeCommit or in any + * other Git repository. When you open a notebook instance, it opens in the directory that + * contains this repository. For more information, see Associating Git Repositories with Amazon SageMaker + * Notebook Instances.

          + */ + DefaultCodeRepository?: string; + + /** + *

          An array of up to three Git repositories associated with the notebook instance. These + * can be either the names of Git repositories stored as resources in your account, or the + * URL of Git repositories in AWS CodeCommit or in any + * other Git repository. These repositories are cloned at the same level as the default + * repository of your notebook instance. For more information, see Associating Git + * Repositories with Amazon SageMaker Notebook Instances.

          + */ + AdditionalCodeRepositories?: string[]; +} + +export namespace NotebookInstanceSummary { + export const filterSensitiveLog = (obj: NotebookInstanceSummary): any => ({ + ...obj, + }); +} + +export interface ListNotebookInstancesOutput { + /** + *

          If the response to the previous ListNotebookInstances request was + * truncated, Amazon SageMaker returns this token. To retrieve the next set of notebook instances, use + * the token in the next request.

          + */ + NextToken?: string; + + /** + *

          An array of NotebookInstanceSummary objects, one for each notebook + * instance.

          + */ + NotebookInstances?: NotebookInstanceSummary[]; +} + +export namespace ListNotebookInstancesOutput { + export const filterSensitiveLog = (obj: ListNotebookInstancesOutput): any => ({ + ...obj, + }); +} + +export enum SortPipelineExecutionsBy { + CREATION_TIME = "CreationTime", + PIPELINE_EXECUTION_ARN = "PipelineExecutionArn", +} + +export interface ListPipelineExecutionsRequest { + /** + *

          The name of the pipeline.

          + */ + PipelineName: string | undefined; + + /** + *

          A filter that returns the pipeline executions that were created after a specified + * time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns the pipeline executions that were created before a specified + * time.

          + */ + CreatedBefore?: Date; + + /** + *

          The field by which to sort results. The default is CreatedTime.

          + */ + SortBy?: SortPipelineExecutionsBy | string; + + /** + *

          The sort order for results.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the result of the previous ListPipelineExecutions request was truncated, + * the response includes a NextToken. To retrieve the next set of pipeline executions, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of pipeline executions to return in the response.

          + */ + MaxResults?: number; +} + +export namespace ListPipelineExecutionsRequest { + export const filterSensitiveLog = (obj: ListPipelineExecutionsRequest): any => ({ + ...obj, + }); +} + +/** + *

          A pipeline execution summary.

          + */ +export interface PipelineExecutionSummary { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn?: string; + + /** + *

          The start time of the pipeline execution.

          + */ + StartTime?: Date; + + /** + *

          The status of the pipeline execution.

          + */ + PipelineExecutionStatus?: PipelineExecutionStatus | string; + + /** + *

          The description of the pipeline execution.

          + */ + PipelineExecutionDescription?: string; + + /** + *

          The display name of the pipeline execution.

          + */ + PipelineExecutionDisplayName?: string; +} + +export namespace PipelineExecutionSummary { + export const filterSensitiveLog = (obj: PipelineExecutionSummary): any => ({ + ...obj, + }); +} + +export interface ListPipelineExecutionsResponse { + /** + *

          Contains a sorted list of pipeline execution summary objects matching the specified + * filters. Each run summary includes the Amazon Resource Name (ARN) of the pipeline execution, the run date, + * and the status. This list can be empty.

          + */ + PipelineExecutionSummaries?: PipelineExecutionSummary[]; + + /** + *

          If the result of the previous ListPipelineExecutions request was truncated, + * the response includes a NextToken. To retrieve the next set of pipeline executions, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListPipelineExecutionsResponse { + export const filterSensitiveLog = (obj: ListPipelineExecutionsResponse): any => ({ + ...obj, + }); +} + +export interface ListPipelineExecutionStepsRequest { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn?: string; + + /** + *

          If the result of the previous ListPipelineExecutionSteps request was truncated, + * the response includes a NextToken. To retrieve the next set of pipeline execution steps, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of pipeline execution steps to return in the response.

          + */ + MaxResults?: number; + + /** + *

          The field by which to sort results. The default is CreatedTime.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListPipelineExecutionStepsRequest { + export const filterSensitiveLog = (obj: ListPipelineExecutionStepsRequest): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for Model steps.

          + */ +export interface ModelStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the created model.

          + */ + Arn?: string; +} + +export namespace ModelStepMetadata { + export const filterSensitiveLog = (obj: ModelStepMetadata): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for a processing job step.

          + */ +export interface ProcessingJobStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the processing job.

          + */ + Arn?: string; +} + +export namespace ProcessingJobStepMetadata { + export const filterSensitiveLog = (obj: ProcessingJobStepMetadata): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for a register model job step.

          + */ +export interface RegisterModelStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the model package.

          + */ + Arn?: string; +} + +export namespace RegisterModelStepMetadata { + export const filterSensitiveLog = (obj: RegisterModelStepMetadata): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for a training job step.

          + */ +export interface TrainingJobStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the training job that was run by this step execution.

          + */ + Arn?: string; +} + +export namespace TrainingJobStepMetadata { + export const filterSensitiveLog = (obj: TrainingJobStepMetadata): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for a transform job step.

          + */ +export interface TransformJobStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the transform job that was run by this step execution.

          + */ + Arn?: string; +} + +export namespace TransformJobStepMetadata { + export const filterSensitiveLog = (obj: TransformJobStepMetadata): any => ({ + ...obj, + }); +} + +/** + *

          Metadata for a step execution.

          + */ +export interface PipelineExecutionStepMetadata { + /** + *

          The Amazon Resource Name (ARN) of the training job that was run by this step execution.

          + */ + TrainingJob?: TrainingJobStepMetadata; + + /** + *

          The Amazon Resource Name (ARN) of the processing job that was run by this step execution.

          + */ + ProcessingJob?: ProcessingJobStepMetadata; + + /** + *

          The Amazon Resource Name (ARN) of the transform job that was run by this step execution.

          + */ + TransformJob?: TransformJobStepMetadata; + + /** + *

          Metadata for the Model step.

          + */ + Model?: ModelStepMetadata; + + /** + *

          Metadata for the RegisterModel step.

          + */ + RegisterModel?: RegisterModelStepMetadata; + + /** + *

          If this is a Condition step metadata object, details on the condition.

          + */ + Condition?: ConditionStepMetadata; +} + +export namespace PipelineExecutionStepMetadata { + export const filterSensitiveLog = (obj: PipelineExecutionStepMetadata): any => ({ + ...obj, + }); +} + +export enum StepStatus { + EXECUTING = "Executing", + FAILED = "Failed", + STARTING = "Starting", + STOPPED = "Stopped", + STOPPING = "Stopping", + SUCCEEDED = "Succeeded", +} + +/** + *

          An execution of a step in a pipeline.

          + */ +export interface PipelineExecutionStep { + /** + *

          The name of the step that is executed.

          + */ + StepName?: string; + + /** + *

          The time that the step started executing.

          + */ + StartTime?: Date; + + /** + *

          The time that the step stopped executing.

          + */ + EndTime?: Date; + + /** + *

          The status of the step execution.

          + */ + StepStatus?: StepStatus | string; + + /** + *

          If this pipeline execution step was cached, details on the cache hit.

          + */ + CacheHitResult?: CacheHitResult; + + /** + *

          The reason why the step failed execution. This is only returned if the step failed its execution.

          + */ + FailureReason?: string; + + /** + *

          The metadata for the step execution.

          + */ + Metadata?: PipelineExecutionStepMetadata; +} + +export namespace PipelineExecutionStep { + export const filterSensitiveLog = (obj: PipelineExecutionStep): any => ({ + ...obj, + }); +} + +export interface ListPipelineExecutionStepsResponse { + /** + *

          A list of PipeLineExecutionStep objects. Each + * PipeLineExecutionStep consists of StepName, StartTime, EndTime, StepStatus, + * and Metadata. Metadata is an object with properties for each job that contains relevant + * information about the job created by the step.

          + */ + PipelineExecutionSteps?: PipelineExecutionStep[]; + + /** + *

          If the result of the previous ListPipelineExecutionSteps request was truncated, + * the response includes a NextToken. To retrieve the next set of pipeline execution steps, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListPipelineExecutionStepsResponse { + export const filterSensitiveLog = (obj: ListPipelineExecutionStepsResponse): any => ({ + ...obj, + }); +} + +export interface ListPipelineParametersForExecutionRequest { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn: string | undefined; + + /** + *

          If the result of the previous ListPipelineParametersForExecution request was truncated, + * the response includes a NextToken. To retrieve the next set of parameters, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of parameters to return in the response.

          + */ + MaxResults?: number; +} + +export namespace ListPipelineParametersForExecutionRequest { + export const filterSensitiveLog = (obj: ListPipelineParametersForExecutionRequest): any => ({ + ...obj, + }); +} + +/** + *

          Assigns a value to a named Pipeline parameter.

          + */ +export interface Parameter { + /** + *

          The name of the parameter to assign a value to. This parameter name must match a named parameter in the pipeline definition.

          + */ + Name: string | undefined; + + /** + *

          The literal value for the parameter.

          + */ + Value: string | undefined; +} + +export namespace Parameter { + export const filterSensitiveLog = (obj: Parameter): any => ({ + ...obj, + }); +} + +export interface ListPipelineParametersForExecutionResponse { + /** + *

          Contains a list of pipeline parameters. This list can be empty.

          + */ + PipelineParameters?: Parameter[]; + + /** + *

          If the result of the previous ListPipelineParametersForExecution request was truncated, + * the response includes a NextToken. To retrieve the next set of parameters, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListPipelineParametersForExecutionResponse { + export const filterSensitiveLog = (obj: ListPipelineParametersForExecutionResponse): any => ({ + ...obj, + }); +} + +export enum SortPipelinesBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListPipelinesRequest { + /** + *

          The prefix of the pipeline name.

          + */ + PipelineNamePrefix?: string; + + /** + *

          A filter that returns the pipelines that were created after a specified + * time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns the pipelines that were created before a specified + * time.

          + */ + CreatedBefore?: Date; + + /** + *

          The field by which to sort results. The default is CreatedTime.

          + */ + SortBy?: SortPipelinesBy | string; + + /** + *

          The sort order for results.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the result of the previous ListPipelines request was truncated, + * the response includes a NextToken. To retrieve the next set of pipelines, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of pipelines to return in the response.

          + */ + MaxResults?: number; +} + +export namespace ListPipelinesRequest { + export const filterSensitiveLog = (obj: ListPipelinesRequest): any => ({ + ...obj, + }); +} + +/** + *

          A summary of a pipeline.

          + */ +export interface PipelineSummary { + /** + *

          The Amazon Resource Name (ARN) of the pipeline.

          + */ + PipelineArn?: string; + + /** + *

          The name of the pipeline.

          + */ + PipelineName?: string; + + /** + *

          The display name of the pipeline.

          + */ + PipelineDisplayName?: string; + + /** + *

          The description of the pipeline.

          + */ + PipelineDescription?: string; + + /** + *

          The Amazon Resource Name (ARN) that the pipeline used to execute.

          + */ + RoleArn?: string; + + /** + *

          The creation time of the pipeline.

          + */ + CreationTime?: Date; + + /** + *

          The time that the pipeline was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The last time that a pipeline execution began.

          + */ + LastExecutionTime?: Date; +} + +export namespace PipelineSummary { + export const filterSensitiveLog = (obj: PipelineSummary): any => ({ + ...obj, + }); +} + +export interface ListPipelinesResponse { + /** + *

          Contains a sorted list of PipelineSummary objects matching the specified + * filters. Each PipelineSummary consists of PipelineArn, PipelineName, + * ExperimentName, PipelineDescription, CreationTime, LastModifiedTime, LastRunTime, and + * RoleArn. This list can be empty.

          + */ + PipelineSummaries?: PipelineSummary[]; + + /** + *

          If the result of the previous ListPipelines request was truncated, + * the response includes a NextToken. To retrieve the next set of pipelines, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListPipelinesResponse { + export const filterSensitiveLog = (obj: ListPipelinesResponse): any => ({ + ...obj, + }); +} + +export interface ListProcessingJobsRequest { + /** + *

          A filter that returns only processing jobs created after the specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only processing jobs created after the specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only processing jobs modified after the specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only processing jobs modified before the specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A string in the processing job name. This filter returns only processing jobs whose + * name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that retrieves only processing jobs with a specific status.

          + */ + StatusEquals?: ProcessingJobStatus | string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: SortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the result of the previous ListProcessingJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of processing + * jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of processing jobs to return in the response.

          + */ + MaxResults?: number; +} + +export namespace ListProcessingJobsRequest { + export const filterSensitiveLog = (obj: ListProcessingJobsRequest): any => ({ + ...obj, + }); +} + +/** + *

          Summary of information about a processing job.

          + */ +export interface ProcessingJobSummary { + /** + *

          The name of the processing job.

          + */ + ProcessingJobName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the processing job..

          + */ + ProcessingJobArn: string | undefined; + + /** + *

          The time at which the processing job was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          The time at which the processing job completed.

          + */ + ProcessingEndTime?: Date; + + /** + *

          A timestamp that indicates the last time the processing job was modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The status of the processing job.

          + */ + ProcessingJobStatus: ProcessingJobStatus | string | undefined; + + /** + *

          A string, up to one KB in size, that contains the reason a processing job failed, if + * it failed.

          + */ + FailureReason?: string; + + /** + *

          An optional string, up to one KB in size, that contains metadata from the processing + * container when the processing job exits.

          + */ + ExitMessage?: string; +} + +export namespace ProcessingJobSummary { + export const filterSensitiveLog = (obj: ProcessingJobSummary): any => ({ + ...obj, + }); +} + +export interface ListProcessingJobsResponse { + /** + *

          An array of ProcessingJobSummary objects, each listing a processing + * job.

          + */ + ProcessingJobSummaries: ProcessingJobSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * processing jobs, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListProcessingJobsResponse { + export const filterSensitiveLog = (obj: ListProcessingJobsResponse): any => ({ + ...obj, + }); +} + +export enum ProjectSortBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export enum ProjectSortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} + +export interface ListProjectsInput { + /** + *

          A filter that returns the projects that were created after a specified + * time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns the projects that were created before a specified + * time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          The maximum number of projects to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A filter that returns the projects whose name contains a specified + * string.

          + */ + NameContains?: string; + + /** + *

          If the result of the previous ListProjects request was truncated, + * the response includes a NextToken. To retrieve the next set of projects, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The field by which to sort results. The default is CreationTime.

          + */ + SortBy?: ProjectSortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: ProjectSortOrder | string; +} + +export namespace ListProjectsInput { + export const filterSensitiveLog = (obj: ListProjectsInput): any => ({ + ...obj, + }); +} + +/** + *

          Information about a project.

          + */ +export interface ProjectSummary { + /** + *

          The name of the project.

          + */ + ProjectName: string | undefined; + + /** + *

          The description of the project.

          + */ + ProjectDescription?: string; + + /** + *

          The Amazon Resource Name (ARN) of the project.

          + */ + ProjectArn: string | undefined; + + /** + *

          The ID of the project.

          + */ + ProjectId: string | undefined; + + /** + *

          The time that the project was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          The status of the project.

          + */ + ProjectStatus: ProjectStatus | string | undefined; +} + +export namespace ProjectSummary { + export const filterSensitiveLog = (obj: ProjectSummary): any => ({ + ...obj, + }); +} + +export interface ListProjectsOutput { + /** + *

          A list of summaries of projects.

          + */ + ProjectSummaryList: ProjectSummary[] | undefined; + + /** + *

          If the result of the previous ListCompilationJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of model + * compilation jobs, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListProjectsOutput { + export const filterSensitiveLog = (obj: ListProjectsOutput): any => ({ + ...obj, + }); +} + +export interface ListSubscribedWorkteamsRequest { + /** + *

          A string in the work team name. This filter returns only work teams whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          If the result of the previous ListSubscribedWorkteams request was + * truncated, the response includes a NextToken. To retrieve the next set of + * labeling jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of work teams to return in each page of the response.

          + */ + MaxResults?: number; +} + +export namespace ListSubscribedWorkteamsRequest { + export const filterSensitiveLog = (obj: ListSubscribedWorkteamsRequest): any => ({ + ...obj, + }); +} + +export interface ListSubscribedWorkteamsResponse { + /** + *

          An array of Workteam objects, each describing a work team.

          + */ + SubscribedWorkteams: SubscribedWorkteam[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * work teams, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListSubscribedWorkteamsResponse { + export const filterSensitiveLog = (obj: ListSubscribedWorkteamsResponse): any => ({ + ...obj, + }); +} + +export interface ListTagsInput { + /** + *

          The Amazon Resource Name (ARN) of the resource whose tags you want to + * retrieve.

          + */ + ResourceArn: string | undefined; + + /** + *

          If the response to the previous ListTags request is truncated, Amazon SageMaker + * returns this token. To retrieve the next set of tags, use it in the subsequent request. + *

          + */ + NextToken?: string; + + /** + *

          Maximum number of tags to return.

          + */ + MaxResults?: number; +} + +export namespace ListTagsInput { + export const filterSensitiveLog = (obj: ListTagsInput): any => ({ + ...obj, + }); +} + +export interface ListTagsOutput { + /** + *

          An array of Tag objects, each with a tag key and a value.

          + */ + Tags?: Tag[]; + + /** + *

          If response is truncated, Amazon SageMaker includes a token in the response. You can use this + * token in your subsequent request to fetch next set of tokens.

          + */ + NextToken?: string; +} + +export namespace ListTagsOutput { + export const filterSensitiveLog = (obj: ListTagsOutput): any => ({ + ...obj, + }); +} + +export interface ListTrainingJobsRequest { + /** + *

          If the result of the previous ListTrainingJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of training + * jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of training jobs to return in the response.

          + */ + MaxResults?: number; + + /** + *

          A filter that returns only training jobs created after the specified time + * (timestamp).

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only training jobs created before the specified time + * (timestamp).

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only training jobs modified after the specified time + * (timestamp).

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only training jobs modified before the specified time + * (timestamp).

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A string in the training job name. This filter returns only training jobs whose + * name contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that retrieves only training jobs with a specific status.

          + */ + StatusEquals?: TrainingJobStatus | string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: SortBy | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListTrainingJobsRequest { + export const filterSensitiveLog = (obj: ListTrainingJobsRequest): any => ({ + ...obj, + }); +} + +/** + *

          Provides summary information about a training job.

          + */ +export interface TrainingJobSummary { + /** + *

          The name of the training job that you want a summary for.

          + */ + TrainingJobName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the training job.

          + */ + TrainingJobArn: string | undefined; + + /** + *

          A timestamp that shows when the training job was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          A timestamp that shows when the training job ended. This field is set only if the + * training job has one of the terminal statuses (Completed, + * Failed, or Stopped).

          + */ + TrainingEndTime?: Date; + + /** + *

          Timestamp when the training job was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The status of the training job.

          + */ + TrainingJobStatus: TrainingJobStatus | string | undefined; +} + +export namespace TrainingJobSummary { + export const filterSensitiveLog = (obj: TrainingJobSummary): any => ({ + ...obj, + }); +} + +export interface ListTrainingJobsResponse { + /** + *

          An array of TrainingJobSummary objects, each listing a training + * job.

          + */ + TrainingJobSummaries: TrainingJobSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * training jobs, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListTrainingJobsResponse { + export const filterSensitiveLog = (obj: ListTrainingJobsResponse): any => ({ + ...obj, + }); +} + +export enum TrainingJobSortByOptions { + CreationTime = "CreationTime", + FinalObjectiveMetricValue = "FinalObjectiveMetricValue", + Name = "Name", + Status = "Status", +} + +export interface ListTrainingJobsForHyperParameterTuningJobRequest { + /** + *

          The name of the tuning job whose training jobs you want to list.

          + */ + HyperParameterTuningJobName: string | undefined; + + /** + *

          If the result of the previous ListTrainingJobsForHyperParameterTuningJob + * request was truncated, the response includes a NextToken. To retrieve the + * next set of training jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of training jobs to return. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          A filter that returns only training jobs with the + * specified + * status.

          + */ + StatusEquals?: TrainingJobStatus | string; + + /** + *

          The field to sort + * results + * by. The default is Name.

          + *

          If the value of this field is FinalObjectiveMetricValue, any training + * jobs that did not return an objective metric are not listed.

          + */ + SortBy?: TrainingJobSortByOptions | string; + + /** + *

          The sort order + * for + * results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; +} + +export namespace ListTrainingJobsForHyperParameterTuningJobRequest { + export const filterSensitiveLog = (obj: ListTrainingJobsForHyperParameterTuningJobRequest): any => ({ + ...obj, + }); +} + +export interface ListTrainingJobsForHyperParameterTuningJobResponse { + /** + *

          A list of TrainingJobSummary objects that + * describe + * the training jobs that the + * ListTrainingJobsForHyperParameterTuningJob request returned.

          + */ + TrainingJobSummaries: HyperParameterTrainingJobSummary[] | undefined; + + /** + *

          If the result of this ListTrainingJobsForHyperParameterTuningJob request + * was truncated, the response includes a NextToken. To retrieve the next set + * of training jobs, use the token in the next request.

          + */ + NextToken?: string; +} + +export namespace ListTrainingJobsForHyperParameterTuningJobResponse { + export const filterSensitiveLog = (obj: ListTrainingJobsForHyperParameterTuningJobResponse): any => ({ + ...obj, + }); +} + +export interface ListTransformJobsRequest { + /** + *

          A filter that returns only transform jobs created after the specified time.

          + */ + CreationTimeAfter?: Date; + + /** + *

          A filter that returns only transform jobs created before the specified time.

          + */ + CreationTimeBefore?: Date; + + /** + *

          A filter that returns only transform jobs modified after the specified time.

          + */ + LastModifiedTimeAfter?: Date; + + /** + *

          A filter that returns only transform jobs modified before the specified time.

          + */ + LastModifiedTimeBefore?: Date; + + /** + *

          A string in the transform job name. This filter returns only transform jobs whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          A filter that retrieves only transform jobs with a specific status.

          + */ + StatusEquals?: TransformJobStatus | string; + + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: SortBy | string; + + /** + *

          The sort order for results. The default is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          If the result of the previous ListTransformJobs request was truncated, + * the response includes a NextToken. To retrieve the next set of transform + * jobs, use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of + * transform + * jobs to return in the response. The default value is + * 10.

          + */ + MaxResults?: number; +} + +export namespace ListTransformJobsRequest { + export const filterSensitiveLog = (obj: ListTransformJobsRequest): any => ({ + ...obj, + }); +} + +/** + *

          Provides a + * summary + * of a transform job. Multiple TransformJobSummary objects are returned as a + * list after in response to a ListTransformJobs call.

          + */ +export interface TransformJobSummary { + /** + *

          The name of the transform job.

          + */ + TransformJobName: string | undefined; + + /** + *

          The Amazon Resource Name (ARN) of the transform job.

          + */ + TransformJobArn: string | undefined; + + /** + *

          A timestamp that shows when the transform Job was created.

          + */ + CreationTime: Date | undefined; + + /** + *

          Indicates when the transform + * job + * ends on compute instances. For successful jobs and stopped jobs, this + * is the exact time + * recorded + * after the results are uploaded. For failed jobs, this is when Amazon SageMaker + * detected that the job failed.

          + */ + TransformEndTime?: Date; + + /** + *

          Indicates when the transform job was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The status of the transform job.

          + */ + TransformJobStatus: TransformJobStatus | string | undefined; + + /** + *

          If the transform job failed, + * the + * reason it failed.

          + */ + FailureReason?: string; +} + +export namespace TransformJobSummary { + export const filterSensitiveLog = (obj: TransformJobSummary): any => ({ + ...obj, + }); +} + +export interface ListTransformJobsResponse { + /** + *

          An array of + * TransformJobSummary + * objects.

          + */ + TransformJobSummaries: TransformJobSummary[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * transform jobs, use it in the next request.

          + */ + NextToken?: string; +} + +export namespace ListTransformJobsResponse { + export const filterSensitiveLog = (obj: ListTransformJobsResponse): any => ({ + ...obj, + }); +} + +export enum SortTrialComponentsBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListTrialComponentsRequest { + /** + *

          A filter that returns only components that are part of the specified experiment. If you + * specify ExperimentName, you can't filter by SourceArn or + * TrialName.

          + */ + ExperimentName?: string; + + /** + *

          A filter that returns only components that are part of the specified trial. If you specify + * TrialName, you can't filter by ExperimentName or + * SourceArn.

          + */ + TrialName?: string; + + /** + *

          A filter that returns only components that have the specified source Amazon Resource Name + * (ARN). If you specify SourceArn, you can't filter by ExperimentName + * or TrialName.

          + */ + SourceArn?: string; + + /** + *

          A filter that returns only components created after the specified time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns only components created before the specified time.

          + */ + CreatedBefore?: Date; + + /** + *

          The property used to sort results. The default value is CreationTime.

          + */ + SortBy?: SortTrialComponentsBy | string; + + /** + *

          The sort order. The default value is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          The maximum number of components to return in the response. The default value is + * 10.

          + */ + MaxResults?: number; + + /** + *

          If the previous call to ListTrialComponents didn't return the full set of + * components, the call returns a token for getting the next set of components.

          + */ + NextToken?: string; +} + +export namespace ListTrialComponentsRequest { + export const filterSensitiveLog = (obj: ListTrialComponentsRequest): any => ({ + ...obj, + }); +} + +/** + *

          A summary of the properties of a trial component. To get all the properties, call the + * DescribeTrialComponent API and provide the + * TrialComponentName.

          + */ +export interface TrialComponentSummary { + /** + *

          The name of the trial component.

          + */ + TrialComponentName?: string; + + /** + *

          The ARN of the trial component.

          + */ + TrialComponentArn?: string; + + /** + *

          The name of the component as displayed. If DisplayName isn't specified, + * TrialComponentName is displayed.

          + */ + DisplayName?: string; + + /** + *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          + */ + TrialComponentSource?: TrialComponentSource; + + /** + *

          The status of the component. States include:

          + *
            + *
          • + *

            InProgress

            + *
          • + *
          • + *

            Completed

            + *
          • + *
          • + *

            Failed

            + *
          • + *
          + */ + Status?: TrialComponentStatus; + + /** + *

          When the component started.

          + */ + StartTime?: Date; + + /** + *

          When the component ended.

          + */ + EndTime?: Date; + + /** + *

          When the component was created.

          + */ + CreationTime?: Date; + + /** + *

          Who created the component.

          + */ + CreatedBy?: UserContext; + + /** + *

          When the component was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          Who last modified the component.

          + */ + LastModifiedBy?: UserContext; +} + +export namespace TrialComponentSummary { + export const filterSensitiveLog = (obj: TrialComponentSummary): any => ({ + ...obj, + }); +} + +export interface ListTrialComponentsResponse { + /** + *

          A list of the summaries of your trial components.

          + */ + TrialComponentSummaries?: TrialComponentSummary[]; + + /** + *

          A token for getting the next set of components, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListTrialComponentsResponse { + export const filterSensitiveLog = (obj: ListTrialComponentsResponse): any => ({ + ...obj, + }); +} + +export enum SortTrialsBy { + CREATION_TIME = "CreationTime", + NAME = "Name", +} + +export interface ListTrialsRequest { + /** + *

          A filter that returns only trials that are part of the specified experiment.

          + */ + ExperimentName?: string; + + /** + *

          A filter that returns only trials that are associated with the specified trial + * component.

          + */ + TrialComponentName?: string; + + /** + *

          A filter that returns only trials created after the specified time.

          + */ + CreatedAfter?: Date; + + /** + *

          A filter that returns only trials created before the specified time.

          + */ + CreatedBefore?: Date; + + /** + *

          The property used to sort results. The default value is CreationTime.

          + */ + SortBy?: SortTrialsBy | string; + + /** + *

          The sort order. The default value is Descending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          The maximum number of trials to return in the response. The default value is 10.

          + */ + MaxResults?: number; + + /** + *

          If the previous call to ListTrials didn't return the full set of trials, the + * call returns a token for getting the next set of trials.

          + */ + NextToken?: string; +} + +export namespace ListTrialsRequest { + export const filterSensitiveLog = (obj: ListTrialsRequest): any => ({ + ...obj, + }); +} + +/** + *

          A summary of the properties of a trial. To get the complete set of properties, call the + * DescribeTrial API and provide the TrialName.

          + */ +export interface TrialSummary { + /** + *

          The Amazon Resource Name (ARN) of the trial.

          + */ + TrialArn?: string; + + /** + *

          The name of the trial.

          + */ + TrialName?: string; + + /** + *

          The name of the trial as displayed. If DisplayName isn't specified, + * TrialName is displayed.

          + */ + DisplayName?: string; + + /** + *

          The source of the trial.

          + */ + TrialSource?: TrialSource; + + /** + *

          When the trial was created.

          + */ + CreationTime?: Date; + + /** + *

          When the trial was last modified.

          + */ + LastModifiedTime?: Date; +} + +export namespace TrialSummary { + export const filterSensitiveLog = (obj: TrialSummary): any => ({ + ...obj, + }); +} + +export interface ListTrialsResponse { + /** + *

          A list of the summaries of your trials.

          + */ + TrialSummaries?: TrialSummary[]; + + /** + *

          A token for getting the next set of trials, if there are any.

          + */ + NextToken?: string; +} + +export namespace ListTrialsResponse { + export const filterSensitiveLog = (obj: ListTrialsResponse): any => ({ + ...obj, + }); +} + +export enum UserProfileSortKey { + CreationTime = "CreationTime", + LastModifiedTime = "LastModifiedTime", +} + +export interface ListUserProfilesRequest { + /** + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          + */ + NextToken?: string; + + /** + *

          Returns a list up to a specified limit.

          + */ + MaxResults?: number; + + /** + *

          The sort order for the results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          The parameter by which to sort the results. The default is CreationTime.

          + */ + SortBy?: UserProfileSortKey | string; + + /** + *

          A parameter by which to filter the results.

          + */ + DomainIdEquals?: string; + + /** + *

          A parameter by which to filter the results.

          + */ + UserProfileNameContains?: string; +} + +export namespace ListUserProfilesRequest { + export const filterSensitiveLog = (obj: ListUserProfilesRequest): any => ({ + ...obj, + }); +} + +/** + *

          The user profile details.

          + */ +export interface UserProfileDetails { + /** + *

          The domain ID.

          + */ + DomainId?: string; + + /** + *

          The user profile name.

          + */ + UserProfileName?: string; + + /** + *

          The status.

          + */ + Status?: UserProfileStatus | string; + + /** + *

          The creation time.

          + */ + CreationTime?: Date; + + /** + *

          The last modified time.

          + */ + LastModifiedTime?: Date; +} + +export namespace UserProfileDetails { + export const filterSensitiveLog = (obj: UserProfileDetails): any => ({ + ...obj, + }); +} + +export interface ListUserProfilesResponse { + /** + *

          The list of user profiles.

          + */ + UserProfiles?: UserProfileDetails[]; + + /** + *

          If the previous response was truncated, you will receive this token. + * Use it in your next request to receive the next set of results.

          + */ + NextToken?: string; +} + +export namespace ListUserProfilesResponse { + export const filterSensitiveLog = (obj: ListUserProfilesResponse): any => ({ + ...obj, + }); +} + +export enum ListWorkforcesSortByOptions { + CreateDate = "CreateDate", + Name = "Name", +} + +export interface ListWorkforcesRequest { + /** + *

          Sort workforces using the workforce name or creation date.

          + */ + SortBy?: ListWorkforcesSortByOptions | string; + + /** + *

          Sort workforces in ascending or descending order.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A filter you can use to search for workforces using part of the workforce name.

          + */ + NameContains?: string; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; + + /** + *

          The maximum number of workforces returned in the response.

          + */ + MaxResults?: number; +} + +export namespace ListWorkforcesRequest { + export const filterSensitiveLog = (obj: ListWorkforcesRequest): any => ({ + ...obj, + }); +} + +export interface ListWorkforcesResponse { + /** + *

          A list containing information about your workforce.

          + */ + Workforces: Workforce[] | undefined; + + /** + *

          A token to resume pagination.

          + */ + NextToken?: string; +} + +export namespace ListWorkforcesResponse { + export const filterSensitiveLog = (obj: ListWorkforcesResponse): any => ({ + ...obj, + }); +} + +export enum ListWorkteamsSortByOptions { + CreateDate = "CreateDate", + Name = "Name", +} + +export interface ListWorkteamsRequest { + /** + *

          The field to sort results by. The default is CreationTime.

          + */ + SortBy?: ListWorkteamsSortByOptions | string; + + /** + *

          The sort order for results. The default is Ascending.

          + */ + SortOrder?: SortOrder | string; + + /** + *

          A string in the work team's name. This filter returns only work teams whose name + * contains the specified string.

          + */ + NameContains?: string; + + /** + *

          If the result of the previous ListWorkteams request was truncated, the + * response includes a NextToken. To retrieve the next set of labeling jobs, + * use the token in the next request.

          + */ + NextToken?: string; + + /** + *

          The maximum number of work teams to return in each page of the response.

          + */ + MaxResults?: number; +} + +export namespace ListWorkteamsRequest { + export const filterSensitiveLog = (obj: ListWorkteamsRequest): any => ({ + ...obj, + }); +} + +export interface ListWorkteamsResponse { + /** + *

          An array of Workteam objects, each describing a work team.

          + */ + Workteams: Workteam[] | undefined; + + /** + *

          If the response is truncated, Amazon SageMaker returns this token. To retrieve the next set of + * work teams, use it in the subsequent request.

          + */ + NextToken?: string; +} + +export namespace ListWorkteamsResponse { + export const filterSensitiveLog = (obj: ListWorkteamsResponse): any => ({ + ...obj, + }); +} + +/** + *

          A versioned model that can be deployed for SageMaker inference.

          + */ +export interface ModelPackage { + /** + *

          The name of the model.

          + */ + ModelPackageName?: string; + + /** + *

          The model group to which the model belongs.

          + */ + ModelPackageGroupName?: string; + + /** + *

          The version number of a versioned model.

          + */ + ModelPackageVersion?: number; + + /** + *

          The Amazon Resource Name (ARN) of the model package.

          + */ + ModelPackageArn?: string; + + /** + *

          The description of the model package.

          + */ + ModelPackageDescription?: string; + + /** + *

          The time that the model package was created.

          + */ + CreationTime?: Date; + + /** + *

          Defines how to perform inference generation after a training job is run.

          + */ + InferenceSpecification?: InferenceSpecification; + + /** + *

          A list of algorithms that were used to create a model package.

          + */ + SourceAlgorithmSpecification?: SourceAlgorithmSpecification; + + /** + *

          Specifies batch transform jobs that Amazon SageMaker runs to validate your model package.

          + */ + ValidationSpecification?: ModelPackageValidationSpecification; + + /** + *

          The status of the model package. This can be one of the following values.

          + *
            + *
          • + *

            + * PENDING - The model package is pending being created.

            + *
          • + *
          • + *

            + * IN_PROGRESS - The model package is in the process of being + * created.

            + *
          • + *
          • + *

            + * COMPLETED - The model package was successfully created.

            + *
          • + *
          • + *

            + * FAILED - The model package failed.

            + *
          • + *
          • + *

            + * DELETING - The model package is in the process of being deleted.

            + *
          • + *
          + */ + ModelPackageStatus?: ModelPackageStatus | string; + + /** + *

          Specifies the validation and image scan statuses of the model package.

          + */ + ModelPackageStatusDetails?: ModelPackageStatusDetails; + + /** + *

          Whether the model package is to be certified to be listed on AWS Marketplace. For + * information about listing model packages on AWS Marketplace, see List Your + * Algorithm or Model Package on AWS Marketplace.

          + */ + CertifyForMarketplace?: boolean; + + /** + *

          The approval status of the model. This can be one of the following values.

          + *
            + *
          • + *

            + * APPROVED - The model is approved

            + *
          • + *
          • + *

            + * REJECTED - The model is rejected.

            + *
          • + *
          • + *

            + * PENDING_MANUAL_APPROVAL - The model is waiting for manual + * approval.

            + *
          • + *
          + */ + ModelApprovalStatus?: ModelApprovalStatus | string; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          Metadata properties of the tracking entity, trial, or trial component.

          + */ + MetadataProperties?: MetadataProperties; + + /** + *

          Metrics for the model.

          + */ + ModelMetrics?: ModelMetrics; + + /** + *

          The last time the model package was modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          A description provided when the model approval is set.

          + */ + ApprovalDescription?: string; + + /** + *

          A list of the tags associated with the model package. For more information, see Tagging AWS + * resources in the AWS General Reference Guide.

          + */ + Tags?: Tag[]; +} + +export namespace ModelPackage { + export const filterSensitiveLog = (obj: ModelPackage): any => ({ + ...obj, + }); +} + +/** + *

          A group of versioned models in the model registry.

          + */ +export interface ModelPackageGroup { + /** + *

          The name of the model group.

          + */ + ModelPackageGroupName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the model group.

          + */ + ModelPackageGroupArn?: string; + + /** + *

          The description for the model group.

          + */ + ModelPackageGroupDescription?: string; + + /** + *

          The time that the model group was created.

          + */ + CreationTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          The status of the model group. This can be one of the following values.

          + *
            + *
          • + *

            + * PENDING - The model group is pending being created.

            + *
          • + *
          • + *

            + * IN_PROGRESS - The model group is in the process of being + * created.

            + *
          • + *
          • + *

            + * COMPLETED - The model group was successfully created.

            + *
          • + *
          • + *

            + * FAILED - The model group failed.

            + *
          • + *
          • + *

            + * DELETING - The model group is in the process of being deleted.

            + *
          • + *
          • + *

            + * DELETE_FAILED - SageMaker failed to delete the model group.

            + *
          • + *
          + */ + ModelPackageGroupStatus?: ModelPackageGroupStatus | string; + + /** + *

          A list of the tags associated with the model group. For more information, see Tagging AWS + * resources in the AWS General Reference Guide.

          + */ + Tags?: Tag[]; +} + +export namespace ModelPackageGroup { + export const filterSensitiveLog = (obj: ModelPackageGroup): any => ({ + ...obj, + }); +} + +/** + *

          A list of nested Filter objects. A resource must satisfy the conditions + * of all filters to be included in the results returned from the Search API.

          + *

          For example, to filter on a training job's InputDataConfig property with a + * specific channel name and S3Uri prefix, define the following filters:

          + *
            + *
          • + *

            + * '{Name:"InputDataConfig.ChannelName", "Operator":"Equals", "Value":"train"}', + *

            + *
          • + *
          • + *

            + * '{Name:"InputDataConfig.DataSource.S3DataSource.S3Uri", "Operator":"Contains", + * "Value":"mybucket/catdata"}' + *

            + *
          • + *
          + */ +export interface NestedFilters { + /** + *

          The name of the property to use in the nested filters. The value must match a listed property name, + * such as InputDataConfig.

          + */ + NestedPropertyName: string | undefined; + + /** + *

          A list of filters. Each filter acts on a property. Filters must contain at least one + * Filters value. For example, a NestedFilters call might + * include a filter on the PropertyName parameter of the + * InputDataConfig property: + * InputDataConfig.DataSource.S3DataSource.S3Uri.

          + */ + Filters: Filter[] | undefined; +} + +export namespace NestedFilters { + export const filterSensitiveLog = (obj: NestedFilters): any => ({ + ...obj, + }); +} + +/** + *

          The trial that a trial component is associated with and the experiment the trial is part + * of. A component might not be associated with a trial. A component can be associated with + * multiple trials.

          + */ +export interface Parent { + /** + *

          The name of the trial.

          + */ + TrialName?: string; + + /** + *

          The name of the experiment.

          + */ + ExperimentName?: string; +} + +export namespace Parent { + export const filterSensitiveLog = (obj: Parent): any => ({ + ...obj, + }); +} + +/** + *

          A SageMaker Model Building Pipeline instance.

          + */ +export interface Pipeline { + /** + *

          The Amazon Resource Name (ARN) of the pipeline.

          + */ + PipelineArn?: string; + + /** + *

          The name of the pipeline.

          + */ + PipelineName?: string; + + /** + *

          The display name of the pipeline.

          + */ + PipelineDisplayName?: string; + + /** + *

          The description of the pipeline.

          + */ + PipelineDescription?: string; + + /** + *

          The Amazon Resource Name (ARN) of the role that created the pipeline.

          + */ + RoleArn?: string; + + /** + *

          The status of the pipeline.

          + */ + PipelineStatus?: PipelineStatus | string; + + /** + *

          The creation time of the pipeline.

          + */ + CreationTime?: Date; + + /** + *

          The time that the pipeline was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The time when the pipeline was last run.

          + */ + LastRunTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          A list of tags that apply to the pipeline.

          + */ + Tags?: Tag[]; +} + +export namespace Pipeline { + export const filterSensitiveLog = (obj: Pipeline): any => ({ + ...obj, + }); +} + +/** + *

          An execution of a pipeline.

          + */ +export interface PipelineExecution { + /** + *

          The Amazon Resource Name (ARN) of the pipeline that was executed.

          + */ + PipelineArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn?: string; + + /** + *

          The display name of the pipeline execution.

          + */ + PipelineExecutionDisplayName?: string; + + /** + *

          The status of the pipeline status.

          + */ + PipelineExecutionStatus?: PipelineExecutionStatus | string; + + /** + *

          The description of the pipeline execution.

          + */ + PipelineExecutionDescription?: string; + + /** + *

          The creation time of the pipeline execution.

          + */ + CreationTime?: Date; + + /** + *

          The time that the pipeline execution was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          Contains a list of pipeline parameters. This list can be empty.

          + */ + PipelineParameters?: Parameter[]; +} + +export namespace PipelineExecution { + export const filterSensitiveLog = (obj: PipelineExecution): any => ({ + ...obj, + }); +} + +/** + *

          An Amazon SageMaker processing job that is used to analyze data and evaluate models. For more information, + * see Process + * Data and Evaluate Models.

          + */ +export interface ProcessingJob { + /** + *

          List of input configurations for the processing job.

          + */ + ProcessingInputs?: ProcessingInput[]; + + /** + *

          The output configuration for the processing job.

          + */ + ProcessingOutputConfig?: ProcessingOutputConfig; + + /** + *

          The name of the processing job.

          + */ + ProcessingJobName?: string; + + /** + *

          Identifies the resources, ML compute instances, and ML storage volumes to deploy for a + * processing job. In distributed training, you specify more than one instance.

          + */ + ProcessingResources?: ProcessingResources; + + /** + *

          Specifies a time limit for how long the processing job is allowed to run.

          + */ + StoppingCondition?: ProcessingStoppingCondition; + + /** + *

          Configuration to run a processing job in a specified container image.

          + */ + AppSpecification?: AppSpecification; + + /** + *

          Sets the environment variables in the Docker container.

          + */ + Environment?: { [key: string]: string }; + + /** + *

          Networking options for a job, such as network traffic encryption between containers, + * whether to allow inbound and outbound network calls to and from containers, and the VPC + * subnets and security groups to use for VPC-enabled jobs.

          + */ + NetworkConfig?: NetworkConfig; + + /** + *

          The ARN of the role used to create the processing job.

          + */ + RoleArn?: string; + + /** + *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

          + * + */ + ExperimentConfig?: ExperimentConfig; + + /** + *

          The ARN of the processing job.

          + */ + ProcessingJobArn?: string; + + /** + *

          The status of the processing job.

          + */ + ProcessingJobStatus?: ProcessingJobStatus | string; + + /** + *

          A string, up to one KB in size, that contains metadata from the processing + * container when the processing job exits.

          + */ + ExitMessage?: string; + + /** + *

          A string, up to one KB in size, that contains the reason a processing job failed, if + * it failed.

          + */ + FailureReason?: string; + + /** + *

          The time that the processing job ended.

          + */ + ProcessingEndTime?: Date; + + /** + *

          The time that the processing job started.

          + */ + ProcessingStartTime?: Date; + + /** + *

          The time the processing job was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          The time the processing job was created.

          + */ + CreationTime?: Date; + + /** + *

          The ARN of a monitoring schedule for an endpoint associated with this processing + * job.

          + */ + MonitoringScheduleArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the AutoML job associated with this processing job.

          + */ + AutoMLJobArn?: string; + + /** + *

          The ARN of the training job associated with this processing job.

          + */ + TrainingJobArn?: string; + + /** + *

          An array of key-value pairs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management + * User Guide.

          + */ + Tags?: Tag[]; +} + +export namespace ProcessingJob { + export const filterSensitiveLog = (obj: ProcessingJob): any => ({ + ...obj, + }); +} + +export interface PutModelPackageGroupPolicyInput { + /** + *

          The name of the model group to add a resource policy to.

          + */ + ModelPackageGroupName: string | undefined; + + /** + *

          The resource policy for the model group.

          + */ + ResourcePolicy: string | undefined; +} + +export namespace PutModelPackageGroupPolicyInput { + export const filterSensitiveLog = (obj: PutModelPackageGroupPolicyInput): any => ({ + ...obj, + }); +} + +export interface PutModelPackageGroupPolicyOutput { + /** + *

          The Amazon Resource Name (ARN) of the model package group.

          + */ + ModelPackageGroupArn: string | undefined; +} + +export namespace PutModelPackageGroupPolicyOutput { + export const filterSensitiveLog = (obj: PutModelPackageGroupPolicyOutput): any => ({ + ...obj, + }); +} + +/** + *

          Contains input values for a task.

          + */ +export interface RenderableTask { + /** + *

          A JSON object that contains values for the variables defined in the template. It is + * made available to the template under the substitution variable task.input. + * For example, if you define a variable task.input.text in your template, you + * can supply the variable in the JSON object as "text": "sample text".

          + */ + Input: string | undefined; +} + +export namespace RenderableTask { + export const filterSensitiveLog = (obj: RenderableTask): any => ({ + ...obj, + }); +} + +/** + *

          A description of an error that occurred while rendering the template.

          + */ +export interface RenderingError { + /** + *

          A unique identifier for a specific class of errors.

          + */ + Code: string | undefined; + + /** + *

          A human-readable message describing the error.

          + */ + Message: string | undefined; +} + +export namespace RenderingError { + export const filterSensitiveLog = (obj: RenderingError): any => ({ + ...obj, + }); +} + +export interface RenderUiTemplateRequest { + /** + *

          A Template object containing the worker UI template to render.

          + */ + UiTemplate?: UiTemplate; + + /** + *

          A RenderableTask object containing a representative task to + * render.

          + */ + Task: RenderableTask | undefined; + + /** + *

          The Amazon Resource Name (ARN) that has access to the S3 objects that are used by the + * template.

          + */ + RoleArn: string | undefined; + + /** + *

          The HumanTaskUiArn of the worker UI that you want to render. Do not + * provide a HumanTaskUiArn if you use the UiTemplate + * parameter.

          + *

          See a list of available Human Ui Amazon Resource Names (ARNs) in UiConfig.

          + */ + HumanTaskUiArn?: string; +} + +export namespace RenderUiTemplateRequest { + export const filterSensitiveLog = (obj: RenderUiTemplateRequest): any => ({ + ...obj, + }); +} + +export interface RenderUiTemplateResponse { + /** + *

          A Liquid template that renders the HTML for the worker UI.

          + */ + RenderedContent: string | undefined; + + /** + *

          A list of one or more RenderingError objects if any were encountered + * while rendering the template. If there were no errors, the list is empty.

          + */ + Errors: RenderingError[] | undefined; +} + +export namespace RenderUiTemplateResponse { + export const filterSensitiveLog = (obj: RenderUiTemplateResponse): any => ({ + ...obj, + }); +} + +export enum SearchSortOrder { + ASCENDING = "Ascending", + DESCENDING = "Descending", +} + +/** + *

          Contains information about a training job.

          + */ +export interface TrainingJob { + /** + *

          The name of the training job.

          + */ + TrainingJobName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the training job.

          + */ + TrainingJobArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the associated hyperparameter tuning job if the + * training job was launched by a hyperparameter tuning job.

          + */ + TuningJobArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the labeling job.

          + */ + LabelingJobArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the job.

          + */ + AutoMLJobArn?: string; + + /** + *

          Information about the Amazon S3 location that is configured for storing model + * artifacts.

          + */ + ModelArtifacts?: ModelArtifacts; + + /** + *

          The status of the + * training + * job.

          + *

          Training job statuses are:

          + *
            + *
          • + *

            + * InProgress - The training is in progress.

            + *
          • + *
          • + *

            + * Completed - The training job has completed.

            + *
          • + *
          • + *

            + * Failed - The training job has failed. To see the reason for the + * failure, see the FailureReason field in the response to a + * DescribeTrainingJobResponse call.

            + *
          • + *
          • + *

            + * Stopping - The training job is stopping.

            + *
          • + *
          • + *

            + * Stopped - The training job has stopped.

            + *
          • + *
          + *

          For + * more detailed information, see SecondaryStatus.

          + */ + TrainingJobStatus?: TrainingJobStatus | string; + + /** + *

          Provides detailed information about the state of the training job. For detailed + * information about the secondary status of the training job, see + * StatusMessage under SecondaryStatusTransition.

          + *

          Amazon SageMaker provides primary statuses and secondary statuses that apply to each of + * them:

          + *
          + *
          InProgress
          + *
          + *
            + *
          • + *

            + * Starting + * - Starting the training job.

            + *
          • + *
          • + *

            + * Downloading - An optional stage for algorithms that + * support File training input mode. It indicates that + * data is being downloaded to the ML storage volumes.

            + *
          • + *
          • + *

            + * Training - Training is in progress.

            + *
          • + *
          • + *

            + * Uploading - Training is complete and the model + * artifacts are being uploaded to the S3 location.

            + *
          • + *
          + *
          + *
          Completed
          + *
          + *
            + *
          • + *

            + * Completed - The training job has completed.

            + *
          • + *
          + *
          + *
          Failed
          + *
          + *
            + *
          • + *

            + * Failed - The training job has failed. The reason for + * the failure is returned in the FailureReason field of + * DescribeTrainingJobResponse.

            + *
          • + *
          + *
          + *
          Stopped
          + *
          + *
            + *
          • + *

            + * MaxRuntimeExceeded - The job stopped because it + * exceeded the maximum allowed runtime.

            + *
          • + *
          • + *

            + * Stopped - The training job has stopped.

            + *
          • + *
          + *
          + *
          Stopping
          + *
          + *
            + *
          • + *

            + * Stopping - Stopping the training job.

            + *
          • + *
          + *
          + *
          + * + *

          Valid values for SecondaryStatus are subject to change.

          + *
          + *

          We no longer support the following secondary statuses:

          + *
            + *
          • + *

            + * LaunchingMLInstances + *

            + *
          • + *
          • + *

            + * PreparingTrainingStack + *

            + *
          • + *
          • + *

            + * DownloadingTrainingImage + *

            + *
          • + *
          + */ + SecondaryStatus?: SecondaryStatus | string; + + /** + *

          If the training job failed, the reason it failed.

          + */ + FailureReason?: string; + + /** + *

          Algorithm-specific parameters.

          + */ + HyperParameters?: { [key: string]: string }; + + /** + *

          Information about the algorithm used for training, and algorithm metadata.

          + */ + AlgorithmSpecification?: AlgorithmSpecification; + + /** + *

          The AWS Identity and Access Management (IAM) role configured for the training job.

          + */ + RoleArn?: string; + + /** + *

          An array of Channel objects that describes each data input + * channel.

          + */ + InputDataConfig?: Channel[]; + + /** + *

          The S3 path where model artifacts that you configured when creating the job are + * stored. Amazon SageMaker creates subfolders for model artifacts.

          + */ + OutputDataConfig?: OutputDataConfig; + + /** + *

          Resources, including ML compute instances and ML storage volumes, that are configured + * for model training.

          + */ + ResourceConfig?: ResourceConfig; + + /** + *

          A VpcConfig object that specifies the VPC that this training job has + * access to. For more information, see Protect Training Jobs by Using an Amazon + * Virtual Private Cloud.

          + */ + VpcConfig?: VpcConfig; + + /** + *

          Specifies a limit to how long a model training job can run. When the job reaches the + * time limit, Amazon SageMaker ends the training job. Use this API to cap model training costs.

          + *

          To stop a job, Amazon SageMaker sends the algorithm the SIGTERM signal, which delays + * job termination for 120 seconds. Algorithms can use this 120-second window to save the + * model artifacts, so the results of training are not lost.

          + */ + StoppingCondition?: StoppingCondition; + + /** + *

          A timestamp that indicates when the training job was created.

          + */ + CreationTime?: Date; + + /** + *

          Indicates the time when the training job starts on training instances. You are billed + * for the time interval between this time and the value of TrainingEndTime. + * The start time in CloudWatch Logs might be later than this time. The difference is due to the time + * it takes to download the training data and to the size of the training container.

          + */ + TrainingStartTime?: Date; + + /** + *

          Indicates the time when the training job ends on training instances. You are billed + * for the time interval between the value of TrainingStartTime and this time. + * For successful jobs and stopped jobs, this is the time after model artifacts are + * uploaded. For failed jobs, this is the time when Amazon SageMaker detects a job failure.

          + */ + TrainingEndTime?: Date; + + /** + *

          A timestamp that indicates when the status of the training job was last + * modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          A history of all of the secondary statuses that the training job has transitioned + * through.

          + */ + SecondaryStatusTransitions?: SecondaryStatusTransition[]; + + /** + *

          A list of final metric values that are set when the training job completes. Used only + * if the training job was configured to use metrics.

          + */ + FinalMetricDataList?: MetricData[]; + + /** + *

          If the TrainingJob was created with network isolation, the value is set + * to true. If network isolation is enabled, nodes can't communicate beyond + * the VPC they run in.

          + */ + EnableNetworkIsolation?: boolean; + + /** + *

          To encrypt all communications between ML compute instances in distributed training, + * choose True. Encryption provides greater security for distributed training, + * but training might take longer. How long it takes depends on the amount of communication + * between compute instances, especially if you use a deep learning algorithm in + * distributed training.

          + */ + EnableInterContainerTrafficEncryption?: boolean; + + /** + *

          When true, enables managed spot training using Amazon EC2 Spot instances to run + * training jobs instead of on-demand instances. For more information, see Managed Spot Training.

          + */ + EnableManagedSpotTraining?: boolean; + + /** + *

          Contains information about the output location for managed spot training checkpoint + * data.

          + */ + CheckpointConfig?: CheckpointConfig; + + /** + *

          The training time in seconds.

          + */ + TrainingTimeInSeconds?: number; + + /** + *

          The billable time in seconds.

          + */ + BillableTimeInSeconds?: number; + + /** + *

          Configuration information for the debug hook parameters, collection configuration, and + * storage paths.

          + */ + DebugHookConfig?: DebugHookConfig; + + /** + *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

          + * + */ + ExperimentConfig?: ExperimentConfig; + + /** + *

          Information about the debug rule configuration.

          + */ + DebugRuleConfigurations?: DebugRuleConfiguration[]; + + /** + *

          Configuration of storage locations for TensorBoard output.

          + */ + TensorBoardOutputConfig?: TensorBoardOutputConfig; + + /** + *

          Information about the evaluation status of the rules for the training job.

          + */ + DebugRuleEvaluationStatuses?: DebugRuleEvaluationStatus[]; + + /** + *

          An array of key-value pairs. You can use tags to categorize your AWS resources in + * different ways, for example, by purpose, owner, or environment. For more information, + * see Tagging AWS + * Resources.

          + */ + Tags?: Tag[]; +} + +export namespace TrainingJob { + export const filterSensitiveLog = (obj: TrainingJob): any => ({ + ...obj, + }); +} + +/** + *

          A short summary of a trial component.

          + */ +export interface TrialComponentSimpleSummary { + /** + *

          The name of the trial component.

          + */ + TrialComponentName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the trial component.

          + */ + TrialComponentArn?: string; + + /** + *

          The Amazon Resource Name (ARN) and job type of the source of a trial component.

          + */ + TrialComponentSource?: TrialComponentSource; + + /** + *

          When the component was created.

          + */ + CreationTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; +} + +export namespace TrialComponentSimpleSummary { + export const filterSensitiveLog = (obj: TrialComponentSimpleSummary): any => ({ + ...obj, + }); +} + +/** + *

          The properties of a trial as returned by the Search API.

          + */ +export interface Trial { + /** + *

          The name of the trial.

          + */ + TrialName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the trial.

          + */ + TrialArn?: string; + + /** + *

          The name of the trial as displayed. If DisplayName isn't specified, + * TrialName is displayed.

          + */ + DisplayName?: string; + + /** + *

          The name of the experiment the trial is part of.

          + */ + ExperimentName?: string; + + /** + *

          The source of the trial.

          + */ + Source?: TrialSource; + + /** + *

          When the trial was created.

          + */ + CreationTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          Who last modified the trial.

          + */ + LastModifiedTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          Metadata properties of the tracking entity, trial, or trial component.

          + */ + MetadataProperties?: MetadataProperties; + + /** + *

          The list of tags that are associated with the trial. You can use Search + * API to search on the tags.

          + */ + Tags?: Tag[]; + + /** + *

          A list of the components associated with the trial. For each component, a summary of the + * component's properties is included.

          + */ + TrialComponentSummaries?: TrialComponentSimpleSummary[]; +} + +export namespace Trial { + export const filterSensitiveLog = (obj: Trial): any => ({ + ...obj, + }); +} + +/** + *

          A batch transform job. For information about SageMaker batch transform, see Use Batch + * Transform.

          + */ +export interface TransformJob { + /** + *

          The name of the transform job.

          + */ + TransformJobName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the transform job.

          + */ + TransformJobArn?: string; + + /** + *

          The status of the transform job.

          + *

          Transform job statuses are:

          + *
            + *
          • + *

            + * InProgress - The job is in progress.

            + *
          • + *
          • + *

            + * Completed - The job has completed.

            + *
          • + *
          • + *

            + * Failed - The transform job has failed. To see the reason for the failure, + * see the FailureReason field in the response to a + * DescribeTransformJob call.

            + *
          • + *
          • + *

            + * Stopping - The transform job is stopping.

            + *
          • + *
          • + *

            + * Stopped - The transform job has stopped.

            + *
          • + *
          + */ + TransformJobStatus?: TransformJobStatus | string; + + /** + *

          If the transform job failed, the reason it failed.

          + */ + FailureReason?: string; + + /** + *

          The name of the model associated with the transform job.

          + */ + ModelName?: string; + + /** + *

          The maximum number of parallel requests that can be sent to each instance in a transform + * job. If MaxConcurrentTransforms is set to 0 or left unset, SageMaker checks the + * optional execution-parameters to determine the settings for your chosen algorithm. If the + * execution-parameters endpoint is not enabled, the default value is 1. For built-in algorithms, + * you don't need to set a value for MaxConcurrentTransforms.

          + */ + MaxConcurrentTransforms?: number; + + /** + *

          Configures the timeout and maximum number of retries for processing a transform job + * invocation.

          + */ + ModelClientConfig?: ModelClientConfig; + + /** + *

          The maximum allowed size of the payload, in MB. A payload is the data portion of a record + * (without metadata). The value in MaxPayloadInMB must be greater than, or equal + * to, the size of a single record. To estimate the size of a record in MB, divide the size of + * your dataset by the number of records. To ensure that the records fit within the maximum + * payload size, we recommend using a slightly larger value. The default value is 6 MB. For cases + * where the payload might be arbitrarily large and is transmitted using HTTP chunked encoding, + * set the value to 0. This feature works only in supported algorithms. Currently, SageMaker built-in + * algorithms do not support HTTP chunked encoding.

          + */ + MaxPayloadInMB?: number; + + /** + *

          Specifies the number of records to include in a mini-batch for an HTTP inference request. + * A record is a single unit of input data that inference can be made on. For example, a single + * line in a CSV file is a record.

          + */ + BatchStrategy?: BatchStrategy | string; + + /** + *

          The environment variables to set in the Docker container. We support up to 16 key and + * values entries in the map.

          + */ + Environment?: { [key: string]: string }; + + /** + *

          Describes the input source of a transform job and the way the transform job consumes + * it.

          + */ + TransformInput?: TransformInput; + + /** + *

          Describes the results of a transform job.

          + */ + TransformOutput?: TransformOutput; + + /** + *

          Describes the resources, including ML instance types and ML instance count, to use for + * transform job.

          + */ + TransformResources?: TransformResources; + + /** + *

          A timestamp that shows when the transform Job was created.

          + */ + CreationTime?: Date; + + /** + *

          Indicates when the transform job starts on ML instances. You are billed for the time + * interval between this time and the value of TransformEndTime.

          + */ + TransformStartTime?: Date; + + /** + *

          Indicates when the transform job has been completed, or has stopped or failed. You are + * billed for the time interval between this time and the value of + * TransformStartTime.

          + */ + TransformEndTime?: Date; + + /** + *

          The Amazon Resource Name (ARN) of the labeling job that created the transform job.

          + */ + LabelingJobArn?: string; + + /** + *

          The Amazon Resource Name (ARN) of the AutoML job that created the transform job.

          + */ + AutoMLJobArn?: string; + + /** + *

          The data structure used to specify the data to be used for inference in a batch + * transform job and to associate the data that is relevant to the prediction results in + * the output. The input filter provided allows you to exclude input data that is not + * needed for inference in a batch transform job. The output filter provided allows you to + * include input data relevant to interpreting the predictions in the output from the job. + * For more information, see Associate Prediction + * Results with their Corresponding Input Records.

          + */ + DataProcessing?: DataProcessing; + + /** + *

          Associates a SageMaker job as a trial component with an experiment and trial. Specified when + * you call the following APIs:

          + * + */ + ExperimentConfig?: ExperimentConfig; + + /** + *

          A list of tags associated with the transform job.

          + */ + Tags?: Tag[]; +} + +export namespace TransformJob { + export const filterSensitiveLog = (obj: TransformJob): any => ({ + ...obj, + }); +} + +/** + *

          Detailed information about the source of a trial component. Either + * ProcessingJob or TrainingJob is returned.

          + */ +export interface TrialComponentSourceDetail { + /** + *

          The Amazon Resource Name (ARN) of the source.

          + */ + SourceArn?: string; + + /** + *

          Information about a training job that's the source of a trial component.

          + */ + TrainingJob?: TrainingJob; + + /** + *

          Information about a processing job that's the source of a trial component.

          + */ + ProcessingJob?: ProcessingJob; + + /** + *

          Information about a transform job that's the source of a trial component.

          + */ + TransformJob?: TransformJob; +} + +export namespace TrialComponentSourceDetail { + export const filterSensitiveLog = (obj: TrialComponentSourceDetail): any => ({ + ...obj, + }); +} + +/** + *

          The properties of a trial component as returned by the Search + * API.

          + */ +export interface TrialComponent { + /** + *

          The name of the trial component.

          + */ + TrialComponentName?: string; + + /** + *

          The name of the component as displayed. If DisplayName isn't specified, + * TrialComponentName is displayed.

          + */ + DisplayName?: string; + + /** + *

          The Amazon Resource Name (ARN) of the trial component.

          + */ + TrialComponentArn?: string; + + /** + *

          The Amazon Resource Name (ARN) and job type of the source of the component.

          + */ + Source?: TrialComponentSource; + + /** + *

          The status of the trial component.

          + */ + Status?: TrialComponentStatus; + + /** + *

          When the component started.

          + */ + StartTime?: Date; + + /** + *

          When the component ended.

          + */ + EndTime?: Date; + + /** + *

          When the component was created.

          + */ + CreationTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + CreatedBy?: UserContext; + + /** + *

          When the component was last modified.

          + */ + LastModifiedTime?: Date; + + /** + *

          Information about the user who created or modified an experiment, trial, or trial + * component.

          + */ + LastModifiedBy?: UserContext; + + /** + *

          The hyperparameters of the component.

          + */ + Parameters?: { [key: string]: TrialComponentParameterValue }; + + /** + *

          The input artifacts of the component.

          + */ + InputArtifacts?: { [key: string]: TrialComponentArtifact }; + + /** + *

          The output artifacts of the component.

          + */ + OutputArtifacts?: { [key: string]: TrialComponentArtifact }; + + /** + *

          The metrics for the component.

          + */ + Metrics?: TrialComponentMetricSummary[]; + + /** + *

          Metadata properties of the tracking entity, trial, or trial component.

          + */ + MetadataProperties?: MetadataProperties; + + /** + *

          Details of the source of the component.

          + */ + SourceDetail?: TrialComponentSourceDetail; + + /** + *

          The list of tags that are associated with the component. You can use Search API to search on the tags.

          + */ + Tags?: Tag[]; + + /** + *

          An array of the parents of the component. A parent is a trial the component is associated + * with and the experiment the trial is part of. A component might not have any parents.

          + */ + Parents?: Parent[]; +} + +export namespace TrialComponent { + export const filterSensitiveLog = (obj: TrialComponent): any => ({ + ...obj, + ...(obj.Parameters && { + Parameters: Object.entries(obj.Parameters).reduce( + (acc: any, [key, value]: [string, TrialComponentParameterValue]) => ({ + ...acc, + [key]: TrialComponentParameterValue.filterSensitiveLog(value), + }), + {} + ), + }), + }); +} + +/** + *

          A single resource returned as part of the Search API response.

          + */ +export interface SearchRecord { + /** + *

          The properties of a training job.

          + */ + TrainingJob?: TrainingJob; + + /** + *

          The properties of an experiment.

          + */ + Experiment?: Experiment; + + /** + *

          The properties of a trial.

          + */ + Trial?: Trial; + + /** + *

          The properties of a trial component.

          + */ + TrialComponent?: TrialComponent; + + /** + *

          A hosted endpoint for real-time inference.

          + */ + Endpoint?: Endpoint; + + /** + *

          A versioned model that can be deployed for SageMaker inference.

          + */ + ModelPackage?: ModelPackage; + + /** + *

          A group of versioned models in the model registry.

          + */ + ModelPackageGroup?: ModelPackageGroup; + + /** + *

          A SageMaker Model Building Pipeline instance.

          + */ + Pipeline?: Pipeline; + + /** + *

          An execution of a pipeline.

          + */ + PipelineExecution?: PipelineExecution; + + /** + *

          Amazon SageMaker Feature Store stores features in a collection called Feature Group. + * A Feature Group can be visualized as a table which has rows, + * with a unique identifier for each row where each column in the table is a feature. + * In principle, a Feature Group is composed of features and values per features.

          + */ + FeatureGroup?: FeatureGroup; +} + +export namespace SearchRecord { + export const filterSensitiveLog = (obj: SearchRecord): any => ({ + ...obj, + ...(obj.TrialComponent && { TrialComponent: TrialComponent.filterSensitiveLog(obj.TrialComponent) }), + }); +} + +export interface SearchResponse { + /** + *

          A list of SearchRecord objects.

          + */ + Results?: SearchRecord[]; + + /** + *

          If the result of the previous Search request was truncated, the response + * includes a NextToken. To retrieve the next set of results, use the token in the next + * request.

          + */ + NextToken?: string; +} + +export namespace SearchResponse { + export const filterSensitiveLog = (obj: SearchResponse): any => ({ + ...obj, + }); +} + +export interface StartMonitoringScheduleRequest { + /** + *

          The name of the schedule to start.

          + */ + MonitoringScheduleName: string | undefined; +} + +export namespace StartMonitoringScheduleRequest { + export const filterSensitiveLog = (obj: StartMonitoringScheduleRequest): any => ({ + ...obj, + }); +} + +export interface StartNotebookInstanceInput { + /** + *

          The name of the notebook instance to start.

          + */ + NotebookInstanceName: string | undefined; +} + +export namespace StartNotebookInstanceInput { + export const filterSensitiveLog = (obj: StartNotebookInstanceInput): any => ({ + ...obj, + }); +} + +export interface StartPipelineExecutionRequest { + /** + *

          The name of the pipeline.

          + */ + PipelineName: string | undefined; + + /** + *

          The display name of the pipeline execution.

          + */ + PipelineExecutionDisplayName?: string; + + /** + *

          Contains a list of pipeline parameters. This list can be empty.

          + */ + PipelineParameters?: Parameter[]; + + /** + *

          The description of the pipeline execution.

          + */ + PipelineExecutionDescription?: string; + + /** + *

          A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * operation. An idempotent operation completes no more than one time.

          + */ + ClientRequestToken?: string; +} + +export namespace StartPipelineExecutionRequest { + export const filterSensitiveLog = (obj: StartPipelineExecutionRequest): any => ({ + ...obj, + }); +} + +export interface StartPipelineExecutionResponse { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn?: string; +} + +export namespace StartPipelineExecutionResponse { + export const filterSensitiveLog = (obj: StartPipelineExecutionResponse): any => ({ + ...obj, + }); +} + +export interface StopAutoMLJobRequest { + /** + *

          The name of the object you are requesting.

          + */ + AutoMLJobName: string | undefined; +} + +export namespace StopAutoMLJobRequest { + export const filterSensitiveLog = (obj: StopAutoMLJobRequest): any => ({ + ...obj, + }); +} + +export interface StopCompilationJobRequest { + /** + *

          The name of the model compilation job to stop.

          + */ + CompilationJobName: string | undefined; +} + +export namespace StopCompilationJobRequest { + export const filterSensitiveLog = (obj: StopCompilationJobRequest): any => ({ + ...obj, + }); +} + +export interface StopHyperParameterTuningJobRequest { + /** + *

          The name of the tuning job to stop.

          + */ + HyperParameterTuningJobName: string | undefined; +} + +export namespace StopHyperParameterTuningJobRequest { + export const filterSensitiveLog = (obj: StopHyperParameterTuningJobRequest): any => ({ + ...obj, + }); +} + +export interface StopLabelingJobRequest { + /** + *

          The name of the labeling job to stop.

          + */ + LabelingJobName: string | undefined; +} + +export namespace StopLabelingJobRequest { + export const filterSensitiveLog = (obj: StopLabelingJobRequest): any => ({ + ...obj, + }); +} + +export interface StopMonitoringScheduleRequest { + /** + *

          The name of the schedule to stop.

          + */ + MonitoringScheduleName: string | undefined; +} + +export namespace StopMonitoringScheduleRequest { + export const filterSensitiveLog = (obj: StopMonitoringScheduleRequest): any => ({ + ...obj, + }); +} + +export interface StopNotebookInstanceInput { + /** + *

          The name of the notebook instance to terminate.

          + */ + NotebookInstanceName: string | undefined; +} + +export namespace StopNotebookInstanceInput { + export const filterSensitiveLog = (obj: StopNotebookInstanceInput): any => ({ + ...obj, + }); +} + +export interface StopPipelineExecutionRequest { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn: string | undefined; + + /** + *

          A unique, case-sensitive identifier that you provide to ensure the idempotency of the + * operation. An idempotent operation completes no more than one time.

          + */ + ClientRequestToken?: string; +} + +export namespace StopPipelineExecutionRequest { + export const filterSensitiveLog = (obj: StopPipelineExecutionRequest): any => ({ + ...obj, + }); +} + +export interface StopPipelineExecutionResponse { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn?: string; +} + +export namespace StopPipelineExecutionResponse { + export const filterSensitiveLog = (obj: StopPipelineExecutionResponse): any => ({ + ...obj, + }); +} + +export interface StopProcessingJobRequest { + /** + *

          The name of the processing job to stop.

          + */ + ProcessingJobName: string | undefined; +} + +export namespace StopProcessingJobRequest { + export const filterSensitiveLog = (obj: StopProcessingJobRequest): any => ({ + ...obj, + }); +} + +export interface StopTrainingJobRequest { + /** + *

          The name of the training job to stop.

          + */ + TrainingJobName: string | undefined; +} + +export namespace StopTrainingJobRequest { + export const filterSensitiveLog = (obj: StopTrainingJobRequest): any => ({ + ...obj, + }); +} + +export interface StopTransformJobRequest { + /** + *

          The name of the transform job to stop.

          + */ + TransformJobName: string | undefined; +} + +export namespace StopTransformJobRequest { + export const filterSensitiveLog = (obj: StopTransformJobRequest): any => ({ + ...obj, + }); +} + +export interface UpdateActionRequest { + /** + *

          The name of the action to update.

          + */ + ActionName: string | undefined; + + /** + *

          The new description for the action.

          + */ + Description?: string; + + /** + *

          The new status for the action.

          + */ + Status?: ActionStatus | string; + + /** + *

          The new list of properties. Overwrites the current property list.

          + */ + Properties?: { [key: string]: string }; + + /** + *

          A list of properties to remove.

          + */ + PropertiesToRemove?: string[]; +} + +export namespace UpdateActionRequest { + export const filterSensitiveLog = (obj: UpdateActionRequest): any => ({ + ...obj, + }); +} + +export interface UpdateActionResponse { + /** + *

          The Amazon Resource Name (ARN) of the action.

          + */ + ActionArn?: string; +} + +export namespace UpdateActionResponse { + export const filterSensitiveLog = (obj: UpdateActionResponse): any => ({ + ...obj, + }); +} + +export interface UpdateAppImageConfigRequest { + /** + *

          The name of the AppImageConfig to update.

          + */ + AppImageConfigName: string | undefined; + + /** + *

          The new KernelGateway app to run on the image.

          + */ + KernelGatewayImageConfig?: KernelGatewayImageConfig; +} + +export namespace UpdateAppImageConfigRequest { + export const filterSensitiveLog = (obj: UpdateAppImageConfigRequest): any => ({ + ...obj, + }); +} + +export interface UpdateAppImageConfigResponse { + /** + *

          The Amazon Resource Name (ARN) for the AppImageConfig.

          + */ + AppImageConfigArn?: string; +} + +export namespace UpdateAppImageConfigResponse { + export const filterSensitiveLog = (obj: UpdateAppImageConfigResponse): any => ({ + ...obj, + }); +} + +export interface UpdateArtifactRequest { + /** + *

          The Amazon Resource Name (ARN) of the artifact to update.

          + */ + ArtifactArn: string | undefined; + + /** + *

          The new name for the artifact.

          + */ + ArtifactName?: string; + + /** + *

          The new list of properties. Overwrites the current property list.

          + */ + Properties?: { [key: string]: string }; + + /** + *

          A list of properties to remove.

          + */ + PropertiesToRemove?: string[]; +} + +export namespace UpdateArtifactRequest { + export const filterSensitiveLog = (obj: UpdateArtifactRequest): any => ({ + ...obj, + }); +} + +export interface UpdateArtifactResponse { + /** + *

          The Amazon Resource Name (ARN) of the artifact.

          + */ + ArtifactArn?: string; +} + +export namespace UpdateArtifactResponse { + export const filterSensitiveLog = (obj: UpdateArtifactResponse): any => ({ + ...obj, + }); +} + +export interface UpdateCodeRepositoryInput { + /** + *

          The name of the Git repository to update.

          + */ + CodeRepositoryName: string | undefined; + + /** + *

          The configuration of the git repository, including the URL and the Amazon Resource + * Name (ARN) of the AWS Secrets Manager secret that contains the credentials used to + * access the repository. The secret must have a staging label of AWSCURRENT + * and must be in the following format:

          + *

          + * {"username": UserName, "password": + * Password} + *

          + */ + GitConfig?: GitConfigForUpdate; +} + +export namespace UpdateCodeRepositoryInput { + export const filterSensitiveLog = (obj: UpdateCodeRepositoryInput): any => ({ + ...obj, + }); +} + +export interface UpdateCodeRepositoryOutput { + /** + *

          The ARN of the Git repository.

          + */ + CodeRepositoryArn: string | undefined; +} + +export namespace UpdateCodeRepositoryOutput { + export const filterSensitiveLog = (obj: UpdateCodeRepositoryOutput): any => ({ + ...obj, + }); +} + +export interface UpdateContextRequest { + /** + *

          The name of the context to update.

          + */ + ContextName: string | undefined; + + /** + *

          The new description for the context.

          + */ + Description?: string; + + /** + *

          The new list of properties. Overwrites the current property list.

          + */ + Properties?: { [key: string]: string }; + + /** + *

          A list of properties to remove.

          + */ + PropertiesToRemove?: string[]; +} + +export namespace UpdateContextRequest { + export const filterSensitiveLog = (obj: UpdateContextRequest): any => ({ + ...obj, + }); +} + +export interface UpdateContextResponse { + /** + *

          The Amazon Resource Name (ARN) of the context.

          + */ + ContextArn?: string; +} + +export namespace UpdateContextResponse { + export const filterSensitiveLog = (obj: UpdateContextResponse): any => ({ + ...obj, + }); +} + +export interface UpdateDomainRequest { + /** + *

          The ID of the domain to be updated.

          + */ + DomainId: string | undefined; + + /** + *

          A collection of settings.

          + */ + DefaultUserSettings?: UserSettings; +} + +export namespace UpdateDomainRequest { + export const filterSensitiveLog = (obj: UpdateDomainRequest): any => ({ + ...obj, + }); +} + +export interface UpdateDomainResponse { + /** + *

          The Amazon Resource Name (ARN) of the domain.

          + */ + DomainArn?: string; +} + +export namespace UpdateDomainResponse { + export const filterSensitiveLog = (obj: UpdateDomainResponse): any => ({ + ...obj, + }); +} + +export enum VariantPropertyType { + DataCaptureConfig = "DataCaptureConfig", + DesiredInstanceCount = "DesiredInstanceCount", + DesiredWeight = "DesiredWeight", +} + +/** + *

          Specifies a production variant property type for an Endpoint.

          + *

          If you are updating an endpoint with the UpdateEndpointInput$RetainAllVariantProperties option set to + * true, the VariantProperty objects listed in UpdateEndpointInput$ExcludeRetainedVariantProperties override the + * existing variant properties of the endpoint.

          + */ +export interface VariantProperty { + /** + *

          The type of variant property. The supported values are:

          + * + */ + VariantPropertyType: VariantPropertyType | string | undefined; +} + +export namespace VariantProperty { + export const filterSensitiveLog = (obj: VariantProperty): any => ({ + ...obj, + }); +} + export interface UpdateEndpointInput { /** *

          The name of the endpoint whose configuration you want to update.

          @@ -38,12 +6146,13 @@ export interface UpdateEndpointInput { EndpointConfigName: string | undefined; /** - *

          When updating endpoint resources, enables or disables the retention of variant - * properties, such as the instance count or the variant weight. To retain the variant + *

          When updating endpoint resources, enables or disables the retention of variant + * properties, such as the instance count or the variant weight. To retain the variant * properties of an endpoint when updating it, set RetainAllVariantProperties * to true. To use the variant properties specified in a new * EndpointConfig call when updating an endpoint, set - * RetainAllVariantProperties to false.

          + * RetainAllVariantProperties to false. The default is + * false.

          */ RetainAllVariantProperties?: boolean; @@ -56,6 +6165,11 @@ export interface UpdateEndpointInput { *

          */ ExcludeRetainedVariantProperties?: VariantProperty[]; + + /** + *

          The deployment configuration for the endpoint to be updated.

          + */ + DeploymentConfig?: DeploymentConfig; } export namespace UpdateEndpointInput { @@ -192,6 +6306,42 @@ export namespace UpdateImageResponse { }); } +export interface UpdateModelPackageInput { + /** + *

          The Amazon Resource Name (ARN) of the model.

          + */ + ModelPackageArn: string | undefined; + + /** + *

          The approval status of the model.

          + */ + ModelApprovalStatus: ModelApprovalStatus | string | undefined; + + /** + *

          A description for the approval status of the model.

          + */ + ApprovalDescription?: string; +} + +export namespace UpdateModelPackageInput { + export const filterSensitiveLog = (obj: UpdateModelPackageInput): any => ({ + ...obj, + }); +} + +export interface UpdateModelPackageOutput { + /** + *

          The Amazon Resource Name (ARN) of the model.

          + */ + ModelPackageArn: string | undefined; +} + +export namespace UpdateModelPackageOutput { + export const filterSensitiveLog = (obj: UpdateModelPackageOutput): any => ({ + ...obj, + }); +} + export interface UpdateMonitoringScheduleRequest { /** *

          The name of the monitoring schedule. The name must be unique within an AWS Region within @@ -382,6 +6532,88 @@ export namespace UpdateNotebookInstanceLifecycleConfigOutput { }); } +export interface UpdatePipelineRequest { + /** + *

          The name of the pipeline to update.

          + */ + PipelineName: string | undefined; + + /** + *

          The display name of the pipeline.

          + */ + PipelineDisplayName?: string; + + /** + *

          The JSON pipeline definition.

          + */ + PipelineDefinition?: string; + + /** + *

          The description of the pipeline.

          + */ + PipelineDescription?: string; + + /** + *

          The Amazon Resource Name (ARN) that the pipeline uses to execute.

          + */ + RoleArn?: string; +} + +export namespace UpdatePipelineRequest { + export const filterSensitiveLog = (obj: UpdatePipelineRequest): any => ({ + ...obj, + }); +} + +export interface UpdatePipelineResponse { + /** + *

          The Amazon Resource Name (ARN) of the updated pipeline.

          + */ + PipelineArn?: string; +} + +export namespace UpdatePipelineResponse { + export const filterSensitiveLog = (obj: UpdatePipelineResponse): any => ({ + ...obj, + }); +} + +export interface UpdatePipelineExecutionRequest { + /** + *

          The Amazon Resource Name (ARN) of the pipeline execution.

          + */ + PipelineExecutionArn: string | undefined; + + /** + *

          The description of the pipeline execution.

          + */ + PipelineExecutionDescription?: string; + + /** + *

          The display name of the pipeline execution.

          + */ + PipelineExecutionDisplayName?: string; +} + +export namespace UpdatePipelineExecutionRequest { + export const filterSensitiveLog = (obj: UpdatePipelineExecutionRequest): any => ({ + ...obj, + }); +} + +export interface UpdatePipelineExecutionResponse { + /** + *

          The Amazon Resource Name (ARN) of the updated pipeline execution.

          + */ + PipelineExecutionArn?: string; +} + +export namespace UpdatePipelineExecutionResponse { + export const filterSensitiveLog = (obj: UpdatePipelineExecutionResponse): any => ({ + ...obj, + }); +} + export interface UpdateTrialRequest { /** *

          The name of the trial to update.

          @@ -476,6 +6708,15 @@ export interface UpdateTrialComponentRequest { export namespace UpdateTrialComponentRequest { export const filterSensitiveLog = (obj: UpdateTrialComponentRequest): any => ({ ...obj, + ...(obj.Parameters && { + Parameters: Object.entries(obj.Parameters).reduce( + (acc: any, [key, value]: [string, TrialComponentParameterValue]) => ({ + ...acc, + [key]: TrialComponentParameterValue.filterSensitiveLog(value), + }), + {} + ), + }), }); } diff --git a/clients/client-sagemaker/pagination/ListActionsPaginator.ts b/clients/client-sagemaker/pagination/ListActionsPaginator.ts new file mode 100644 index 000000000000..dd2c41c2b1cf --- /dev/null +++ b/clients/client-sagemaker/pagination/ListActionsPaginator.ts @@ -0,0 +1,53 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { ListActionsCommand, ListActionsCommandInput, ListActionsCommandOutput } from "../commands/ListActionsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListActionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListActionsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListActionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listActions(input, ...args); +}; +export async function* paginateListActions( + config: SageMakerPaginationConfiguration, + input: ListActionsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListActionsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListAppImageConfigsPaginator.ts b/clients/client-sagemaker/pagination/ListAppImageConfigsPaginator.ts new file mode 100644 index 000000000000..2c8a0dba6ddd --- /dev/null +++ b/clients/client-sagemaker/pagination/ListAppImageConfigsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListAppImageConfigsCommand, + ListAppImageConfigsCommandInput, + ListAppImageConfigsCommandOutput, +} from "../commands/ListAppImageConfigsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListAppImageConfigsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListAppImageConfigsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListAppImageConfigsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listAppImageConfigs(input, ...args); +}; +export async function* paginateListAppImageConfigs( + config: SageMakerPaginationConfiguration, + input: ListAppImageConfigsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListAppImageConfigsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListArtifactsPaginator.ts b/clients/client-sagemaker/pagination/ListArtifactsPaginator.ts new file mode 100644 index 000000000000..1f5ffc7eb5a6 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListArtifactsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListArtifactsCommand, + ListArtifactsCommandInput, + ListArtifactsCommandOutput, +} from "../commands/ListArtifactsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListArtifactsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListArtifactsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListArtifactsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listArtifacts(input, ...args); +}; +export async function* paginateListArtifacts( + config: SageMakerPaginationConfiguration, + input: ListArtifactsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListArtifactsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListAssociationsPaginator.ts b/clients/client-sagemaker/pagination/ListAssociationsPaginator.ts new file mode 100644 index 000000000000..820f3a7f3c34 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListAssociationsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListAssociationsCommand, + ListAssociationsCommandInput, + ListAssociationsCommandOutput, +} from "../commands/ListAssociationsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListAssociationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListAssociationsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListAssociationsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listAssociations(input, ...args); +}; +export async function* paginateListAssociations( + config: SageMakerPaginationConfiguration, + input: ListAssociationsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListAssociationsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListContextsPaginator.ts b/clients/client-sagemaker/pagination/ListContextsPaginator.ts new file mode 100644 index 000000000000..ab2ab7804620 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListContextsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListContextsCommand, + ListContextsCommandInput, + ListContextsCommandOutput, +} from "../commands/ListContextsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListContextsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListContextsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListContextsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listContexts(input, ...args); +}; +export async function* paginateListContexts( + config: SageMakerPaginationConfiguration, + input: ListContextsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListContextsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListModelPackageGroupsPaginator.ts b/clients/client-sagemaker/pagination/ListModelPackageGroupsPaginator.ts new file mode 100644 index 000000000000..ab9d92b678f2 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListModelPackageGroupsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListModelPackageGroupsCommand, + ListModelPackageGroupsCommandInput, + ListModelPackageGroupsCommandOutput, +} from "../commands/ListModelPackageGroupsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListModelPackageGroupsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListModelPackageGroupsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListModelPackageGroupsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listModelPackageGroups(input, ...args); +}; +export async function* paginateListModelPackageGroups( + config: SageMakerPaginationConfiguration, + input: ListModelPackageGroupsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListModelPackageGroupsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListPipelineExecutionStepsPaginator.ts b/clients/client-sagemaker/pagination/ListPipelineExecutionStepsPaginator.ts new file mode 100644 index 000000000000..b77f1cbd26ec --- /dev/null +++ b/clients/client-sagemaker/pagination/ListPipelineExecutionStepsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListPipelineExecutionStepsCommand, + ListPipelineExecutionStepsCommandInput, + ListPipelineExecutionStepsCommandOutput, +} from "../commands/ListPipelineExecutionStepsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListPipelineExecutionStepsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListPipelineExecutionStepsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListPipelineExecutionStepsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listPipelineExecutionSteps(input, ...args); +}; +export async function* paginateListPipelineExecutionSteps( + config: SageMakerPaginationConfiguration, + input: ListPipelineExecutionStepsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListPipelineExecutionStepsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListPipelineExecutionsPaginator.ts b/clients/client-sagemaker/pagination/ListPipelineExecutionsPaginator.ts new file mode 100644 index 000000000000..c0555ee31a6b --- /dev/null +++ b/clients/client-sagemaker/pagination/ListPipelineExecutionsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListPipelineExecutionsCommand, + ListPipelineExecutionsCommandInput, + ListPipelineExecutionsCommandOutput, +} from "../commands/ListPipelineExecutionsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListPipelineExecutionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListPipelineExecutionsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListPipelineExecutionsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listPipelineExecutions(input, ...args); +}; +export async function* paginateListPipelineExecutions( + config: SageMakerPaginationConfiguration, + input: ListPipelineExecutionsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListPipelineExecutionsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListPipelineParametersForExecutionPaginator.ts b/clients/client-sagemaker/pagination/ListPipelineParametersForExecutionPaginator.ts new file mode 100644 index 000000000000..b6c9ece1bb19 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListPipelineParametersForExecutionPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListPipelineParametersForExecutionCommand, + ListPipelineParametersForExecutionCommandInput, + ListPipelineParametersForExecutionCommandOutput, +} from "../commands/ListPipelineParametersForExecutionCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListPipelineParametersForExecutionCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListPipelineParametersForExecutionCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListPipelineParametersForExecutionCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listPipelineParametersForExecution(input, ...args); +}; +export async function* paginateListPipelineParametersForExecution( + config: SageMakerPaginationConfiguration, + input: ListPipelineParametersForExecutionCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListPipelineParametersForExecutionCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListPipelinesPaginator.ts b/clients/client-sagemaker/pagination/ListPipelinesPaginator.ts new file mode 100644 index 000000000000..5ab7025e6bf5 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListPipelinesPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListPipelinesCommand, + ListPipelinesCommandInput, + ListPipelinesCommandOutput, +} from "../commands/ListPipelinesCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListPipelinesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListPipelinesCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListPipelinesCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listPipelines(input, ...args); +}; +export async function* paginateListPipelines( + config: SageMakerPaginationConfiguration, + input: ListPipelinesCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListPipelinesCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/pagination/ListProjectsPaginator.ts b/clients/client-sagemaker/pagination/ListProjectsPaginator.ts new file mode 100644 index 000000000000..603870f3ce14 --- /dev/null +++ b/clients/client-sagemaker/pagination/ListProjectsPaginator.ts @@ -0,0 +1,57 @@ +import { SageMaker } from "../SageMaker"; +import { SageMakerClient } from "../SageMakerClient"; +import { + ListProjectsCommand, + ListProjectsCommandInput, + ListProjectsCommandOutput, +} from "../commands/ListProjectsCommand"; +import { SageMakerPaginationConfiguration } from "./Interfaces"; +import { Paginator } from "@aws-sdk/types"; + +/** + * @private + */ +const makePagedClientRequest = async ( + client: SageMakerClient, + input: ListProjectsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.send(new ListProjectsCommand(input), ...args); +}; +/** + * @private + */ +const makePagedRequest = async ( + client: SageMaker, + input: ListProjectsCommandInput, + ...args: any +): Promise => { + // @ts-ignore + return await client.listProjects(input, ...args); +}; +export async function* paginateListProjects( + config: SageMakerPaginationConfiguration, + input: ListProjectsCommandInput, + ...additionalArguments: any +): Paginator { + let token: string | undefined = config.startingToken || undefined; + let hasNext = true; + let page: ListProjectsCommandOutput; + while (hasNext) { + input.NextToken = token; + input["MaxResults"] = config.pageSize; + if (config.client instanceof SageMaker) { + page = await makePagedRequest(config.client, input, ...additionalArguments); + } else if (config.client instanceof SageMakerClient) { + page = await makePagedClientRequest(config.client, input, ...additionalArguments); + } else { + throw new Error("Invalid client, expected SageMaker | SageMakerClient"); + } + yield page; + token = page.NextToken; + hasNext = !!token; + } + // @ts-ignore + return undefined; +} diff --git a/clients/client-sagemaker/protocols/Aws_json1_1.ts b/clients/client-sagemaker/protocols/Aws_json1_1.ts index 244bb855e737..db15b98cc08d 100644 --- a/clients/client-sagemaker/protocols/Aws_json1_1.ts +++ b/clients/client-sagemaker/protocols/Aws_json1_1.ts @@ -1,14 +1,17 @@ +import { AddAssociationCommandInput, AddAssociationCommandOutput } from "../commands/AddAssociationCommand"; import { AddTagsCommandInput, AddTagsCommandOutput } from "../commands/AddTagsCommand"; import { AssociateTrialComponentCommandInput, AssociateTrialComponentCommandOutput, } from "../commands/AssociateTrialComponentCommand"; +import { CreateActionCommandInput, CreateActionCommandOutput } from "../commands/CreateActionCommand"; import { CreateAlgorithmCommandInput, CreateAlgorithmCommandOutput } from "../commands/CreateAlgorithmCommand"; import { CreateAppCommandInput, CreateAppCommandOutput } from "../commands/CreateAppCommand"; import { CreateAppImageConfigCommandInput, CreateAppImageConfigCommandOutput, } from "../commands/CreateAppImageConfigCommand"; +import { CreateArtifactCommandInput, CreateArtifactCommandOutput } from "../commands/CreateArtifactCommand"; import { CreateAutoMLJobCommandInput, CreateAutoMLJobCommandOutput } from "../commands/CreateAutoMLJobCommand"; import { CreateCodeRepositoryCommandInput, @@ -18,6 +21,7 @@ import { CreateCompilationJobCommandInput, CreateCompilationJobCommandOutput, } from "../commands/CreateCompilationJobCommand"; +import { CreateContextCommandInput, CreateContextCommandOutput } from "../commands/CreateContextCommand"; import { CreateDomainCommandInput, CreateDomainCommandOutput } from "../commands/CreateDomainCommand"; import { CreateEndpointCommandInput, CreateEndpointCommandOutput } from "../commands/CreateEndpointCommand"; import { @@ -25,6 +29,7 @@ import { CreateEndpointConfigCommandOutput, } from "../commands/CreateEndpointConfigCommand"; import { CreateExperimentCommandInput, CreateExperimentCommandOutput } from "../commands/CreateExperimentCommand"; +import { CreateFeatureGroupCommandInput, CreateFeatureGroupCommandOutput } from "../commands/CreateFeatureGroupCommand"; import { CreateFlowDefinitionCommandInput, CreateFlowDefinitionCommandOutput, @@ -39,6 +44,10 @@ import { CreateImageVersionCommandInput, CreateImageVersionCommandOutput } from import { CreateLabelingJobCommandInput, CreateLabelingJobCommandOutput } from "../commands/CreateLabelingJobCommand"; import { CreateModelCommandInput, CreateModelCommandOutput } from "../commands/CreateModelCommand"; import { CreateModelPackageCommandInput, CreateModelPackageCommandOutput } from "../commands/CreateModelPackageCommand"; +import { + CreateModelPackageGroupCommandInput, + CreateModelPackageGroupCommandOutput, +} from "../commands/CreateModelPackageGroupCommand"; import { CreateMonitoringScheduleCommandInput, CreateMonitoringScheduleCommandOutput, @@ -51,6 +60,7 @@ import { CreateNotebookInstanceLifecycleConfigCommandInput, CreateNotebookInstanceLifecycleConfigCommandOutput, } from "../commands/CreateNotebookInstanceLifecycleConfigCommand"; +import { CreatePipelineCommandInput, CreatePipelineCommandOutput } from "../commands/CreatePipelineCommand"; import { CreatePresignedDomainUrlCommandInput, CreatePresignedDomainUrlCommandOutput, @@ -63,6 +73,7 @@ import { CreateProcessingJobCommandInput, CreateProcessingJobCommandOutput, } from "../commands/CreateProcessingJobCommand"; +import { CreateProjectCommandInput, CreateProjectCommandOutput } from "../commands/CreateProjectCommand"; import { CreateTrainingJobCommandInput, CreateTrainingJobCommandOutput } from "../commands/CreateTrainingJobCommand"; import { CreateTransformJobCommandInput, CreateTransformJobCommandOutput } from "../commands/CreateTransformJobCommand"; import { CreateTrialCommandInput, CreateTrialCommandOutput } from "../commands/CreateTrialCommand"; @@ -73,16 +84,20 @@ import { import { CreateUserProfileCommandInput, CreateUserProfileCommandOutput } from "../commands/CreateUserProfileCommand"; import { CreateWorkforceCommandInput, CreateWorkforceCommandOutput } from "../commands/CreateWorkforceCommand"; import { CreateWorkteamCommandInput, CreateWorkteamCommandOutput } from "../commands/CreateWorkteamCommand"; +import { DeleteActionCommandInput, DeleteActionCommandOutput } from "../commands/DeleteActionCommand"; import { DeleteAlgorithmCommandInput, DeleteAlgorithmCommandOutput } from "../commands/DeleteAlgorithmCommand"; import { DeleteAppCommandInput, DeleteAppCommandOutput } from "../commands/DeleteAppCommand"; import { DeleteAppImageConfigCommandInput, DeleteAppImageConfigCommandOutput, } from "../commands/DeleteAppImageConfigCommand"; +import { DeleteArtifactCommandInput, DeleteArtifactCommandOutput } from "../commands/DeleteArtifactCommand"; +import { DeleteAssociationCommandInput, DeleteAssociationCommandOutput } from "../commands/DeleteAssociationCommand"; import { DeleteCodeRepositoryCommandInput, DeleteCodeRepositoryCommandOutput, } from "../commands/DeleteCodeRepositoryCommand"; +import { DeleteContextCommandInput, DeleteContextCommandOutput } from "../commands/DeleteContextCommand"; import { DeleteDomainCommandInput, DeleteDomainCommandOutput } from "../commands/DeleteDomainCommand"; import { DeleteEndpointCommandInput, DeleteEndpointCommandOutput } from "../commands/DeleteEndpointCommand"; import { @@ -90,6 +105,7 @@ import { DeleteEndpointConfigCommandOutput, } from "../commands/DeleteEndpointConfigCommand"; import { DeleteExperimentCommandInput, DeleteExperimentCommandOutput } from "../commands/DeleteExperimentCommand"; +import { DeleteFeatureGroupCommandInput, DeleteFeatureGroupCommandOutput } from "../commands/DeleteFeatureGroupCommand"; import { DeleteFlowDefinitionCommandInput, DeleteFlowDefinitionCommandOutput, @@ -99,6 +115,14 @@ import { DeleteImageCommandInput, DeleteImageCommandOutput } from "../commands/D import { DeleteImageVersionCommandInput, DeleteImageVersionCommandOutput } from "../commands/DeleteImageVersionCommand"; import { DeleteModelCommandInput, DeleteModelCommandOutput } from "../commands/DeleteModelCommand"; import { DeleteModelPackageCommandInput, DeleteModelPackageCommandOutput } from "../commands/DeleteModelPackageCommand"; +import { + DeleteModelPackageGroupCommandInput, + DeleteModelPackageGroupCommandOutput, +} from "../commands/DeleteModelPackageGroupCommand"; +import { + DeleteModelPackageGroupPolicyCommandInput, + DeleteModelPackageGroupPolicyCommandOutput, +} from "../commands/DeleteModelPackageGroupPolicyCommand"; import { DeleteMonitoringScheduleCommandInput, DeleteMonitoringScheduleCommandOutput, @@ -111,6 +135,8 @@ import { DeleteNotebookInstanceLifecycleConfigCommandInput, DeleteNotebookInstanceLifecycleConfigCommandOutput, } from "../commands/DeleteNotebookInstanceLifecycleConfigCommand"; +import { DeletePipelineCommandInput, DeletePipelineCommandOutput } from "../commands/DeletePipelineCommand"; +import { DeleteProjectCommandInput, DeleteProjectCommandOutput } from "../commands/DeleteProjectCommand"; import { DeleteTagsCommandInput, DeleteTagsCommandOutput } from "../commands/DeleteTagsCommand"; import { DeleteTrialCommandInput, DeleteTrialCommandOutput } from "../commands/DeleteTrialCommand"; import { @@ -120,12 +146,14 @@ import { import { DeleteUserProfileCommandInput, DeleteUserProfileCommandOutput } from "../commands/DeleteUserProfileCommand"; import { DeleteWorkforceCommandInput, DeleteWorkforceCommandOutput } from "../commands/DeleteWorkforceCommand"; import { DeleteWorkteamCommandInput, DeleteWorkteamCommandOutput } from "../commands/DeleteWorkteamCommand"; +import { DescribeActionCommandInput, DescribeActionCommandOutput } from "../commands/DescribeActionCommand"; import { DescribeAlgorithmCommandInput, DescribeAlgorithmCommandOutput } from "../commands/DescribeAlgorithmCommand"; import { DescribeAppCommandInput, DescribeAppCommandOutput } from "../commands/DescribeAppCommand"; import { DescribeAppImageConfigCommandInput, DescribeAppImageConfigCommandOutput, } from "../commands/DescribeAppImageConfigCommand"; +import { DescribeArtifactCommandInput, DescribeArtifactCommandOutput } from "../commands/DescribeArtifactCommand"; import { DescribeAutoMLJobCommandInput, DescribeAutoMLJobCommandOutput } from "../commands/DescribeAutoMLJobCommand"; import { DescribeCodeRepositoryCommandInput, @@ -135,6 +163,7 @@ import { DescribeCompilationJobCommandInput, DescribeCompilationJobCommandOutput, } from "../commands/DescribeCompilationJobCommand"; +import { DescribeContextCommandInput, DescribeContextCommandOutput } from "../commands/DescribeContextCommand"; import { DescribeDomainCommandInput, DescribeDomainCommandOutput } from "../commands/DescribeDomainCommand"; import { DescribeEndpointCommandInput, DescribeEndpointCommandOutput } from "../commands/DescribeEndpointCommand"; import { @@ -142,6 +171,10 @@ import { DescribeEndpointConfigCommandOutput, } from "../commands/DescribeEndpointConfigCommand"; import { DescribeExperimentCommandInput, DescribeExperimentCommandOutput } from "../commands/DescribeExperimentCommand"; +import { + DescribeFeatureGroupCommandInput, + DescribeFeatureGroupCommandOutput, +} from "../commands/DescribeFeatureGroupCommand"; import { DescribeFlowDefinitionCommandInput, DescribeFlowDefinitionCommandOutput, @@ -168,6 +201,10 @@ import { DescribeModelPackageCommandInput, DescribeModelPackageCommandOutput, } from "../commands/DescribeModelPackageCommand"; +import { + DescribeModelPackageGroupCommandInput, + DescribeModelPackageGroupCommandOutput, +} from "../commands/DescribeModelPackageGroupCommand"; import { DescribeMonitoringScheduleCommandInput, DescribeMonitoringScheduleCommandOutput, @@ -180,10 +217,20 @@ import { DescribeNotebookInstanceLifecycleConfigCommandInput, DescribeNotebookInstanceLifecycleConfigCommandOutput, } from "../commands/DescribeNotebookInstanceLifecycleConfigCommand"; +import { DescribePipelineCommandInput, DescribePipelineCommandOutput } from "../commands/DescribePipelineCommand"; +import { + DescribePipelineDefinitionForExecutionCommandInput, + DescribePipelineDefinitionForExecutionCommandOutput, +} from "../commands/DescribePipelineDefinitionForExecutionCommand"; +import { + DescribePipelineExecutionCommandInput, + DescribePipelineExecutionCommandOutput, +} from "../commands/DescribePipelineExecutionCommand"; import { DescribeProcessingJobCommandInput, DescribeProcessingJobCommandOutput, } from "../commands/DescribeProcessingJobCommand"; +import { DescribeProjectCommandInput, DescribeProjectCommandOutput } from "../commands/DescribeProjectCommand"; import { DescribeSubscribedWorkteamCommandInput, DescribeSubscribedWorkteamCommandOutput, @@ -207,20 +254,39 @@ import { } from "../commands/DescribeUserProfileCommand"; import { DescribeWorkforceCommandInput, DescribeWorkforceCommandOutput } from "../commands/DescribeWorkforceCommand"; import { DescribeWorkteamCommandInput, DescribeWorkteamCommandOutput } from "../commands/DescribeWorkteamCommand"; +import { + DisableSagemakerServicecatalogPortfolioCommandInput, + DisableSagemakerServicecatalogPortfolioCommandOutput, +} from "../commands/DisableSagemakerServicecatalogPortfolioCommand"; import { DisassociateTrialComponentCommandInput, DisassociateTrialComponentCommandOutput, } from "../commands/DisassociateTrialComponentCommand"; +import { + EnableSagemakerServicecatalogPortfolioCommandInput, + EnableSagemakerServicecatalogPortfolioCommandOutput, +} from "../commands/EnableSagemakerServicecatalogPortfolioCommand"; +import { + GetModelPackageGroupPolicyCommandInput, + GetModelPackageGroupPolicyCommandOutput, +} from "../commands/GetModelPackageGroupPolicyCommand"; +import { + GetSagemakerServicecatalogPortfolioStatusCommandInput, + GetSagemakerServicecatalogPortfolioStatusCommandOutput, +} from "../commands/GetSagemakerServicecatalogPortfolioStatusCommand"; import { GetSearchSuggestionsCommandInput, GetSearchSuggestionsCommandOutput, } from "../commands/GetSearchSuggestionsCommand"; +import { ListActionsCommandInput, ListActionsCommandOutput } from "../commands/ListActionsCommand"; import { ListAlgorithmsCommandInput, ListAlgorithmsCommandOutput } from "../commands/ListAlgorithmsCommand"; import { ListAppImageConfigsCommandInput, ListAppImageConfigsCommandOutput, } from "../commands/ListAppImageConfigsCommand"; import { ListAppsCommandInput, ListAppsCommandOutput } from "../commands/ListAppsCommand"; +import { ListArtifactsCommandInput, ListArtifactsCommandOutput } from "../commands/ListArtifactsCommand"; +import { ListAssociationsCommandInput, ListAssociationsCommandOutput } from "../commands/ListAssociationsCommand"; import { ListAutoMLJobsCommandInput, ListAutoMLJobsCommandOutput } from "../commands/ListAutoMLJobsCommand"; import { ListCandidatesForAutoMLJobCommandInput, @@ -234,6 +300,7 @@ import { ListCompilationJobsCommandInput, ListCompilationJobsCommandOutput, } from "../commands/ListCompilationJobsCommand"; +import { ListContextsCommandInput, ListContextsCommandOutput } from "../commands/ListContextsCommand"; import { ListDomainsCommandInput, ListDomainsCommandOutput } from "../commands/ListDomainsCommand"; import { ListEndpointConfigsCommandInput, @@ -241,6 +308,7 @@ import { } from "../commands/ListEndpointConfigsCommand"; import { ListEndpointsCommandInput, ListEndpointsCommandOutput } from "../commands/ListEndpointsCommand"; import { ListExperimentsCommandInput, ListExperimentsCommandOutput } from "../commands/ListExperimentsCommand"; +import { ListFeatureGroupsCommandInput, ListFeatureGroupsCommandOutput } from "../commands/ListFeatureGroupsCommand"; import { ListFlowDefinitionsCommandInput, ListFlowDefinitionsCommandOutput, @@ -257,6 +325,10 @@ import { ListLabelingJobsForWorkteamCommandInput, ListLabelingJobsForWorkteamCommandOutput, } from "../commands/ListLabelingJobsForWorkteamCommand"; +import { + ListModelPackageGroupsCommandInput, + ListModelPackageGroupsCommandOutput, +} from "../commands/ListModelPackageGroupsCommand"; import { ListModelPackagesCommandInput, ListModelPackagesCommandOutput } from "../commands/ListModelPackagesCommand"; import { ListModelsCommandInput, ListModelsCommandOutput } from "../commands/ListModelsCommand"; import { @@ -275,7 +347,21 @@ import { ListNotebookInstancesCommandInput, ListNotebookInstancesCommandOutput, } from "../commands/ListNotebookInstancesCommand"; +import { + ListPipelineExecutionStepsCommandInput, + ListPipelineExecutionStepsCommandOutput, +} from "../commands/ListPipelineExecutionStepsCommand"; +import { + ListPipelineExecutionsCommandInput, + ListPipelineExecutionsCommandOutput, +} from "../commands/ListPipelineExecutionsCommand"; +import { + ListPipelineParametersForExecutionCommandInput, + ListPipelineParametersForExecutionCommandOutput, +} from "../commands/ListPipelineParametersForExecutionCommand"; +import { ListPipelinesCommandInput, ListPipelinesCommandOutput } from "../commands/ListPipelinesCommand"; import { ListProcessingJobsCommandInput, ListProcessingJobsCommandOutput } from "../commands/ListProcessingJobsCommand"; +import { ListProjectsCommandInput, ListProjectsCommandOutput } from "../commands/ListProjectsCommand"; import { ListSubscribedWorkteamsCommandInput, ListSubscribedWorkteamsCommandOutput, @@ -295,6 +381,10 @@ import { ListTrialsCommandInput, ListTrialsCommandOutput } from "../commands/Lis import { ListUserProfilesCommandInput, ListUserProfilesCommandOutput } from "../commands/ListUserProfilesCommand"; import { ListWorkforcesCommandInput, ListWorkforcesCommandOutput } from "../commands/ListWorkforcesCommand"; import { ListWorkteamsCommandInput, ListWorkteamsCommandOutput } from "../commands/ListWorkteamsCommand"; +import { + PutModelPackageGroupPolicyCommandInput, + PutModelPackageGroupPolicyCommandOutput, +} from "../commands/PutModelPackageGroupPolicyCommand"; import { RenderUiTemplateCommandInput, RenderUiTemplateCommandOutput } from "../commands/RenderUiTemplateCommand"; import { SearchCommandInput, SearchCommandOutput } from "../commands/SearchCommand"; import { @@ -305,6 +395,10 @@ import { StartNotebookInstanceCommandInput, StartNotebookInstanceCommandOutput, } from "../commands/StartNotebookInstanceCommand"; +import { + StartPipelineExecutionCommandInput, + StartPipelineExecutionCommandOutput, +} from "../commands/StartPipelineExecutionCommand"; import { StopAutoMLJobCommandInput, StopAutoMLJobCommandOutput } from "../commands/StopAutoMLJobCommand"; import { StopCompilationJobCommandInput, StopCompilationJobCommandOutput } from "../commands/StopCompilationJobCommand"; import { @@ -320,17 +414,24 @@ import { StopNotebookInstanceCommandInput, StopNotebookInstanceCommandOutput, } from "../commands/StopNotebookInstanceCommand"; +import { + StopPipelineExecutionCommandInput, + StopPipelineExecutionCommandOutput, +} from "../commands/StopPipelineExecutionCommand"; import { StopProcessingJobCommandInput, StopProcessingJobCommandOutput } from "../commands/StopProcessingJobCommand"; import { StopTrainingJobCommandInput, StopTrainingJobCommandOutput } from "../commands/StopTrainingJobCommand"; import { StopTransformJobCommandInput, StopTransformJobCommandOutput } from "../commands/StopTransformJobCommand"; +import { UpdateActionCommandInput, UpdateActionCommandOutput } from "../commands/UpdateActionCommand"; import { UpdateAppImageConfigCommandInput, UpdateAppImageConfigCommandOutput, } from "../commands/UpdateAppImageConfigCommand"; +import { UpdateArtifactCommandInput, UpdateArtifactCommandOutput } from "../commands/UpdateArtifactCommand"; import { UpdateCodeRepositoryCommandInput, UpdateCodeRepositoryCommandOutput, } from "../commands/UpdateCodeRepositoryCommand"; +import { UpdateContextCommandInput, UpdateContextCommandOutput } from "../commands/UpdateContextCommand"; import { UpdateDomainCommandInput, UpdateDomainCommandOutput } from "../commands/UpdateDomainCommand"; import { UpdateEndpointCommandInput, UpdateEndpointCommandOutput } from "../commands/UpdateEndpointCommand"; import { @@ -339,6 +440,7 @@ import { } from "../commands/UpdateEndpointWeightsAndCapacitiesCommand"; import { UpdateExperimentCommandInput, UpdateExperimentCommandOutput } from "../commands/UpdateExperimentCommand"; import { UpdateImageCommandInput, UpdateImageCommandOutput } from "../commands/UpdateImageCommand"; +import { UpdateModelPackageCommandInput, UpdateModelPackageCommandOutput } from "../commands/UpdateModelPackageCommand"; import { UpdateMonitoringScheduleCommandInput, UpdateMonitoringScheduleCommandOutput, @@ -351,6 +453,11 @@ import { UpdateNotebookInstanceLifecycleConfigCommandInput, UpdateNotebookInstanceLifecycleConfigCommandOutput, } from "../commands/UpdateNotebookInstanceLifecycleConfigCommand"; +import { UpdatePipelineCommandInput, UpdatePipelineCommandOutput } from "../commands/UpdatePipelineCommand"; +import { + UpdatePipelineExecutionCommandInput, + UpdatePipelineExecutionCommandOutput, +} from "../commands/UpdatePipelineExecutionCommand"; import { UpdateTrialCommandInput, UpdateTrialCommandOutput } from "../commands/UpdateTrialCommand"; import { UpdateTrialComponentCommandInput, @@ -360,8 +467,13 @@ import { UpdateUserProfileCommandInput, UpdateUserProfileCommandOutput } from ". import { UpdateWorkforceCommandInput, UpdateWorkforceCommandOutput } from "../commands/UpdateWorkforceCommand"; import { UpdateWorkteamCommandInput, UpdateWorkteamCommandOutput } from "../commands/UpdateWorkteamCommand"; import { + ActionSource, + ActionSummary, + AddAssociationRequest, + AddAssociationResponse, AddTagsInput, AddTagsOutput, + Alarm, AlgorithmSpecification, AlgorithmStatusDetails, AlgorithmStatusItem, @@ -372,8 +484,13 @@ import { AppDetails, AppImageConfigDetails, AppSpecification, + ArtifactSource, + ArtifactSourceType, + ArtifactSummary, AssociateTrialComponentRequest, AssociateTrialComponentResponse, + AssociationSummary, + AthenaDatasetDefinition, AutoMLCandidate, AutoMLCandidateStep, AutoMLChannel, @@ -387,6 +504,11 @@ import { AutoMLOutputDataConfig, AutoMLS3DataSource, AutoMLSecurityConfig, + AutoRollbackConfig, + Bias, + BlueGreenUpdatePolicy, + CacheHitResult, + CapacitySize, CaptureContentTypeHeader, CaptureOption, CategoricalParameterRange, @@ -400,23 +522,32 @@ import { CollectionConfiguration, CompilationJobSummary, CompressionType, + ConditionStepMetadata, ConflictException, ContainerDefinition, ContentClassifier, + ContextSource, + ContextSummary, ContinuousParameterRange, ContinuousParameterRangeSpecification, + CreateActionRequest, + CreateActionResponse, CreateAlgorithmInput, CreateAlgorithmOutput, CreateAppImageConfigRequest, CreateAppImageConfigResponse, CreateAppRequest, CreateAppResponse, + CreateArtifactRequest, + CreateArtifactResponse, CreateAutoMLJobRequest, CreateAutoMLJobResponse, CreateCodeRepositoryInput, CreateCodeRepositoryOutput, CreateCompilationJobRequest, CreateCompilationJobResponse, + CreateContextRequest, + CreateContextResponse, CreateDomainRequest, CreateDomainResponse, CreateEndpointConfigInput, @@ -425,6 +556,8 @@ import { CreateEndpointOutput, CreateExperimentRequest, CreateExperimentResponse, + CreateFeatureGroupRequest, + CreateFeatureGroupResponse, CreateFlowDefinitionRequest, CreateFlowDefinitionResponse, CreateHumanTaskUiRequest, @@ -439,6 +572,8 @@ import { CreateLabelingJobResponse, CreateModelInput, CreateModelOutput, + CreateModelPackageGroupInput, + CreateModelPackageGroupOutput, CreateModelPackageInput, CreateModelPackageOutput, CreateMonitoringScheduleRequest, @@ -447,40 +582,16 @@ import { CreateNotebookInstanceLifecycleConfigInput, CreateNotebookInstanceLifecycleConfigOutput, CreateNotebookInstanceOutput, + CreatePipelineRequest, + CreatePipelineResponse, CreatePresignedDomainUrlRequest, - CreatePresignedDomainUrlResponse, - CreatePresignedNotebookInstanceUrlInput, - CreatePresignedNotebookInstanceUrlOutput, - CreateProcessingJobRequest, - CreateProcessingJobResponse, - CreateTrainingJobRequest, - CreateTrainingJobResponse, - CreateTransformJobRequest, - CreateTransformJobResponse, - CreateTrialComponentRequest, - CreateTrialComponentResponse, - CreateTrialRequest, - CreateTrialResponse, - CreateUserProfileRequest, - CreateUserProfileResponse, - CreateWorkforceRequest, - CreateWorkforceResponse, - CreateWorkteamRequest, - CreateWorkteamResponse, CustomImage, DataCaptureConfig, - DataCaptureConfigSummary, - DataProcessing, + DataCatalogConfig, DataSource, - DebugHookConfig, - DebugRuleConfiguration, - DebugRuleEvaluationStatus, - DeleteAlgorithmInput, - DeleteAppImageConfigRequest, - DeleteAppRequest, - DeleteCodeRepositoryInput, EndpointInput, - ExperimentConfig, + Explainability, + FeatureDefinition, FileSystemConfig, FileSystemDataSource, FinalAutoMLJobObjectiveMetric, @@ -515,12 +626,15 @@ import { LabelingJobS3DataSource, LabelingJobSnsDataSource, LabelingJobStoppingConditions, - MemberDefinition, + MetadataProperties, MetricDefinition, - ModelClientConfig, + MetricsSource, + ModelDataQuality, + ModelMetrics, ModelPackageContainerDefinition, ModelPackageValidationProfile, ModelPackageValidationSpecification, + ModelQuality, MonitoringAppSpecification, MonitoringBaselineConfig, MonitoringClusterConfig, @@ -537,22 +651,14 @@ import { NetworkConfig, NotebookInstanceAcceleratorType, NotebookInstanceLifecycleHook, - NotificationConfiguration, - OidcConfig, - OidcMemberDefinition, + OfflineStoreConfig, + OnlineStoreConfig, + OnlineStoreSecurityConfig, OutputConfig, OutputDataConfig, ParameterRange, ParameterRanges, ParentHyperParameterTuningJob, - ProcessingClusterConfig, - ProcessingInput, - ProcessingOutput, - ProcessingOutputConfig, - ProcessingResources, - ProcessingS3Input, - ProcessingS3Output, - ProcessingStoppingCondition, ProductionVariant, ProductionVariantInstanceType, PublicWorkforceTaskPrice, @@ -562,19 +668,18 @@ import { ResourceLimits, ResourceNotFound, ResourceSpec, - RetentionPolicy, S3DataSource, + S3StorageConfig, ScheduleConfig, SharingSettings, ShuffleConfig, SourceAlgorithm, SourceAlgorithmSpecification, - SourceIpConfig, StoppingCondition, Tag, TargetPlatform, TensorBoardAppSettings, - TensorBoardOutputConfig, + TrafficRoutingConfig, TrainingInputMode, TrainingInstanceType, TrainingJobDefinition, @@ -586,22 +691,60 @@ import { TransformOutput, TransformResources, TransformS3DataSource, - TrialComponentArtifact, - TrialComponentParameterValue, - TrialComponentStatus, TuningJobCompletionCriteria, USD, UiConfig, UiTemplate, + UserContext, UserSettings, VpcConfig, } from "../models/models_0"; import { + CreatePresignedDomainUrlResponse, + CreatePresignedNotebookInstanceUrlInput, + CreatePresignedNotebookInstanceUrlOutput, + CreateProcessingJobRequest, + CreateProcessingJobResponse, + CreateProjectInput, + CreateProjectOutput, + CreateTrainingJobRequest, + CreateTrainingJobResponse, + CreateTransformJobRequest, + CreateTransformJobResponse, + CreateTrialComponentRequest, + CreateTrialComponentResponse, + CreateTrialRequest, + CreateTrialResponse, + CreateUserProfileRequest, + CreateUserProfileResponse, + CreateWorkforceRequest, + CreateWorkforceResponse, + CreateWorkteamRequest, + CreateWorkteamResponse, + DataCaptureConfigSummary, + DataProcessing, + DatasetDefinition, + DebugHookConfig, + DebugRuleConfiguration, + DebugRuleEvaluationStatus, + DeleteActionRequest, + DeleteActionResponse, + DeleteAlgorithmInput, + DeleteAppImageConfigRequest, + DeleteAppRequest, + DeleteArtifactRequest, + DeleteArtifactResponse, + DeleteAssociationRequest, + DeleteAssociationResponse, + DeleteCodeRepositoryInput, + DeleteContextRequest, + DeleteContextResponse, DeleteDomainRequest, DeleteEndpointConfigInput, DeleteEndpointInput, DeleteExperimentRequest, DeleteExperimentResponse, + DeleteFeatureGroupRequest, DeleteFlowDefinitionRequest, DeleteFlowDefinitionResponse, DeleteHumanTaskUiRequest, @@ -611,10 +754,15 @@ import { DeleteImageVersionRequest, DeleteImageVersionResponse, DeleteModelInput, + DeleteModelPackageGroupInput, + DeleteModelPackageGroupPolicyInput, DeleteModelPackageInput, DeleteMonitoringScheduleRequest, DeleteNotebookInstanceInput, DeleteNotebookInstanceLifecycleConfigInput, + DeletePipelineRequest, + DeletePipelineResponse, + DeleteProjectInput, DeleteTagsInput, DeleteTagsOutput, DeleteTrialComponentRequest, @@ -627,18 +775,25 @@ import { DeleteWorkteamRequest, DeleteWorkteamResponse, DeployedImage, + DeploymentConfig, + DescribeActionRequest, + DescribeActionResponse, DescribeAlgorithmInput, DescribeAlgorithmOutput, DescribeAppImageConfigRequest, DescribeAppImageConfigResponse, DescribeAppRequest, DescribeAppResponse, + DescribeArtifactRequest, + DescribeArtifactResponse, DescribeAutoMLJobRequest, DescribeAutoMLJobResponse, DescribeCodeRepositoryInput, DescribeCodeRepositoryOutput, DescribeCompilationJobRequest, DescribeCompilationJobResponse, + DescribeContextRequest, + DescribeContextResponse, DescribeDomainRequest, DescribeDomainResponse, DescribeEndpointConfigInput, @@ -647,6 +802,8 @@ import { DescribeEndpointOutput, DescribeExperimentRequest, DescribeExperimentResponse, + DescribeFeatureGroupRequest, + DescribeFeatureGroupResponse, DescribeFlowDefinitionRequest, DescribeFlowDefinitionResponse, DescribeHumanTaskUiRequest, @@ -661,6 +818,8 @@ import { DescribeLabelingJobResponse, DescribeModelInput, DescribeModelOutput, + DescribeModelPackageGroupInput, + DescribeModelPackageGroupOutput, DescribeModelPackageInput, DescribeModelPackageOutput, DescribeMonitoringScheduleRequest, @@ -669,8 +828,16 @@ import { DescribeNotebookInstanceLifecycleConfigInput, DescribeNotebookInstanceLifecycleConfigOutput, DescribeNotebookInstanceOutput, + DescribePipelineDefinitionForExecutionRequest, + DescribePipelineDefinitionForExecutionResponse, + DescribePipelineExecutionRequest, + DescribePipelineExecutionResponse, + DescribePipelineRequest, + DescribePipelineResponse, DescribeProcessingJobRequest, DescribeProcessingJobResponse, + DescribeProjectInput, + DescribeProjectOutput, DescribeSubscribedWorkteamRequest, DescribeSubscribedWorkteamResponse, DescribeTrainingJobRequest, @@ -688,17 +855,29 @@ import { DescribeWorkteamRequest, DescribeWorkteamResponse, DesiredWeightAndCapacity, + DisableSagemakerServicecatalogPortfolioInput, + DisableSagemakerServicecatalogPortfolioOutput, DisassociateTrialComponentRequest, DisassociateTrialComponentResponse, DomainDetails, + EnableSagemakerServicecatalogPortfolioInput, + EnableSagemakerServicecatalogPortfolioOutput, + Endpoint, EndpointConfigSummary, EndpointSummary, Experiment, + ExperimentConfig, ExperimentSource, ExperimentSummary, + FeatureGroup, + FeatureGroupSummary, Filter, FinalHyperParameterTuningJobObjectiveMetric, FlowDefinitionSummary, + GetModelPackageGroupPolicyInput, + GetModelPackageGroupPolicyOutput, + GetSagemakerServicecatalogPortfolioStatusInput, + GetSagemakerServicecatalogPortfolioStatusOutput, GetSearchSuggestionsRequest, GetSearchSuggestionsResponse, GitConfigForUpdate, @@ -712,12 +891,68 @@ import { LabelingJobForWorkteamSummary, LabelingJobOutput, LabelingJobSummary, + ListActionsRequest, + ListActionsResponse, ListAlgorithmsInput, ListAlgorithmsOutput, ListAppImageConfigsRequest, ListAppImageConfigsResponse, ListAppsRequest, ListAppsResponse, + ListArtifactsRequest, + ListArtifactsResponse, + ListAssociationsRequest, + MemberDefinition, + MetricData, + ModelArtifacts, + ModelClientConfig, + ModelDigests, + ModelPackageStatusDetails, + ModelPackageStatusItem, + MonitoringExecutionSummary, + MonitoringSchedule, + NotificationConfiguration, + ObjectiveStatusCounters, + OfflineStoreStatus, + OidcConfig, + OidcConfigForResponse, + OidcMemberDefinition, + ProcessingClusterConfig, + ProcessingFeatureStoreOutput, + ProcessingInput, + ProcessingOutput, + ProcessingOutputConfig, + ProcessingResources, + ProcessingS3Input, + ProcessingS3Output, + ProcessingStoppingCondition, + ProductionVariantSummary, + PropertyNameQuery, + PropertyNameSuggestion, + ProvisioningParameter, + RedshiftDatasetDefinition, + ResolvedAttributes, + RetentionPolicy, + SecondaryStatusTransition, + ServiceCatalogProvisionedProductDetails, + ServiceCatalogProvisioningDetails, + SourceIpConfig, + SubscribedWorkteam, + SuggestionQuery, + TensorBoardOutputConfig, + TrainingJobStatusCounters, + TrialComponentArtifact, + TrialComponentMetricSummary, + TrialComponentParameterValue, + TrialComponentSource, + TrialComponentStatus, + TrialSource, + UiTemplateInfo, + Workforce, + Workteam, +} from "../models/models_1"; +import { + ListAssociationsResponse, ListAutoMLJobsRequest, ListAutoMLJobsResponse, ListCandidatesForAutoMLJobRequest, @@ -726,6 +961,8 @@ import { ListCodeRepositoriesOutput, ListCompilationJobsRequest, ListCompilationJobsResponse, + ListContextsRequest, + ListContextsResponse, ListDomainsRequest, ListDomainsResponse, ListEndpointConfigsInput, @@ -734,6 +971,8 @@ import { ListEndpointsOutput, ListExperimentsRequest, ListExperimentsResponse, + ListFeatureGroupsRequest, + ListFeatureGroupsResponse, ListFlowDefinitionsRequest, ListFlowDefinitionsResponse, ListHumanTaskUisRequest, @@ -748,6 +987,8 @@ import { ListLabelingJobsForWorkteamResponse, ListLabelingJobsRequest, ListLabelingJobsResponse, + ListModelPackageGroupsInput, + ListModelPackageGroupsOutput, ListModelPackagesInput, ListModelPackagesOutput, ListModelsInput, @@ -760,8 +1001,18 @@ import { ListNotebookInstanceLifecycleConfigsOutput, ListNotebookInstancesInput, ListNotebookInstancesOutput, + ListPipelineExecutionStepsRequest, + ListPipelineExecutionStepsResponse, + ListPipelineExecutionsRequest, + ListPipelineExecutionsResponse, + ListPipelineParametersForExecutionRequest, + ListPipelineParametersForExecutionResponse, + ListPipelinesRequest, + ListPipelinesResponse, ListProcessingJobsRequest, ListProcessingJobsResponse, + ListProjectsInput, + ListProjectsOutput, ListSubscribedWorkteamsRequest, ListSubscribedWorkteamsResponse, ListTagsInput, @@ -782,76 +1033,78 @@ import { ListWorkforcesResponse, ListWorkteamsRequest, ListWorkteamsResponse, - MetricData, - ModelArtifacts, - ModelPackageStatusDetails, - ModelPackageStatusItem, + ModelPackage, + ModelPackageGroup, + ModelPackageGroupSummary, ModelPackageSummary, + ModelStepMetadata, ModelSummary, - MonitoringExecutionSummary, MonitoringScheduleSummary, NestedFilters, NotebookInstanceLifecycleConfigSummary, NotebookInstanceSummary, - ObjectiveStatusCounters, - OidcConfigForResponse, + Parameter, Parent, + Pipeline, + PipelineExecution, + PipelineExecutionStep, + PipelineExecutionStepMetadata, + PipelineExecutionSummary, + PipelineSummary, ProcessingJob, + ProcessingJobStepMetadata, ProcessingJobSummary, - ProductionVariantSummary, - PropertyNameQuery, - PropertyNameSuggestion, + ProjectSummary, + PutModelPackageGroupPolicyInput, + PutModelPackageGroupPolicyOutput, + RegisterModelStepMetadata, RenderUiTemplateRequest, RenderUiTemplateResponse, RenderableTask, RenderingError, - ResolvedAttributes, + SearchExpression, SearchRecord, + SearchRequest, SearchResponse, - SecondaryStatusTransition, StartMonitoringScheduleRequest, StartNotebookInstanceInput, + StartPipelineExecutionRequest, + StartPipelineExecutionResponse, StopAutoMLJobRequest, StopCompilationJobRequest, StopHyperParameterTuningJobRequest, StopLabelingJobRequest, StopMonitoringScheduleRequest, StopNotebookInstanceInput, + StopPipelineExecutionRequest, + StopPipelineExecutionResponse, StopProcessingJobRequest, StopTrainingJobRequest, StopTransformJobRequest, - SubscribedWorkteam, - SuggestionQuery, TrainingJob, - TrainingJobStatusCounters, + TrainingJobStepMetadata, TrainingJobSummary, TransformJob, + TransformJobStepMetadata, TransformJobSummary, Trial, TrialComponent, - TrialComponentMetricSummary, TrialComponentSimpleSummary, - TrialComponentSource, TrialComponentSourceDetail, TrialComponentSummary, - TrialSource, TrialSummary, - UiTemplateInfo, + UpdateActionRequest, + UpdateActionResponse, UpdateAppImageConfigRequest, UpdateAppImageConfigResponse, + UpdateArtifactRequest, + UpdateArtifactResponse, UpdateCodeRepositoryInput, UpdateCodeRepositoryOutput, + UpdateContextRequest, + UpdateContextResponse, UpdateDomainRequest, UpdateDomainResponse, - UserContext, - UserProfileDetails, - VariantProperty, - Workforce, - Workteam, -} from "../models/models_1"; -import { - SearchExpression, - SearchRequest, UpdateEndpointInput, UpdateEndpointOutput, UpdateEndpointWeightsAndCapacitiesInput, @@ -860,12 +1113,18 @@ import { UpdateExperimentResponse, UpdateImageRequest, UpdateImageResponse, + UpdateModelPackageInput, + UpdateModelPackageOutput, UpdateMonitoringScheduleRequest, UpdateMonitoringScheduleResponse, UpdateNotebookInstanceInput, UpdateNotebookInstanceLifecycleConfigInput, UpdateNotebookInstanceLifecycleConfigOutput, UpdateNotebookInstanceOutput, + UpdatePipelineExecutionRequest, + UpdatePipelineExecutionResponse, + UpdatePipelineRequest, + UpdatePipelineResponse, UpdateTrialComponentRequest, UpdateTrialComponentResponse, UpdateTrialRequest, @@ -876,6 +1135,8 @@ import { UpdateWorkforceResponse, UpdateWorkteamRequest, UpdateWorkteamResponse, + UserProfileDetails, + VariantProperty, } from "../models/models_2"; import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http"; import { LazyJsonString as __LazyJsonString, SmithyException as __SmithyException } from "@aws-sdk/smithy-client"; @@ -888,6 +1149,19 @@ import { } from "@aws-sdk/types"; import { v4 as generateIdempotencyToken } from "uuid"; +export const serializeAws_json1_1AddAssociationCommand = async ( + input: AddAssociationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.AddAssociation", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1AddAssociationRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1AddTagsCommand = async ( input: AddTagsCommandInput, context: __SerdeContext @@ -914,6 +1188,19 @@ export const serializeAws_json1_1AssociateTrialComponentCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateActionCommand = async ( + input: CreateActionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateAction", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateActionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateAlgorithmCommand = async ( input: CreateAlgorithmCommandInput, context: __SerdeContext @@ -953,6 +1240,19 @@ export const serializeAws_json1_1CreateAppImageConfigCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateArtifactCommand = async ( + input: CreateArtifactCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateArtifact", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateArtifactRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateAutoMLJobCommand = async ( input: CreateAutoMLJobCommandInput, context: __SerdeContext @@ -992,6 +1292,19 @@ export const serializeAws_json1_1CreateCompilationJobCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateContextCommand = async ( + input: CreateContextCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateContext", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateContextRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateDomainCommand = async ( input: CreateDomainCommandInput, context: __SerdeContext @@ -1044,6 +1357,19 @@ export const serializeAws_json1_1CreateExperimentCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateFeatureGroupCommand = async ( + input: CreateFeatureGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateFeatureGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateFeatureGroupRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateFlowDefinitionCommand = async ( input: CreateFlowDefinitionCommandInput, context: __SerdeContext @@ -1148,6 +1474,19 @@ export const serializeAws_json1_1CreateModelPackageCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateModelPackageGroupCommand = async ( + input: CreateModelPackageGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateModelPackageGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateModelPackageGroupInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateMonitoringScheduleCommand = async ( input: CreateMonitoringScheduleCommandInput, context: __SerdeContext @@ -1187,6 +1526,19 @@ export const serializeAws_json1_1CreateNotebookInstanceLifecycleConfigCommand = return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreatePipelineCommand = async ( + input: CreatePipelineCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreatePipeline", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreatePipelineRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreatePresignedDomainUrlCommand = async ( input: CreatePresignedDomainUrlCommandInput, context: __SerdeContext @@ -1226,6 +1578,19 @@ export const serializeAws_json1_1CreateProcessingJobCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1CreateProjectCommand = async ( + input: CreateProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.CreateProject", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1CreateProjectInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1CreateTrainingJobCommand = async ( input: CreateTrainingJobCommandInput, context: __SerdeContext @@ -1317,6 +1682,19 @@ export const serializeAws_json1_1CreateWorkteamCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DeleteActionCommand = async ( + input: DeleteActionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteAction", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteActionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DeleteAlgorithmCommand = async ( input: DeleteAlgorithmCommandInput, context: __SerdeContext @@ -1356,16 +1734,55 @@ export const serializeAws_json1_1DeleteAppImageConfigCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; -export const serializeAws_json1_1DeleteCodeRepositoryCommand = async ( - input: DeleteCodeRepositoryCommandInput, +export const serializeAws_json1_1DeleteArtifactCommand = async ( + input: DeleteArtifactCommandInput, context: __SerdeContext ): Promise<__HttpRequest> => { const headers: __HeaderBag = { "Content-Type": "application/x-amz-json-1.1", - "X-Amz-Target": "SageMaker.DeleteCodeRepository", + "X-Amz-Target": "SageMaker.DeleteArtifact", }; let body: any; - body = JSON.stringify(serializeAws_json1_1DeleteCodeRepositoryInput(input, context)); + body = JSON.stringify(serializeAws_json1_1DeleteArtifactRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteAssociationCommand = async ( + input: DeleteAssociationCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteAssociation", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteAssociationRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteCodeRepositoryCommand = async ( + input: DeleteCodeRepositoryCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteCodeRepository", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteCodeRepositoryInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteContextCommand = async ( + input: DeleteContextCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteContext", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteContextRequest(input, context)); return buildHttpRpcRequest(context, headers, "/", undefined, body); }; @@ -1421,6 +1838,19 @@ export const serializeAws_json1_1DeleteExperimentCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DeleteFeatureGroupCommand = async ( + input: DeleteFeatureGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteFeatureGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteFeatureGroupRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DeleteFlowDefinitionCommand = async ( input: DeleteFlowDefinitionCommandInput, context: __SerdeContext @@ -1499,6 +1929,32 @@ export const serializeAws_json1_1DeleteModelPackageCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DeleteModelPackageGroupCommand = async ( + input: DeleteModelPackageGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteModelPackageGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteModelPackageGroupInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteModelPackageGroupPolicyCommand = async ( + input: DeleteModelPackageGroupPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteModelPackageGroupPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteModelPackageGroupPolicyInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DeleteMonitoringScheduleCommand = async ( input: DeleteMonitoringScheduleCommandInput, context: __SerdeContext @@ -1538,6 +1994,32 @@ export const serializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommand = return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DeletePipelineCommand = async ( + input: DeletePipelineCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeletePipeline", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeletePipelineRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DeleteProjectCommand = async ( + input: DeleteProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DeleteProject", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DeleteProjectInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DeleteTagsCommand = async ( input: DeleteTagsCommandInput, context: __SerdeContext @@ -1616,6 +2098,19 @@ export const serializeAws_json1_1DeleteWorkteamCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeActionCommand = async ( + input: DescribeActionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeAction", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeActionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeAlgorithmCommand = async ( input: DescribeAlgorithmCommandInput, context: __SerdeContext @@ -1655,6 +2150,19 @@ export const serializeAws_json1_1DescribeAppImageConfigCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeArtifactCommand = async ( + input: DescribeArtifactCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeArtifact", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeArtifactRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeAutoMLJobCommand = async ( input: DescribeAutoMLJobCommandInput, context: __SerdeContext @@ -1694,6 +2202,19 @@ export const serializeAws_json1_1DescribeCompilationJobCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeContextCommand = async ( + input: DescribeContextCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeContext", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeContextRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeDomainCommand = async ( input: DescribeDomainCommandInput, context: __SerdeContext @@ -1746,6 +2267,19 @@ export const serializeAws_json1_1DescribeExperimentCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeFeatureGroupCommand = async ( + input: DescribeFeatureGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeFeatureGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeFeatureGroupRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeFlowDefinitionCommand = async ( input: DescribeFlowDefinitionCommandInput, context: __SerdeContext @@ -1850,6 +2384,19 @@ export const serializeAws_json1_1DescribeModelPackageCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeModelPackageGroupCommand = async ( + input: DescribeModelPackageGroupCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeModelPackageGroup", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeModelPackageGroupInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeMonitoringScheduleCommand = async ( input: DescribeMonitoringScheduleCommandInput, context: __SerdeContext @@ -1889,6 +2436,45 @@ export const serializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommand return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribePipelineCommand = async ( + input: DescribePipelineCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribePipeline", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribePipelineRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribePipelineDefinitionForExecutionCommand = async ( + input: DescribePipelineDefinitionForExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribePipelineDefinitionForExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribePipelineDefinitionForExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1DescribePipelineExecutionCommand = async ( + input: DescribePipelineExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribePipelineExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribePipelineExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeProcessingJobCommand = async ( input: DescribeProcessingJobCommandInput, context: __SerdeContext @@ -1902,6 +2488,19 @@ export const serializeAws_json1_1DescribeProcessingJobCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DescribeProjectCommand = async ( + input: DescribeProjectCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DescribeProject", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DescribeProjectInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DescribeSubscribedWorkteamCommand = async ( input: DescribeSubscribedWorkteamCommandInput, context: __SerdeContext @@ -2006,6 +2605,19 @@ export const serializeAws_json1_1DescribeWorkteamCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand = async ( + input: DisableSagemakerServicecatalogPortfolioCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.DisableSagemakerServicecatalogPortfolio", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1DisableSagemakerServicecatalogPortfolioInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1DisassociateTrialComponentCommand = async ( input: DisassociateTrialComponentCommandInput, context: __SerdeContext @@ -2019,6 +2631,45 @@ export const serializeAws_json1_1DisassociateTrialComponentCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand = async ( + input: EnableSagemakerServicecatalogPortfolioCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.EnableSagemakerServicecatalogPortfolio", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1EnableSagemakerServicecatalogPortfolioInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetModelPackageGroupPolicyCommand = async ( + input: GetModelPackageGroupPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.GetModelPackageGroupPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetModelPackageGroupPolicyInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand = async ( + input: GetSagemakerServicecatalogPortfolioStatusCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.GetSagemakerServicecatalogPortfolioStatus", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1GetSearchSuggestionsCommand = async ( input: GetSearchSuggestionsCommandInput, context: __SerdeContext @@ -2032,6 +2683,19 @@ export const serializeAws_json1_1GetSearchSuggestionsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1ListActionsCommand = async ( + input: ListActionsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListActions", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListActionsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1ListAlgorithmsCommand = async ( input: ListAlgorithmsCommandInput, context: __SerdeContext @@ -2071,6 +2735,32 @@ export const serializeAws_json1_1ListAppsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1ListArtifactsCommand = async ( + input: ListArtifactsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListArtifacts", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListArtifactsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListAssociationsCommand = async ( + input: ListAssociationsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListAssociations", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListAssociationsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1ListAutoMLJobsCommand = async ( input: ListAutoMLJobsCommandInput, context: __SerdeContext @@ -2123,6 +2813,19 @@ export const serializeAws_json1_1ListCompilationJobsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1ListContextsCommand = async ( + input: ListContextsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListContexts", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListContextsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1ListDomainsCommand = async ( input: ListDomainsCommandInput, context: __SerdeContext @@ -2175,6 +2878,19 @@ export const serializeAws_json1_1ListExperimentsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1ListFeatureGroupsCommand = async ( + input: ListFeatureGroupsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListFeatureGroups", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListFeatureGroupsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1ListFlowDefinitionsCommand = async ( input: ListFlowDefinitionsCommandInput, context: __SerdeContext @@ -2266,6 +2982,19 @@ export const serializeAws_json1_1ListLabelingJobsForWorkteamCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1ListModelPackageGroupsCommand = async ( + input: ListModelPackageGroupsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListModelPackageGroups", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListModelPackageGroupsInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1ListModelPackagesCommand = async ( input: ListModelPackagesCommandInput, context: __SerdeContext @@ -2344,33 +3073,98 @@ export const serializeAws_json1_1ListNotebookInstancesCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; -export const serializeAws_json1_1ListProcessingJobsCommand = async ( - input: ListProcessingJobsCommandInput, +export const serializeAws_json1_1ListPipelineExecutionsCommand = async ( + input: ListPipelineExecutionsCommandInput, context: __SerdeContext ): Promise<__HttpRequest> => { const headers: __HeaderBag = { "Content-Type": "application/x-amz-json-1.1", - "X-Amz-Target": "SageMaker.ListProcessingJobs", + "X-Amz-Target": "SageMaker.ListPipelineExecutions", }; let body: any; - body = JSON.stringify(serializeAws_json1_1ListProcessingJobsRequest(input, context)); + body = JSON.stringify(serializeAws_json1_1ListPipelineExecutionsRequest(input, context)); return buildHttpRpcRequest(context, headers, "/", undefined, body); }; -export const serializeAws_json1_1ListSubscribedWorkteamsCommand = async ( - input: ListSubscribedWorkteamsCommandInput, +export const serializeAws_json1_1ListPipelineExecutionStepsCommand = async ( + input: ListPipelineExecutionStepsCommandInput, context: __SerdeContext ): Promise<__HttpRequest> => { const headers: __HeaderBag = { "Content-Type": "application/x-amz-json-1.1", - "X-Amz-Target": "SageMaker.ListSubscribedWorkteams", + "X-Amz-Target": "SageMaker.ListPipelineExecutionSteps", }; let body: any; - body = JSON.stringify(serializeAws_json1_1ListSubscribedWorkteamsRequest(input, context)); + body = JSON.stringify(serializeAws_json1_1ListPipelineExecutionStepsRequest(input, context)); return buildHttpRpcRequest(context, headers, "/", undefined, body); }; -export const serializeAws_json1_1ListTagsCommand = async ( +export const serializeAws_json1_1ListPipelineParametersForExecutionCommand = async ( + input: ListPipelineParametersForExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListPipelineParametersForExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListPipelineParametersForExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListPipelinesCommand = async ( + input: ListPipelinesCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListPipelines", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListPipelinesRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListProcessingJobsCommand = async ( + input: ListProcessingJobsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListProcessingJobs", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListProcessingJobsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListProjectsCommand = async ( + input: ListProjectsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListProjects", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListProjectsInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListSubscribedWorkteamsCommand = async ( + input: ListSubscribedWorkteamsCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.ListSubscribedWorkteams", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1ListSubscribedWorkteamsRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1ListTagsCommand = async ( input: ListTagsCommandInput, context: __SerdeContext ): Promise<__HttpRequest> => { @@ -2487,6 +3281,19 @@ export const serializeAws_json1_1ListWorkteamsCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1PutModelPackageGroupPolicyCommand = async ( + input: PutModelPackageGroupPolicyCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.PutModelPackageGroupPolicy", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1PutModelPackageGroupPolicyInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1RenderUiTemplateCommand = async ( input: RenderUiTemplateCommandInput, context: __SerdeContext @@ -2539,6 +3346,19 @@ export const serializeAws_json1_1StartNotebookInstanceCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1StartPipelineExecutionCommand = async ( + input: StartPipelineExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.StartPipelineExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1StartPipelineExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1StopAutoMLJobCommand = async ( input: StopAutoMLJobCommandInput, context: __SerdeContext @@ -2617,6 +3437,19 @@ export const serializeAws_json1_1StopNotebookInstanceCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1StopPipelineExecutionCommand = async ( + input: StopPipelineExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.StopPipelineExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1StopPipelineExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1StopProcessingJobCommand = async ( input: StopProcessingJobCommandInput, context: __SerdeContext @@ -2656,6 +3489,19 @@ export const serializeAws_json1_1StopTransformJobCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1UpdateActionCommand = async ( + input: UpdateActionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdateAction", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdateActionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1UpdateAppImageConfigCommand = async ( input: UpdateAppImageConfigCommandInput, context: __SerdeContext @@ -2669,6 +3515,19 @@ export const serializeAws_json1_1UpdateAppImageConfigCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1UpdateArtifactCommand = async ( + input: UpdateArtifactCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdateArtifact", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdateArtifactRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1UpdateCodeRepositoryCommand = async ( input: UpdateCodeRepositoryCommandInput, context: __SerdeContext @@ -2682,6 +3541,19 @@ export const serializeAws_json1_1UpdateCodeRepositoryCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1UpdateContextCommand = async ( + input: UpdateContextCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdateContext", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdateContextRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1UpdateDomainCommand = async ( input: UpdateDomainCommandInput, context: __SerdeContext @@ -2747,6 +3619,19 @@ export const serializeAws_json1_1UpdateImageCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1UpdateModelPackageCommand = async ( + input: UpdateModelPackageCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdateModelPackage", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdateModelPackageInput(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1UpdateMonitoringScheduleCommand = async ( input: UpdateMonitoringScheduleCommandInput, context: __SerdeContext @@ -2786,6 +3671,32 @@ export const serializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommand = return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const serializeAws_json1_1UpdatePipelineCommand = async ( + input: UpdatePipelineCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdatePipeline", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdatePipelineRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + +export const serializeAws_json1_1UpdatePipelineExecutionCommand = async ( + input: UpdatePipelineExecutionCommandInput, + context: __SerdeContext +): Promise<__HttpRequest> => { + const headers: __HeaderBag = { + "Content-Type": "application/x-amz-json-1.1", + "X-Amz-Target": "SageMaker.UpdatePipelineExecution", + }; + let body: any; + body = JSON.stringify(serializeAws_json1_1UpdatePipelineExecutionRequest(input, context)); + return buildHttpRpcRequest(context, headers, "/", undefined, body); +}; + export const serializeAws_json1_1UpdateTrialCommand = async ( input: UpdateTrialCommandInput, context: __SerdeContext @@ -2851,6 +3762,69 @@ export const serializeAws_json1_1UpdateWorkteamCommand = async ( return buildHttpRpcRequest(context, headers, "/", undefined, body); }; +export const deserializeAws_json1_1AddAssociationCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1AddAssociationCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1AddAssociationResponse(data, context); + const response: AddAssociationCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1AddAssociationCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1AddTagsCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -2961,6 +3935,61 @@ const deserializeAws_json1_1AssociateTrialComponentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1CreateActionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateActionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateActionResponse(data, context); + const response: CreateActionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateActionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1CreateAlgorithmCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -3126,27 +4155,27 @@ const deserializeAws_json1_1CreateAppImageConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1CreateAutoMLJobCommand = async ( +export const deserializeAws_json1_1CreateArtifactCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1CreateAutoMLJobCommandError(output, context); + return deserializeAws_json1_1CreateArtifactCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1CreateAutoMLJobResponse(data, context); - const response: CreateAutoMLJobCommandOutput = { + contents = deserializeAws_json1_1CreateArtifactResponse(data, context); + const response: CreateArtifactCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1CreateAutoMLJobCommandError = async ( +const deserializeAws_json1_1CreateArtifactCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -3156,14 +4185,6 @@ const deserializeAws_json1_1CreateAutoMLJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "ResourceLimitExceeded": case "com.amazonaws.sagemaker#ResourceLimitExceeded": response = { @@ -3189,7 +4210,70 @@ const deserializeAws_json1_1CreateAutoMLJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1CreateCodeRepositoryCommand = async ( +export const deserializeAws_json1_1CreateAutoMLJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateAutoMLJobCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateAutoMLJobResponse(data, context); + const response: CreateAutoMLJobCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateAutoMLJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1CreateCodeRepositoryCommand = async ( output: __HttpResponse, context: __SerdeContext ): Promise => { @@ -3299,6 +4383,61 @@ const deserializeAws_json1_1CreateCompilationJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1CreateContextCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateContextCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateContextResponse(data, context); + const response: CreateContextCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateContextCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1CreateDomainCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -3527,6 +4666,69 @@ const deserializeAws_json1_1CreateExperimentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1CreateFeatureGroupCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateFeatureGroupCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateFeatureGroupResponse(data, context); + const response: CreateFeatureGroupCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateFeatureGroupCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1CreateFlowDefinitionCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -4031,6 +5233,61 @@ const deserializeAws_json1_1CreateModelPackageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1CreateModelPackageGroupCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateModelPackageGroupCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateModelPackageGroupOutput(data, context); + const response: CreateModelPackageGroupCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateModelPackageGroupCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1CreateMonitoringScheduleCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -4204,27 +5461,27 @@ const deserializeAws_json1_1CreateNotebookInstanceLifecycleConfigCommandError = return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1CreatePresignedDomainUrlCommand = async ( +export const deserializeAws_json1_1CreatePipelineCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1CreatePresignedDomainUrlCommandError(output, context); + return deserializeAws_json1_1CreatePipelineCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1CreatePresignedDomainUrlResponse(data, context); - const response: CreatePresignedDomainUrlCommandOutput = { + contents = deserializeAws_json1_1CreatePipelineResponse(data, context); + const response: CreatePipelineCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1CreatePresignedDomainUrlCommandError = async ( +const deserializeAws_json1_1CreatePipelineCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4234,6 +5491,14 @@ const deserializeAws_json1_1CreatePresignedDomainUrlCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -4259,27 +5524,27 @@ const deserializeAws_json1_1CreatePresignedDomainUrlCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommand = async ( +export const deserializeAws_json1_1CreatePresignedDomainUrlCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError(output, context); + return deserializeAws_json1_1CreatePresignedDomainUrlCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1CreatePresignedNotebookInstanceUrlOutput(data, context); - const response: CreatePresignedNotebookInstanceUrlCommandOutput = { + contents = deserializeAws_json1_1CreatePresignedDomainUrlResponse(data, context); + const response: CreatePresignedDomainUrlCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError = async ( +const deserializeAws_json1_1CreatePresignedDomainUrlCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4289,6 +5554,14 @@ const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError = asy const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -4306,10 +5579,57 @@ const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError = asy return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1CreateProcessingJobCommand = async ( +export const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreatePresignedNotebookInstanceUrlOutput(data, context); + const response: CreatePresignedNotebookInstanceUrlCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreatePresignedNotebookInstanceUrlCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1CreateProcessingJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { if (output.statusCode >= 300) { return deserializeAws_json1_1CreateProcessingJobCommandError(output, context); } @@ -4377,6 +5697,61 @@ const deserializeAws_json1_1CreateProcessingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; +export const deserializeAws_json1_1CreateProjectCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1CreateProjectCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1CreateProjectOutput(data, context); + const response: CreateProjectCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1CreateProjectCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + export const deserializeAws_json1_1CreateTrainingJobCommand = async ( output: __HttpResponse, context: __SerdeContext @@ -4810,24 +6185,27 @@ const deserializeAws_json1_1CreateWorkteamCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteAlgorithmCommand = async ( +export const deserializeAws_json1_1DeleteActionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteAlgorithmCommandError(output, context); + return deserializeAws_json1_1DeleteActionCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteAlgorithmCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteActionResponse(data, context); + const response: DeleteActionCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteAlgorithmCommandError = async ( +const deserializeAws_json1_1DeleteActionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4837,6 +6215,14 @@ const deserializeAws_json1_1DeleteAlgorithmCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -4854,24 +6240,24 @@ const deserializeAws_json1_1DeleteAlgorithmCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteAppCommand = async ( +export const deserializeAws_json1_1DeleteAlgorithmCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteAppCommandError(output, context); + return deserializeAws_json1_1DeleteAlgorithmCommandError(output, context); } await collectBody(output.body, context); - const response: DeleteAppCommandOutput = { + const response: DeleteAlgorithmCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteAppCommandError = async ( +const deserializeAws_json1_1DeleteAlgorithmCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4881,22 +6267,6 @@ const deserializeAws_json1_1DeleteAppCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -4914,24 +6284,24 @@ const deserializeAws_json1_1DeleteAppCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteAppImageConfigCommand = async ( +export const deserializeAws_json1_1DeleteAppCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteAppImageConfigCommandError(output, context); + return deserializeAws_json1_1DeleteAppCommandError(output, context); } await collectBody(output.body, context); - const response: DeleteAppImageConfigCommandOutput = { + const response: DeleteAppCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteAppImageConfigCommandError = async ( +const deserializeAws_json1_1DeleteAppCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4941,6 +6311,14 @@ const deserializeAws_json1_1DeleteAppImageConfigCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -4966,24 +6344,24 @@ const deserializeAws_json1_1DeleteAppImageConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteCodeRepositoryCommand = async ( +export const deserializeAws_json1_1DeleteAppImageConfigCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteCodeRepositoryCommandError(output, context); + return deserializeAws_json1_1DeleteAppImageConfigCommandError(output, context); } await collectBody(output.body, context); - const response: DeleteCodeRepositoryCommandOutput = { + const response: DeleteAppImageConfigCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteCodeRepositoryCommandError = async ( +const deserializeAws_json1_1DeleteAppImageConfigCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -4993,6 +6371,14 @@ const deserializeAws_json1_1DeleteCodeRepositoryCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5010,24 +6396,27 @@ const deserializeAws_json1_1DeleteCodeRepositoryCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteDomainCommand = async ( +export const deserializeAws_json1_1DeleteArtifactCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteDomainCommandError(output, context); + return deserializeAws_json1_1DeleteArtifactCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteDomainCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteArtifactResponse(data, context); + const response: DeleteArtifactCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteDomainCommandError = async ( +const deserializeAws_json1_1DeleteArtifactCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5037,14 +6426,6 @@ const deserializeAws_json1_1DeleteDomainCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -5070,24 +6451,27 @@ const deserializeAws_json1_1DeleteDomainCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteEndpointCommand = async ( +export const deserializeAws_json1_1DeleteAssociationCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteEndpointCommandError(output, context); + return deserializeAws_json1_1DeleteAssociationCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteEndpointCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteAssociationResponse(data, context); + const response: DeleteAssociationCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteEndpointCommandError = async ( +const deserializeAws_json1_1DeleteAssociationCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5097,6 +6481,14 @@ const deserializeAws_json1_1DeleteEndpointCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5114,24 +6506,24 @@ const deserializeAws_json1_1DeleteEndpointCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteEndpointConfigCommand = async ( +export const deserializeAws_json1_1DeleteCodeRepositoryCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteEndpointConfigCommandError(output, context); + return deserializeAws_json1_1DeleteCodeRepositoryCommandError(output, context); } await collectBody(output.body, context); - const response: DeleteEndpointConfigCommandOutput = { + const response: DeleteCodeRepositoryCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteEndpointConfigCommandError = async ( +const deserializeAws_json1_1DeleteCodeRepositoryCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5158,27 +6550,27 @@ const deserializeAws_json1_1DeleteEndpointConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteExperimentCommand = async ( +export const deserializeAws_json1_1DeleteContextCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteExperimentCommandError(output, context); + return deserializeAws_json1_1DeleteContextCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteExperimentResponse(data, context); - const response: DeleteExperimentCommandOutput = { + contents = deserializeAws_json1_1DeleteContextResponse(data, context); + const response: DeleteContextCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteExperimentCommandError = async ( +const deserializeAws_json1_1DeleteContextCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5213,27 +6605,24 @@ const deserializeAws_json1_1DeleteExperimentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteFlowDefinitionCommand = async ( +export const deserializeAws_json1_1DeleteDomainCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteFlowDefinitionCommandError(output, context); + return deserializeAws_json1_1DeleteDomainCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1DeleteFlowDefinitionResponse(data, context); - const response: DeleteFlowDefinitionCommandOutput = { + await collectBody(output.body, context); + const response: DeleteDomainCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteFlowDefinitionCommandError = async ( +const deserializeAws_json1_1DeleteDomainCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5276,10 +6665,268 @@ const deserializeAws_json1_1DeleteFlowDefinitionCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteHumanTaskUiCommand = async ( +export const deserializeAws_json1_1DeleteEndpointCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteEndpointCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteEndpointCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteEndpointCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteEndpointConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteEndpointConfigCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteEndpointConfigCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteEndpointConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteExperimentCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteExperimentCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteExperimentResponse(data, context); + const response: DeleteExperimentCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteExperimentCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteFeatureGroupCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteFeatureGroupCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteFeatureGroupCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteFeatureGroupCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteFlowDefinitionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteFlowDefinitionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteFlowDefinitionResponse(data, context); + const response: DeleteFlowDefinitionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteFlowDefinitionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteHumanTaskUiCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { if (output.statusCode >= 300) { return deserializeAws_json1_1DeleteHumanTaskUiCommandError(output, context); } @@ -5394,27 +7041,1994 @@ const deserializeAws_json1_1DeleteImageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteImageVersionCommand = async ( +export const deserializeAws_json1_1DeleteImageVersionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteImageVersionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteImageVersionResponse(data, context); + const response: DeleteImageVersionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteImageVersionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteModelCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteModelCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteModelPackageCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteModelPackageCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteModelPackageCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteModelPackageCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ConflictException": + case "com.amazonaws.sagemaker#ConflictException": + response = { + ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteModelPackageGroupCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteModelPackageGroupCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteModelPackageGroupCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteModelPackageGroupCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteModelPackageGroupPolicyCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteModelPackageGroupPolicyCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteModelPackageGroupPolicyCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteModelPackageGroupPolicyCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteMonitoringScheduleCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteMonitoringScheduleCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteMonitoringScheduleCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteMonitoringScheduleCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteNotebookInstanceCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteNotebookInstanceCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteNotebookInstanceCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteNotebookInstanceCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteNotebookInstanceLifecycleConfigCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeletePipelineCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeletePipelineCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeletePipelineResponse(data, context); + const response: DeletePipelineCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeletePipelineCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteProjectCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteProjectCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteProjectCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteProjectCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteTagsCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteTagsCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteTagsOutput(data, context); + const response: DeleteTagsCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteTagsCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteTrialCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteTrialCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteTrialResponse(data, context); + const response: DeleteTrialCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteTrialCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteTrialComponentCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteTrialComponentCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteTrialComponentResponse(data, context); + const response: DeleteTrialComponentCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteTrialComponentCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteUserProfileCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteUserProfileCommandError(output, context); + } + await collectBody(output.body, context); + const response: DeleteUserProfileCommandOutput = { + $metadata: deserializeMetadata(output), + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteUserProfileCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteWorkforceCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteWorkforceCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteWorkforceResponse(data, context); + const response: DeleteWorkforceCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteWorkforceCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DeleteWorkteamCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DeleteWorkteamCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DeleteWorkteamResponse(data, context); + const response: DeleteWorkteamCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DeleteWorkteamCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeActionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeActionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeActionResponse(data, context); + const response: DescribeActionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeActionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeAlgorithmCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeAlgorithmCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeAlgorithmOutput(data, context); + const response: DescribeAlgorithmCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeAlgorithmCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeAppCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeAppCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeAppResponse(data, context); + const response: DescribeAppCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeAppCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeAppImageConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeAppImageConfigCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeAppImageConfigResponse(data, context); + const response: DescribeAppImageConfigCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeAppImageConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeArtifactCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeArtifactCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeArtifactResponse(data, context); + const response: DescribeArtifactCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeArtifactCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeAutoMLJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeAutoMLJobCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeAutoMLJobResponse(data, context); + const response: DescribeAutoMLJobCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeAutoMLJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeCodeRepositoryCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeCodeRepositoryCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeCodeRepositoryOutput(data, context); + const response: DescribeCodeRepositoryCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeCodeRepositoryCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeCompilationJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeCompilationJobCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeCompilationJobResponse(data, context); + const response: DescribeCompilationJobCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeCompilationJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeContextCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeContextCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeContextResponse(data, context); + const response: DescribeContextCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeContextCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeDomainCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeDomainCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeDomainResponse(data, context); + const response: DescribeDomainCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeDomainCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeEndpointCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeEndpointCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeEndpointOutput(data, context); + const response: DescribeEndpointCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeEndpointCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeEndpointConfigCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeEndpointConfigCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeEndpointConfigOutput(data, context); + const response: DescribeEndpointConfigCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeEndpointConfigCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeExperimentCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeExperimentCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeExperimentResponse(data, context); + const response: DescribeExperimentCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeExperimentCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeFeatureGroupCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeFeatureGroupCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeFeatureGroupResponse(data, context); + const response: DescribeFeatureGroupCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeFeatureGroupCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeFlowDefinitionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeFlowDefinitionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeFlowDefinitionResponse(data, context); + const response: DescribeFlowDefinitionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeFlowDefinitionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeHumanTaskUiCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeHumanTaskUiCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeHumanTaskUiResponse(data, context); + const response: DescribeHumanTaskUiCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeHumanTaskUiCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeHyperParameterTuningJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeHyperParameterTuningJobResponse(data, context); + const response: DescribeHyperParameterTuningJobCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeImageCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeImageCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeImageResponse(data, context); + const response: DescribeImageCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeImageCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeImageVersionCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeImageVersionCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeImageVersionResponse(data, context); + const response: DescribeImageVersionCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeImageVersionCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeLabelingJobCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeLabelingJobCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeLabelingJobResponse(data, context); + const response: DescribeLabelingJobCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeLabelingJobCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeModelCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeModelCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeModelOutput(data, context); + const response: DescribeModelCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeModelCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeModelPackageCommand = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + if (output.statusCode >= 300) { + return deserializeAws_json1_1DescribeModelPackageCommandError(output, context); + } + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeModelPackageOutput(data, context); + const response: DescribeModelPackageCommandOutput = { + $metadata: deserializeMetadata(output), + ...contents, + }; + return Promise.resolve(response); +}; + +const deserializeAws_json1_1DescribeModelPackageCommandError = async ( + output: __HttpResponse, + context: __SerdeContext +): Promise => { + const parsedOutput: any = { + ...output, + body: await parseBody(output.body, context), + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { + default: + const parsedBody = parsedOutput.body; + errorCode = parsedBody.code || parsedBody.Code || errorCode; + response = { + ...parsedBody, + name: `${errorCode}`, + message: parsedBody.message || parsedBody.Message || errorCode, + $fault: "client", + $metadata: deserializeMetadata(output), + } as any; + } + const message = response.message || response.Message || errorCode; + response.message = message; + delete response.Message; + return Promise.reject(Object.assign(new Error(message), response)); +}; + +export const deserializeAws_json1_1DescribeModelPackageGroupCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteImageVersionCommandError(output, context); + return deserializeAws_json1_1DescribeModelPackageGroupCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteImageVersionResponse(data, context); - const response: DeleteImageVersionCommandOutput = { + contents = deserializeAws_json1_1DescribeModelPackageGroupOutput(data, context); + const response: DescribeModelPackageGroupCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteImageVersionCommandError = async ( +const deserializeAws_json1_1DescribeModelPackageGroupCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5424,22 +9038,6 @@ const deserializeAws_json1_1DeleteImageVersionCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5457,24 +9055,27 @@ const deserializeAws_json1_1DeleteImageVersionCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteModelCommand = async ( +export const deserializeAws_json1_1DescribeMonitoringScheduleCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteModelCommandError(output, context); + return deserializeAws_json1_1DescribeMonitoringScheduleCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteModelCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeMonitoringScheduleResponse(data, context); + const response: DescribeMonitoringScheduleCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteModelCommandError = async ( +const deserializeAws_json1_1DescribeMonitoringScheduleCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5484,6 +9085,14 @@ const deserializeAws_json1_1DeleteModelCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5501,24 +9110,27 @@ const deserializeAws_json1_1DeleteModelCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteModelPackageCommand = async ( +export const deserializeAws_json1_1DescribeNotebookInstanceCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteModelPackageCommandError(output, context); + return deserializeAws_json1_1DescribeNotebookInstanceCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteModelPackageCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeNotebookInstanceOutput(data, context); + const response: DescribeNotebookInstanceCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteModelPackageCommandError = async ( +const deserializeAws_json1_1DescribeNotebookInstanceCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5528,14 +9140,6 @@ const deserializeAws_json1_1DeleteModelPackageCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ConflictException": - case "com.amazonaws.sagemaker#ConflictException": - response = { - ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5553,24 +9157,27 @@ const deserializeAws_json1_1DeleteModelPackageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteMonitoringScheduleCommand = async ( +export const deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteMonitoringScheduleCommandError(output, context); + return deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteMonitoringScheduleCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigOutput(data, context); + const response: DescribeNotebookInstanceLifecycleConfigCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteMonitoringScheduleCommandError = async ( +const deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5580,14 +9187,6 @@ const deserializeAws_json1_1DeleteMonitoringScheduleCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5605,24 +9204,27 @@ const deserializeAws_json1_1DeleteMonitoringScheduleCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteNotebookInstanceCommand = async ( +export const deserializeAws_json1_1DescribePipelineCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteNotebookInstanceCommandError(output, context); + return deserializeAws_json1_1DescribePipelineCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteNotebookInstanceCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribePipelineResponse(data, context); + const response: DescribePipelineCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteNotebookInstanceCommandError = async ( +const deserializeAws_json1_1DescribePipelineCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5632,6 +9234,14 @@ const deserializeAws_json1_1DeleteNotebookInstanceCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5649,24 +9259,27 @@ const deserializeAws_json1_1DeleteNotebookInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommand = async ( +export const deserializeAws_json1_1DescribePipelineDefinitionForExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError(output, context); + return deserializeAws_json1_1DescribePipelineDefinitionForExecutionCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteNotebookInstanceLifecycleConfigCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribePipelineDefinitionForExecutionResponse(data, context); + const response: DescribePipelineDefinitionForExecutionCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError = async ( +const deserializeAws_json1_1DescribePipelineDefinitionForExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5676,6 +9289,14 @@ const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError = const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5693,27 +9314,27 @@ const deserializeAws_json1_1DeleteNotebookInstanceLifecycleConfigCommandError = return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteTagsCommand = async ( +export const deserializeAws_json1_1DescribePipelineExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteTagsCommandError(output, context); + return deserializeAws_json1_1DescribePipelineExecutionCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteTagsOutput(data, context); - const response: DeleteTagsCommandOutput = { + contents = deserializeAws_json1_1DescribePipelineExecutionResponse(data, context); + const response: DescribePipelineExecutionCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteTagsCommandError = async ( +const deserializeAws_json1_1DescribePipelineExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5723,6 +9344,14 @@ const deserializeAws_json1_1DeleteTagsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5740,27 +9369,27 @@ const deserializeAws_json1_1DeleteTagsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteTrialCommand = async ( +export const deserializeAws_json1_1DescribeProcessingJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteTrialCommandError(output, context); + return deserializeAws_json1_1DescribeProcessingJobCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteTrialResponse(data, context); - const response: DeleteTrialCommandOutput = { + contents = deserializeAws_json1_1DescribeProcessingJobResponse(data, context); + const response: DescribeProcessingJobCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteTrialCommandError = async ( +const deserializeAws_json1_1DescribeProcessingJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5795,27 +9424,27 @@ const deserializeAws_json1_1DeleteTrialCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteTrialComponentCommand = async ( +export const deserializeAws_json1_1DescribeProjectCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteTrialComponentCommandError(output, context); + return deserializeAws_json1_1DescribeProjectCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteTrialComponentResponse(data, context); - const response: DeleteTrialComponentCommandOutput = { + contents = deserializeAws_json1_1DescribeProjectOutput(data, context); + const response: DescribeProjectCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteTrialComponentCommandError = async ( +const deserializeAws_json1_1DescribeProjectCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5825,14 +9454,6 @@ const deserializeAws_json1_1DeleteTrialComponentCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5850,24 +9471,27 @@ const deserializeAws_json1_1DeleteTrialComponentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteUserProfileCommand = async ( +export const deserializeAws_json1_1DescribeSubscribedWorkteamCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteUserProfileCommandError(output, context); + return deserializeAws_json1_1DescribeSubscribedWorkteamCommandError(output, context); } - await collectBody(output.body, context); - const response: DeleteUserProfileCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1DescribeSubscribedWorkteamResponse(data, context); + const response: DescribeSubscribedWorkteamCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteUserProfileCommandError = async ( +const deserializeAws_json1_1DescribeSubscribedWorkteamCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5877,22 +9501,6 @@ const deserializeAws_json1_1DeleteUserProfileCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5910,27 +9518,27 @@ const deserializeAws_json1_1DeleteUserProfileCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteWorkforceCommand = async ( +export const deserializeAws_json1_1DescribeTrainingJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteWorkforceCommandError(output, context); + return deserializeAws_json1_1DescribeTrainingJobCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DeleteWorkforceResponse(data, context); - const response: DeleteWorkforceCommandOutput = { + contents = deserializeAws_json1_1DescribeTrainingJobResponse(data, context); + const response: DescribeTrainingJobCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteWorkforceCommandError = async ( +const deserializeAws_json1_1DescribeTrainingJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5940,6 +9548,14 @@ const deserializeAws_json1_1DeleteWorkforceCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -5957,27 +9573,27 @@ const deserializeAws_json1_1DeleteWorkforceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DeleteWorkteamCommand = async ( +export const deserializeAws_json1_1DescribeTransformJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DeleteWorkteamCommandError(output, context); + return deserializeAws_json1_1DescribeTransformJobCommandError(output, context); } const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1DeleteWorkteamResponse(data, context); - const response: DeleteWorkteamCommandOutput = { + let contents: any = {}; + contents = deserializeAws_json1_1DescribeTransformJobResponse(data, context); + const response: DescribeTransformJobCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DeleteWorkteamCommandError = async ( +const deserializeAws_json1_1DescribeTransformJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -5987,10 +9603,10 @@ const deserializeAws_json1_1DeleteWorkteamCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -6012,27 +9628,27 @@ const deserializeAws_json1_1DeleteWorkteamCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeAlgorithmCommand = async ( +export const deserializeAws_json1_1DescribeTrialCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeAlgorithmCommandError(output, context); + return deserializeAws_json1_1DescribeTrialCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeAlgorithmOutput(data, context); - const response: DescribeAlgorithmCommandOutput = { + contents = deserializeAws_json1_1DescribeTrialResponse(data, context); + const response: DescribeTrialCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeAlgorithmCommandError = async ( +const deserializeAws_json1_1DescribeTrialCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6042,6 +9658,14 @@ const deserializeAws_json1_1DescribeAlgorithmCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6059,27 +9683,27 @@ const deserializeAws_json1_1DescribeAlgorithmCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeAppCommand = async ( +export const deserializeAws_json1_1DescribeTrialComponentCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeAppCommandError(output, context); + return deserializeAws_json1_1DescribeTrialComponentCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeAppResponse(data, context); - const response: DescribeAppCommandOutput = { + contents = deserializeAws_json1_1DescribeTrialComponentResponse(data, context); + const response: DescribeTrialComponentCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeAppCommandError = async ( +const deserializeAws_json1_1DescribeTrialComponentCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6114,27 +9738,27 @@ const deserializeAws_json1_1DescribeAppCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeAppImageConfigCommand = async ( +export const deserializeAws_json1_1DescribeUserProfileCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeAppImageConfigCommandError(output, context); + return deserializeAws_json1_1DescribeUserProfileCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeAppImageConfigResponse(data, context); - const response: DescribeAppImageConfigCommandOutput = { + contents = deserializeAws_json1_1DescribeUserProfileResponse(data, context); + const response: DescribeUserProfileCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeAppImageConfigCommandError = async ( +const deserializeAws_json1_1DescribeUserProfileCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6169,27 +9793,27 @@ const deserializeAws_json1_1DescribeAppImageConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeAutoMLJobCommand = async ( +export const deserializeAws_json1_1DescribeWorkforceCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeAutoMLJobCommandError(output, context); + return deserializeAws_json1_1DescribeWorkforceCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeAutoMLJobResponse(data, context); - const response: DescribeAutoMLJobCommandOutput = { + contents = deserializeAws_json1_1DescribeWorkforceResponse(data, context); + const response: DescribeWorkforceCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeAutoMLJobCommandError = async ( +const deserializeAws_json1_1DescribeWorkforceCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6199,14 +9823,6 @@ const deserializeAws_json1_1DescribeAutoMLJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6224,27 +9840,27 @@ const deserializeAws_json1_1DescribeAutoMLJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeCodeRepositoryCommand = async ( +export const deserializeAws_json1_1DescribeWorkteamCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeCodeRepositoryCommandError(output, context); + return deserializeAws_json1_1DescribeWorkteamCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeCodeRepositoryOutput(data, context); - const response: DescribeCodeRepositoryCommandOutput = { + contents = deserializeAws_json1_1DescribeWorkteamResponse(data, context); + const response: DescribeWorkteamCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeCodeRepositoryCommandError = async ( +const deserializeAws_json1_1DescribeWorkteamCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6271,27 +9887,27 @@ const deserializeAws_json1_1DescribeCodeRepositoryCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeCompilationJobCommand = async ( +export const deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeCompilationJobCommandError(output, context); + return deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeCompilationJobResponse(data, context); - const response: DescribeCompilationJobCommandOutput = { + contents = deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioOutput(data, context); + const response: DisableSagemakerServicecatalogPortfolioCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeCompilationJobCommandError = async ( +const deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6301,14 +9917,6 @@ const deserializeAws_json1_1DescribeCompilationJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6326,27 +9934,27 @@ const deserializeAws_json1_1DescribeCompilationJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeDomainCommand = async ( +export const deserializeAws_json1_1DisassociateTrialComponentCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeDomainCommandError(output, context); + return deserializeAws_json1_1DisassociateTrialComponentCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeDomainResponse(data, context); - const response: DescribeDomainCommandOutput = { + contents = deserializeAws_json1_1DisassociateTrialComponentResponse(data, context); + const response: DisassociateTrialComponentCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeDomainCommandError = async ( +const deserializeAws_json1_1DisassociateTrialComponentCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6381,27 +9989,27 @@ const deserializeAws_json1_1DescribeDomainCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeEndpointCommand = async ( +export const deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeEndpointCommandError(output, context); + return deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeEndpointOutput(data, context); - const response: DescribeEndpointCommandOutput = { + contents = deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioOutput(data, context); + const response: EnableSagemakerServicecatalogPortfolioCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeEndpointCommandError = async ( +const deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6428,27 +10036,27 @@ const deserializeAws_json1_1DescribeEndpointCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeEndpointConfigCommand = async ( +export const deserializeAws_json1_1GetModelPackageGroupPolicyCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeEndpointConfigCommandError(output, context); + return deserializeAws_json1_1GetModelPackageGroupPolicyCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeEndpointConfigOutput(data, context); - const response: DescribeEndpointConfigCommandOutput = { + contents = deserializeAws_json1_1GetModelPackageGroupPolicyOutput(data, context); + const response: GetModelPackageGroupPolicyCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeEndpointConfigCommandError = async ( +const deserializeAws_json1_1GetModelPackageGroupPolicyCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6475,27 +10083,27 @@ const deserializeAws_json1_1DescribeEndpointConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeExperimentCommand = async ( +export const deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeExperimentCommandError(output, context); + return deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeExperimentResponse(data, context); - const response: DescribeExperimentCommandOutput = { + contents = deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusOutput(data, context); + const response: GetSagemakerServicecatalogPortfolioStatusCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeExperimentCommandError = async ( +const deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6505,14 +10113,6 @@ const deserializeAws_json1_1DescribeExperimentCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6530,27 +10130,27 @@ const deserializeAws_json1_1DescribeExperimentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeFlowDefinitionCommand = async ( +export const deserializeAws_json1_1GetSearchSuggestionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeFlowDefinitionCommandError(output, context); + return deserializeAws_json1_1GetSearchSuggestionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeFlowDefinitionResponse(data, context); - const response: DescribeFlowDefinitionCommandOutput = { + contents = deserializeAws_json1_1GetSearchSuggestionsResponse(data, context); + const response: GetSearchSuggestionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeFlowDefinitionCommandError = async ( +const deserializeAws_json1_1GetSearchSuggestionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6560,14 +10160,6 @@ const deserializeAws_json1_1DescribeFlowDefinitionCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6585,27 +10177,27 @@ const deserializeAws_json1_1DescribeFlowDefinitionCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeHumanTaskUiCommand = async ( +export const deserializeAws_json1_1ListActionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeHumanTaskUiCommandError(output, context); + return deserializeAws_json1_1ListActionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeHumanTaskUiResponse(data, context); - const response: DescribeHumanTaskUiCommandOutput = { + contents = deserializeAws_json1_1ListActionsResponse(data, context); + const response: ListActionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeHumanTaskUiCommandError = async ( +const deserializeAws_json1_1ListActionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6640,27 +10232,27 @@ const deserializeAws_json1_1DescribeHumanTaskUiCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeHyperParameterTuningJobCommand = async ( +export const deserializeAws_json1_1ListAlgorithmsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError(output, context); + return deserializeAws_json1_1ListAlgorithmsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeHyperParameterTuningJobResponse(data, context); - const response: DescribeHyperParameterTuningJobCommandOutput = { + contents = deserializeAws_json1_1ListAlgorithmsOutput(data, context); + const response: ListAlgorithmsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError = async ( +const deserializeAws_json1_1ListAlgorithmsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6670,14 +10262,6 @@ const deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError = async const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6695,27 +10279,27 @@ const deserializeAws_json1_1DescribeHyperParameterTuningJobCommandError = async return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeImageCommand = async ( +export const deserializeAws_json1_1ListAppImageConfigsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeImageCommandError(output, context); + return deserializeAws_json1_1ListAppImageConfigsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeImageResponse(data, context); - const response: DescribeImageCommandOutput = { + contents = deserializeAws_json1_1ListAppImageConfigsResponse(data, context); + const response: ListAppImageConfigsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeImageCommandError = async ( +const deserializeAws_json1_1ListAppImageConfigsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6725,14 +10309,6 @@ const deserializeAws_json1_1DescribeImageCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6750,44 +10326,36 @@ const deserializeAws_json1_1DescribeImageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeImageVersionCommand = async ( +export const deserializeAws_json1_1ListAppsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeImageVersionCommandError(output, context); + return deserializeAws_json1_1ListAppsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeImageVersionResponse(data, context); - const response: DescribeImageVersionCommandOutput = { + contents = deserializeAws_json1_1ListAppsResponse(data, context); + const response: ListAppsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeImageVersionCommandError = async ( +const deserializeAws_json1_1ListAppsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), }; let response: __SmithyException & __MetadataBearer & { [key: string]: any }; - let errorCode: string = "UnknownError"; - const errorTypeParts: String = parsedOutput.body["__type"].split("#"); - errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; - switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6805,27 +10373,27 @@ const deserializeAws_json1_1DescribeImageVersionCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeLabelingJobCommand = async ( +export const deserializeAws_json1_1ListArtifactsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeLabelingJobCommandError(output, context); + return deserializeAws_json1_1ListArtifactsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeLabelingJobResponse(data, context); - const response: DescribeLabelingJobCommandOutput = { + contents = deserializeAws_json1_1ListArtifactsResponse(data, context); + const response: ListArtifactsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeLabelingJobCommandError = async ( +const deserializeAws_json1_1ListArtifactsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6860,27 +10428,27 @@ const deserializeAws_json1_1DescribeLabelingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeModelCommand = async ( +export const deserializeAws_json1_1ListAssociationsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeModelCommandError(output, context); + return deserializeAws_json1_1ListAssociationsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeModelOutput(data, context); - const response: DescribeModelCommandOutput = { + contents = deserializeAws_json1_1ListAssociationsResponse(data, context); + const response: ListAssociationsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeModelCommandError = async ( +const deserializeAws_json1_1ListAssociationsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6890,6 +10458,14 @@ const deserializeAws_json1_1DescribeModelCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -6907,27 +10483,27 @@ const deserializeAws_json1_1DescribeModelCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeModelPackageCommand = async ( +export const deserializeAws_json1_1ListAutoMLJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeModelPackageCommandError(output, context); + return deserializeAws_json1_1ListAutoMLJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeModelPackageOutput(data, context); - const response: DescribeModelPackageCommandOutput = { + contents = deserializeAws_json1_1ListAutoMLJobsResponse(data, context); + const response: ListAutoMLJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeModelPackageCommandError = async ( +const deserializeAws_json1_1ListAutoMLJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -6954,27 +10530,27 @@ const deserializeAws_json1_1DescribeModelPackageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeMonitoringScheduleCommand = async ( +export const deserializeAws_json1_1ListCandidatesForAutoMLJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeMonitoringScheduleCommandError(output, context); + return deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeMonitoringScheduleResponse(data, context); - const response: DescribeMonitoringScheduleCommandOutput = { + contents = deserializeAws_json1_1ListCandidatesForAutoMLJobResponse(data, context); + const response: ListCandidatesForAutoMLJobCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeMonitoringScheduleCommandError = async ( +const deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7009,27 +10585,27 @@ const deserializeAws_json1_1DescribeMonitoringScheduleCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeNotebookInstanceCommand = async ( +export const deserializeAws_json1_1ListCodeRepositoriesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeNotebookInstanceCommandError(output, context); + return deserializeAws_json1_1ListCodeRepositoriesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeNotebookInstanceOutput(data, context); - const response: DescribeNotebookInstanceCommandOutput = { + contents = deserializeAws_json1_1ListCodeRepositoriesOutput(data, context); + const response: ListCodeRepositoriesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeNotebookInstanceCommandError = async ( +const deserializeAws_json1_1ListCodeRepositoriesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7056,27 +10632,27 @@ const deserializeAws_json1_1DescribeNotebookInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommand = async ( +export const deserializeAws_json1_1ListCompilationJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommandError(output, context); + return deserializeAws_json1_1ListCompilationJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigOutput(data, context); - const response: DescribeNotebookInstanceLifecycleConfigCommandOutput = { + contents = deserializeAws_json1_1ListCompilationJobsResponse(data, context); + const response: ListCompilationJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommandError = async ( +const deserializeAws_json1_1ListCompilationJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7103,27 +10679,27 @@ const deserializeAws_json1_1DescribeNotebookInstanceLifecycleConfigCommandError return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeProcessingJobCommand = async ( +export const deserializeAws_json1_1ListContextsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeProcessingJobCommandError(output, context); + return deserializeAws_json1_1ListContextsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeProcessingJobResponse(data, context); - const response: DescribeProcessingJobCommandOutput = { + contents = deserializeAws_json1_1ListContextsResponse(data, context); + const response: ListContextsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeProcessingJobCommandError = async ( +const deserializeAws_json1_1ListContextsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7158,74 +10734,27 @@ const deserializeAws_json1_1DescribeProcessingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeSubscribedWorkteamCommand = async ( - output: __HttpResponse, - context: __SerdeContext -): Promise => { - if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeSubscribedWorkteamCommandError(output, context); - } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1DescribeSubscribedWorkteamResponse(data, context); - const response: DescribeSubscribedWorkteamCommandOutput = { - $metadata: deserializeMetadata(output), - ...contents, - }; - return Promise.resolve(response); -}; - -const deserializeAws_json1_1DescribeSubscribedWorkteamCommandError = async ( - output: __HttpResponse, - context: __SerdeContext -): Promise => { - const parsedOutput: any = { - ...output, - body: await parseBody(output.body, context), - }; - let response: __SmithyException & __MetadataBearer & { [key: string]: any }; - let errorCode: string = "UnknownError"; - const errorTypeParts: String = parsedOutput.body["__type"].split("#"); - errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; - switch (errorCode) { - default: - const parsedBody = parsedOutput.body; - errorCode = parsedBody.code || parsedBody.Code || errorCode; - response = { - ...parsedBody, - name: `${errorCode}`, - message: parsedBody.message || parsedBody.Message || errorCode, - $fault: "client", - $metadata: deserializeMetadata(output), - } as any; - } - const message = response.message || response.Message || errorCode; - response.message = message; - delete response.Message; - return Promise.reject(Object.assign(new Error(message), response)); -}; - -export const deserializeAws_json1_1DescribeTrainingJobCommand = async ( +export const deserializeAws_json1_1ListDomainsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeTrainingJobCommandError(output, context); + return deserializeAws_json1_1ListDomainsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeTrainingJobResponse(data, context); - const response: DescribeTrainingJobCommandOutput = { + contents = deserializeAws_json1_1ListDomainsResponse(data, context); + const response: ListDomainsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeTrainingJobCommandError = async ( +const deserializeAws_json1_1ListDomainsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7235,14 +10764,6 @@ const deserializeAws_json1_1DescribeTrainingJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7260,27 +10781,27 @@ const deserializeAws_json1_1DescribeTrainingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeTransformJobCommand = async ( +export const deserializeAws_json1_1ListEndpointConfigsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeTransformJobCommandError(output, context); + return deserializeAws_json1_1ListEndpointConfigsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeTransformJobResponse(data, context); - const response: DescribeTransformJobCommandOutput = { + contents = deserializeAws_json1_1ListEndpointConfigsOutput(data, context); + const response: ListEndpointConfigsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeTransformJobCommandError = async ( +const deserializeAws_json1_1ListEndpointConfigsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7290,14 +10811,6 @@ const deserializeAws_json1_1DescribeTransformJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7315,27 +10828,27 @@ const deserializeAws_json1_1DescribeTransformJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeTrialCommand = async ( +export const deserializeAws_json1_1ListEndpointsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeTrialCommandError(output, context); + return deserializeAws_json1_1ListEndpointsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeTrialResponse(data, context); - const response: DescribeTrialCommandOutput = { + contents = deserializeAws_json1_1ListEndpointsOutput(data, context); + const response: ListEndpointsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeTrialCommandError = async ( +const deserializeAws_json1_1ListEndpointsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7345,14 +10858,6 @@ const deserializeAws_json1_1DescribeTrialCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7370,27 +10875,27 @@ const deserializeAws_json1_1DescribeTrialCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeTrialComponentCommand = async ( +export const deserializeAws_json1_1ListExperimentsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeTrialComponentCommandError(output, context); + return deserializeAws_json1_1ListExperimentsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeTrialComponentResponse(data, context); - const response: DescribeTrialComponentCommandOutput = { + contents = deserializeAws_json1_1ListExperimentsResponse(data, context); + const response: ListExperimentsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeTrialComponentCommandError = async ( +const deserializeAws_json1_1ListExperimentsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7400,14 +10905,6 @@ const deserializeAws_json1_1DescribeTrialComponentCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7425,27 +10922,27 @@ const deserializeAws_json1_1DescribeTrialComponentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeUserProfileCommand = async ( +export const deserializeAws_json1_1ListFeatureGroupsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeUserProfileCommandError(output, context); + return deserializeAws_json1_1ListFeatureGroupsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeUserProfileResponse(data, context); - const response: DescribeUserProfileCommandOutput = { + contents = deserializeAws_json1_1ListFeatureGroupsResponse(data, context); + const response: ListFeatureGroupsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeUserProfileCommandError = async ( +const deserializeAws_json1_1ListFeatureGroupsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7455,14 +10952,6 @@ const deserializeAws_json1_1DescribeUserProfileCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7480,27 +10969,27 @@ const deserializeAws_json1_1DescribeUserProfileCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeWorkforceCommand = async ( +export const deserializeAws_json1_1ListFlowDefinitionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeWorkforceCommandError(output, context); + return deserializeAws_json1_1ListFlowDefinitionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeWorkforceResponse(data, context); - const response: DescribeWorkforceCommandOutput = { + contents = deserializeAws_json1_1ListFlowDefinitionsResponse(data, context); + const response: ListFlowDefinitionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeWorkforceCommandError = async ( +const deserializeAws_json1_1ListFlowDefinitionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7527,27 +11016,27 @@ const deserializeAws_json1_1DescribeWorkforceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DescribeWorkteamCommand = async ( +export const deserializeAws_json1_1ListHumanTaskUisCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DescribeWorkteamCommandError(output, context); + return deserializeAws_json1_1ListHumanTaskUisCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DescribeWorkteamResponse(data, context); - const response: DescribeWorkteamCommandOutput = { + contents = deserializeAws_json1_1ListHumanTaskUisResponse(data, context); + const response: ListHumanTaskUisCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DescribeWorkteamCommandError = async ( +const deserializeAws_json1_1ListHumanTaskUisCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7574,27 +11063,27 @@ const deserializeAws_json1_1DescribeWorkteamCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1DisassociateTrialComponentCommand = async ( +export const deserializeAws_json1_1ListHyperParameterTuningJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1DisassociateTrialComponentCommandError(output, context); + return deserializeAws_json1_1ListHyperParameterTuningJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1DisassociateTrialComponentResponse(data, context); - const response: DisassociateTrialComponentCommandOutput = { + contents = deserializeAws_json1_1ListHyperParameterTuningJobsResponse(data, context); + const response: ListHyperParameterTuningJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1DisassociateTrialComponentCommandError = async ( +const deserializeAws_json1_1ListHyperParameterTuningJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7604,14 +11093,6 @@ const deserializeAws_json1_1DisassociateTrialComponentCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7629,27 +11110,27 @@ const deserializeAws_json1_1DisassociateTrialComponentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1GetSearchSuggestionsCommand = async ( +export const deserializeAws_json1_1ListImagesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1GetSearchSuggestionsCommandError(output, context); + return deserializeAws_json1_1ListImagesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1GetSearchSuggestionsResponse(data, context); - const response: GetSearchSuggestionsCommandOutput = { + contents = deserializeAws_json1_1ListImagesResponse(data, context); + const response: ListImagesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1GetSearchSuggestionsCommandError = async ( +const deserializeAws_json1_1ListImagesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7676,27 +11157,27 @@ const deserializeAws_json1_1GetSearchSuggestionsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListAlgorithmsCommand = async ( +export const deserializeAws_json1_1ListImageVersionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListAlgorithmsCommandError(output, context); + return deserializeAws_json1_1ListImageVersionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListAlgorithmsOutput(data, context); - const response: ListAlgorithmsCommandOutput = { + contents = deserializeAws_json1_1ListImageVersionsResponse(data, context); + const response: ListImageVersionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListAlgorithmsCommandError = async ( +const deserializeAws_json1_1ListImageVersionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7706,6 +11187,14 @@ const deserializeAws_json1_1ListAlgorithmsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7723,27 +11212,27 @@ const deserializeAws_json1_1ListAlgorithmsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListAppImageConfigsCommand = async ( +export const deserializeAws_json1_1ListLabelingJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListAppImageConfigsCommandError(output, context); + return deserializeAws_json1_1ListLabelingJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListAppImageConfigsResponse(data, context); - const response: ListAppImageConfigsCommandOutput = { + contents = deserializeAws_json1_1ListLabelingJobsResponse(data, context); + const response: ListLabelingJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListAppImageConfigsCommandError = async ( +const deserializeAws_json1_1ListLabelingJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7770,27 +11259,27 @@ const deserializeAws_json1_1ListAppImageConfigsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListAppsCommand = async ( +export const deserializeAws_json1_1ListLabelingJobsForWorkteamCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListAppsCommandError(output, context); + return deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListAppsResponse(data, context); - const response: ListAppsCommandOutput = { + contents = deserializeAws_json1_1ListLabelingJobsForWorkteamResponse(data, context); + const response: ListLabelingJobsForWorkteamCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListAppsCommandError = async ( +const deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7800,6 +11289,14 @@ const deserializeAws_json1_1ListAppsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7817,27 +11314,27 @@ const deserializeAws_json1_1ListAppsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListAutoMLJobsCommand = async ( +export const deserializeAws_json1_1ListModelPackageGroupsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListAutoMLJobsCommandError(output, context); + return deserializeAws_json1_1ListModelPackageGroupsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListAutoMLJobsResponse(data, context); - const response: ListAutoMLJobsCommandOutput = { + contents = deserializeAws_json1_1ListModelPackageGroupsOutput(data, context); + const response: ListModelPackageGroupsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListAutoMLJobsCommandError = async ( +const deserializeAws_json1_1ListModelPackageGroupsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7864,27 +11361,27 @@ const deserializeAws_json1_1ListAutoMLJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListCandidatesForAutoMLJobCommand = async ( +export const deserializeAws_json1_1ListModelPackagesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError(output, context); + return deserializeAws_json1_1ListModelPackagesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListCandidatesForAutoMLJobResponse(data, context); - const response: ListCandidatesForAutoMLJobCommandOutput = { + contents = deserializeAws_json1_1ListModelPackagesOutput(data, context); + const response: ListModelPackagesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError = async ( +const deserializeAws_json1_1ListModelPackagesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7894,14 +11391,6 @@ const deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -7919,27 +11408,27 @@ const deserializeAws_json1_1ListCandidatesForAutoMLJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListCodeRepositoriesCommand = async ( +export const deserializeAws_json1_1ListModelsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListCodeRepositoriesCommandError(output, context); + return deserializeAws_json1_1ListModelsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListCodeRepositoriesOutput(data, context); - const response: ListCodeRepositoriesCommandOutput = { + contents = deserializeAws_json1_1ListModelsOutput(data, context); + const response: ListModelsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListCodeRepositoriesCommandError = async ( +const deserializeAws_json1_1ListModelsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -7966,27 +11455,27 @@ const deserializeAws_json1_1ListCodeRepositoriesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListCompilationJobsCommand = async ( +export const deserializeAws_json1_1ListMonitoringExecutionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListCompilationJobsCommandError(output, context); + return deserializeAws_json1_1ListMonitoringExecutionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListCompilationJobsResponse(data, context); - const response: ListCompilationJobsCommandOutput = { + contents = deserializeAws_json1_1ListMonitoringExecutionsResponse(data, context); + const response: ListMonitoringExecutionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListCompilationJobsCommandError = async ( +const deserializeAws_json1_1ListMonitoringExecutionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8013,27 +11502,27 @@ const deserializeAws_json1_1ListCompilationJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListDomainsCommand = async ( +export const deserializeAws_json1_1ListMonitoringSchedulesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListDomainsCommandError(output, context); + return deserializeAws_json1_1ListMonitoringSchedulesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListDomainsResponse(data, context); - const response: ListDomainsCommandOutput = { + contents = deserializeAws_json1_1ListMonitoringSchedulesResponse(data, context); + const response: ListMonitoringSchedulesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListDomainsCommandError = async ( +const deserializeAws_json1_1ListMonitoringSchedulesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8060,27 +11549,27 @@ const deserializeAws_json1_1ListDomainsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListEndpointConfigsCommand = async ( +export const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListEndpointConfigsCommandError(output, context); + return deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListEndpointConfigsOutput(data, context); - const response: ListEndpointConfigsCommandOutput = { + contents = deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsOutput(data, context); + const response: ListNotebookInstanceLifecycleConfigsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListEndpointConfigsCommandError = async ( +const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8107,27 +11596,27 @@ const deserializeAws_json1_1ListEndpointConfigsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListEndpointsCommand = async ( +export const deserializeAws_json1_1ListNotebookInstancesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListEndpointsCommandError(output, context); + return deserializeAws_json1_1ListNotebookInstancesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListEndpointsOutput(data, context); - const response: ListEndpointsCommandOutput = { + contents = deserializeAws_json1_1ListNotebookInstancesOutput(data, context); + const response: ListNotebookInstancesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListEndpointsCommandError = async ( +const deserializeAws_json1_1ListNotebookInstancesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8154,27 +11643,27 @@ const deserializeAws_json1_1ListEndpointsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListExperimentsCommand = async ( +export const deserializeAws_json1_1ListPipelineExecutionsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListExperimentsCommandError(output, context); + return deserializeAws_json1_1ListPipelineExecutionsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListExperimentsResponse(data, context); - const response: ListExperimentsCommandOutput = { + contents = deserializeAws_json1_1ListPipelineExecutionsResponse(data, context); + const response: ListPipelineExecutionsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListExperimentsCommandError = async ( +const deserializeAws_json1_1ListPipelineExecutionsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8184,6 +11673,14 @@ const deserializeAws_json1_1ListExperimentsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8201,27 +11698,27 @@ const deserializeAws_json1_1ListExperimentsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListFlowDefinitionsCommand = async ( +export const deserializeAws_json1_1ListPipelineExecutionStepsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListFlowDefinitionsCommandError(output, context); + return deserializeAws_json1_1ListPipelineExecutionStepsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListFlowDefinitionsResponse(data, context); - const response: ListFlowDefinitionsCommandOutput = { + contents = deserializeAws_json1_1ListPipelineExecutionStepsResponse(data, context); + const response: ListPipelineExecutionStepsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListFlowDefinitionsCommandError = async ( +const deserializeAws_json1_1ListPipelineExecutionStepsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8231,6 +11728,14 @@ const deserializeAws_json1_1ListFlowDefinitionsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8248,27 +11753,27 @@ const deserializeAws_json1_1ListFlowDefinitionsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListHumanTaskUisCommand = async ( +export const deserializeAws_json1_1ListPipelineParametersForExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListHumanTaskUisCommandError(output, context); + return deserializeAws_json1_1ListPipelineParametersForExecutionCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListHumanTaskUisResponse(data, context); - const response: ListHumanTaskUisCommandOutput = { + contents = deserializeAws_json1_1ListPipelineParametersForExecutionResponse(data, context); + const response: ListPipelineParametersForExecutionCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListHumanTaskUisCommandError = async ( +const deserializeAws_json1_1ListPipelineParametersForExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8278,6 +11783,14 @@ const deserializeAws_json1_1ListHumanTaskUisCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8295,27 +11808,27 @@ const deserializeAws_json1_1ListHumanTaskUisCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListHyperParameterTuningJobsCommand = async ( +export const deserializeAws_json1_1ListPipelinesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListHyperParameterTuningJobsCommandError(output, context); + return deserializeAws_json1_1ListPipelinesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListHyperParameterTuningJobsResponse(data, context); - const response: ListHyperParameterTuningJobsCommandOutput = { + contents = deserializeAws_json1_1ListPipelinesResponse(data, context); + const response: ListPipelinesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListHyperParameterTuningJobsCommandError = async ( +const deserializeAws_json1_1ListPipelinesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8342,27 +11855,27 @@ const deserializeAws_json1_1ListHyperParameterTuningJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListImagesCommand = async ( +export const deserializeAws_json1_1ListProcessingJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListImagesCommandError(output, context); + return deserializeAws_json1_1ListProcessingJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListImagesResponse(data, context); - const response: ListImagesCommandOutput = { + contents = deserializeAws_json1_1ListProcessingJobsResponse(data, context); + const response: ListProcessingJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListImagesCommandError = async ( +const deserializeAws_json1_1ListProcessingJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8389,27 +11902,27 @@ const deserializeAws_json1_1ListImagesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListImageVersionsCommand = async ( +export const deserializeAws_json1_1ListProjectsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListImageVersionsCommandError(output, context); + return deserializeAws_json1_1ListProjectsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListImageVersionsResponse(data, context); - const response: ListImageVersionsCommandOutput = { + contents = deserializeAws_json1_1ListProjectsOutput(data, context); + const response: ListProjectsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListImageVersionsCommandError = async ( +const deserializeAws_json1_1ListProjectsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8419,14 +11932,6 @@ const deserializeAws_json1_1ListImageVersionsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8444,27 +11949,27 @@ const deserializeAws_json1_1ListImageVersionsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListLabelingJobsCommand = async ( +export const deserializeAws_json1_1ListSubscribedWorkteamsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListLabelingJobsCommandError(output, context); + return deserializeAws_json1_1ListSubscribedWorkteamsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListLabelingJobsResponse(data, context); - const response: ListLabelingJobsCommandOutput = { + contents = deserializeAws_json1_1ListSubscribedWorkteamsResponse(data, context); + const response: ListSubscribedWorkteamsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListLabelingJobsCommandError = async ( +const deserializeAws_json1_1ListSubscribedWorkteamsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8491,27 +11996,27 @@ const deserializeAws_json1_1ListLabelingJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListLabelingJobsForWorkteamCommand = async ( +export const deserializeAws_json1_1ListTagsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError(output, context); + return deserializeAws_json1_1ListTagsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListLabelingJobsForWorkteamResponse(data, context); - const response: ListLabelingJobsForWorkteamCommandOutput = { + contents = deserializeAws_json1_1ListTagsOutput(data, context); + const response: ListTagsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError = async ( +const deserializeAws_json1_1ListTagsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8521,14 +12026,6 @@ const deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8546,27 +12043,27 @@ const deserializeAws_json1_1ListLabelingJobsForWorkteamCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListModelPackagesCommand = async ( +export const deserializeAws_json1_1ListTrainingJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListModelPackagesCommandError(output, context); + return deserializeAws_json1_1ListTrainingJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListModelPackagesOutput(data, context); - const response: ListModelPackagesCommandOutput = { + contents = deserializeAws_json1_1ListTrainingJobsResponse(data, context); + const response: ListTrainingJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListModelPackagesCommandError = async ( +const deserializeAws_json1_1ListTrainingJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8593,27 +12090,27 @@ const deserializeAws_json1_1ListModelPackagesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListModelsCommand = async ( +export const deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListModelsCommandError(output, context); + return deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListModelsOutput(data, context); - const response: ListModelsCommandOutput = { + contents = deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobResponse(data, context); + const response: ListTrainingJobsForHyperParameterTuningJobCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListModelsCommandError = async ( +const deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8623,6 +12120,14 @@ const deserializeAws_json1_1ListModelsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8640,27 +12145,27 @@ const deserializeAws_json1_1ListModelsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListMonitoringExecutionsCommand = async ( +export const deserializeAws_json1_1ListTransformJobsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListMonitoringExecutionsCommandError(output, context); + return deserializeAws_json1_1ListTransformJobsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListMonitoringExecutionsResponse(data, context); - const response: ListMonitoringExecutionsCommandOutput = { + contents = deserializeAws_json1_1ListTransformJobsResponse(data, context); + const response: ListTransformJobsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListMonitoringExecutionsCommandError = async ( +const deserializeAws_json1_1ListTransformJobsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8687,27 +12192,27 @@ const deserializeAws_json1_1ListMonitoringExecutionsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListMonitoringSchedulesCommand = async ( +export const deserializeAws_json1_1ListTrialComponentsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListMonitoringSchedulesCommandError(output, context); + return deserializeAws_json1_1ListTrialComponentsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListMonitoringSchedulesResponse(data, context); - const response: ListMonitoringSchedulesCommandOutput = { + contents = deserializeAws_json1_1ListTrialComponentsResponse(data, context); + const response: ListTrialComponentsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListMonitoringSchedulesCommandError = async ( +const deserializeAws_json1_1ListTrialComponentsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8717,6 +12222,14 @@ const deserializeAws_json1_1ListMonitoringSchedulesCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8734,27 +12247,27 @@ const deserializeAws_json1_1ListMonitoringSchedulesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommand = async ( +export const deserializeAws_json1_1ListTrialsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError(output, context); + return deserializeAws_json1_1ListTrialsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsOutput(data, context); - const response: ListNotebookInstanceLifecycleConfigsCommandOutput = { + contents = deserializeAws_json1_1ListTrialsResponse(data, context); + const response: ListTrialsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError = async ( +const deserializeAws_json1_1ListTrialsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8764,6 +12277,14 @@ const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError = a const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -8781,27 +12302,27 @@ const deserializeAws_json1_1ListNotebookInstanceLifecycleConfigsCommandError = a return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListNotebookInstancesCommand = async ( +export const deserializeAws_json1_1ListUserProfilesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListNotebookInstancesCommandError(output, context); + return deserializeAws_json1_1ListUserProfilesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListNotebookInstancesOutput(data, context); - const response: ListNotebookInstancesCommandOutput = { + contents = deserializeAws_json1_1ListUserProfilesResponse(data, context); + const response: ListUserProfilesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListNotebookInstancesCommandError = async ( +const deserializeAws_json1_1ListUserProfilesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8828,27 +12349,27 @@ const deserializeAws_json1_1ListNotebookInstancesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListProcessingJobsCommand = async ( +export const deserializeAws_json1_1ListWorkforcesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListProcessingJobsCommandError(output, context); + return deserializeAws_json1_1ListWorkforcesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListProcessingJobsResponse(data, context); - const response: ListProcessingJobsCommandOutput = { + contents = deserializeAws_json1_1ListWorkforcesResponse(data, context); + const response: ListWorkforcesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListProcessingJobsCommandError = async ( +const deserializeAws_json1_1ListWorkforcesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8875,27 +12396,27 @@ const deserializeAws_json1_1ListProcessingJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListSubscribedWorkteamsCommand = async ( +export const deserializeAws_json1_1ListWorkteamsCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListSubscribedWorkteamsCommandError(output, context); + return deserializeAws_json1_1ListWorkteamsCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListSubscribedWorkteamsResponse(data, context); - const response: ListSubscribedWorkteamsCommandOutput = { + contents = deserializeAws_json1_1ListWorkteamsResponse(data, context); + const response: ListWorkteamsCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListSubscribedWorkteamsCommandError = async ( +const deserializeAws_json1_1ListWorkteamsCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8922,27 +12443,27 @@ const deserializeAws_json1_1ListSubscribedWorkteamsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTagsCommand = async ( +export const deserializeAws_json1_1PutModelPackageGroupPolicyCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTagsCommandError(output, context); + return deserializeAws_json1_1PutModelPackageGroupPolicyCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListTagsOutput(data, context); - const response: ListTagsCommandOutput = { + contents = deserializeAws_json1_1PutModelPackageGroupPolicyOutput(data, context); + const response: PutModelPackageGroupPolicyCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTagsCommandError = async ( +const deserializeAws_json1_1PutModelPackageGroupPolicyCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8969,27 +12490,27 @@ const deserializeAws_json1_1ListTagsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTrainingJobsCommand = async ( +export const deserializeAws_json1_1RenderUiTemplateCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTrainingJobsCommandError(output, context); + return deserializeAws_json1_1RenderUiTemplateCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListTrainingJobsResponse(data, context); - const response: ListTrainingJobsCommandOutput = { + contents = deserializeAws_json1_1RenderUiTemplateResponse(data, context); + const response: RenderUiTemplateCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTrainingJobsCommandError = async ( +const deserializeAws_json1_1RenderUiTemplateCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -8999,6 +12520,14 @@ const deserializeAws_json1_1ListTrainingJobsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9016,44 +12545,36 @@ const deserializeAws_json1_1ListTrainingJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommand = async ( +export const deserializeAws_json1_1SearchCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommandError(output, context); + return deserializeAws_json1_1SearchCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobResponse(data, context); - const response: ListTrainingJobsForHyperParameterTuningJobCommandOutput = { + contents = deserializeAws_json1_1SearchResponse(data, context); + const response: SearchCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommandError = async ( +const deserializeAws_json1_1SearchCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), }; let response: __SmithyException & __MetadataBearer & { [key: string]: any }; - let errorCode: string = "UnknownError"; - const errorTypeParts: String = parsedOutput.body["__type"].split("#"); - errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; - switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9071,27 +12592,24 @@ const deserializeAws_json1_1ListTrainingJobsForHyperParameterTuningJobCommandErr return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTransformJobsCommand = async ( +export const deserializeAws_json1_1StartMonitoringScheduleCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTransformJobsCommandError(output, context); + return deserializeAws_json1_1StartMonitoringScheduleCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1ListTransformJobsResponse(data, context); - const response: ListTransformJobsCommandOutput = { + await collectBody(output.body, context); + const response: StartMonitoringScheduleCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTransformJobsCommandError = async ( +const deserializeAws_json1_1StartMonitoringScheduleCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9101,6 +12619,14 @@ const deserializeAws_json1_1ListTransformJobsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9118,27 +12644,24 @@ const deserializeAws_json1_1ListTransformJobsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTrialComponentsCommand = async ( +export const deserializeAws_json1_1StartNotebookInstanceCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTrialComponentsCommandError(output, context); + return deserializeAws_json1_1StartNotebookInstanceCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1ListTrialComponentsResponse(data, context); - const response: ListTrialComponentsCommandOutput = { + await collectBody(output.body, context); + const response: StartNotebookInstanceCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTrialComponentsCommandError = async ( +const deserializeAws_json1_1StartNotebookInstanceCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9148,10 +12671,10 @@ const deserializeAws_json1_1ListTrialComponentsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -9173,27 +12696,27 @@ const deserializeAws_json1_1ListTrialComponentsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListTrialsCommand = async ( +export const deserializeAws_json1_1StartPipelineExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListTrialsCommandError(output, context); + return deserializeAws_json1_1StartPipelineExecutionCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1ListTrialsResponse(data, context); - const response: ListTrialsCommandOutput = { + contents = deserializeAws_json1_1StartPipelineExecutionResponse(data, context); + const response: StartPipelineExecutionCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListTrialsCommandError = async ( +const deserializeAws_json1_1StartPipelineExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9203,6 +12726,14 @@ const deserializeAws_json1_1ListTrialsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -9228,27 +12759,24 @@ const deserializeAws_json1_1ListTrialsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListUserProfilesCommand = async ( +export const deserializeAws_json1_1StopAutoMLJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListUserProfilesCommandError(output, context); + return deserializeAws_json1_1StopAutoMLJobCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1ListUserProfilesResponse(data, context); - const response: ListUserProfilesCommandOutput = { + await collectBody(output.body, context); + const response: StopAutoMLJobCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListUserProfilesCommandError = async ( +const deserializeAws_json1_1StopAutoMLJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9258,6 +12786,14 @@ const deserializeAws_json1_1ListUserProfilesCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9275,27 +12811,24 @@ const deserializeAws_json1_1ListUserProfilesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListWorkforcesCommand = async ( +export const deserializeAws_json1_1StopCompilationJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListWorkforcesCommandError(output, context); + return deserializeAws_json1_1StopCompilationJobCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1ListWorkforcesResponse(data, context); - const response: ListWorkforcesCommandOutput = { + await collectBody(output.body, context); + const response: StopCompilationJobCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListWorkforcesCommandError = async ( +const deserializeAws_json1_1StopCompilationJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9305,6 +12838,14 @@ const deserializeAws_json1_1ListWorkforcesCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9322,27 +12863,24 @@ const deserializeAws_json1_1ListWorkforcesCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1ListWorkteamsCommand = async ( +export const deserializeAws_json1_1StopHyperParameterTuningJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1ListWorkteamsCommandError(output, context); + return deserializeAws_json1_1StopHyperParameterTuningJobCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1ListWorkteamsResponse(data, context); - const response: ListWorkteamsCommandOutput = { + await collectBody(output.body, context); + const response: StopHyperParameterTuningJobCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1ListWorkteamsCommandError = async ( +const deserializeAws_json1_1StopHyperParameterTuningJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9352,6 +12890,14 @@ const deserializeAws_json1_1ListWorkteamsCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9369,27 +12915,24 @@ const deserializeAws_json1_1ListWorkteamsCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1RenderUiTemplateCommand = async ( +export const deserializeAws_json1_1StopLabelingJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1RenderUiTemplateCommandError(output, context); + return deserializeAws_json1_1StopLabelingJobCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1RenderUiTemplateResponse(data, context); - const response: RenderUiTemplateCommandOutput = { + await collectBody(output.body, context); + const response: StopLabelingJobCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1RenderUiTemplateCommandError = async ( +const deserializeAws_json1_1StopLabelingJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9424,27 +12967,24 @@ const deserializeAws_json1_1RenderUiTemplateCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1SearchCommand = async ( +export const deserializeAws_json1_1StopMonitoringScheduleCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1SearchCommandError(output, context); + return deserializeAws_json1_1StopMonitoringScheduleCommandError(output, context); } - const data: any = await parseBody(output.body, context); - let contents: any = {}; - contents = deserializeAws_json1_1SearchResponse(data, context); - const response: SearchCommandOutput = { + await collectBody(output.body, context); + const response: StopMonitoringScheduleCommandOutput = { $metadata: deserializeMetadata(output), - ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1SearchCommandError = async ( +const deserializeAws_json1_1StopMonitoringScheduleCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9454,6 +12994,14 @@ const deserializeAws_json1_1SearchCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9471,24 +13019,24 @@ const deserializeAws_json1_1SearchCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StartMonitoringScheduleCommand = async ( +export const deserializeAws_json1_1StopNotebookInstanceCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StartMonitoringScheduleCommandError(output, context); + return deserializeAws_json1_1StopNotebookInstanceCommandError(output, context); } await collectBody(output.body, context); - const response: StartMonitoringScheduleCommandOutput = { + const response: StopNotebookInstanceCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1StartMonitoringScheduleCommandError = async ( +const deserializeAws_json1_1StopNotebookInstanceCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9498,14 +13046,6 @@ const deserializeAws_json1_1StartMonitoringScheduleCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9523,24 +13063,27 @@ const deserializeAws_json1_1StartMonitoringScheduleCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StartNotebookInstanceCommand = async ( +export const deserializeAws_json1_1StopPipelineExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StartNotebookInstanceCommandError(output, context); + return deserializeAws_json1_1StopPipelineExecutionCommandError(output, context); } - await collectBody(output.body, context); - const response: StartNotebookInstanceCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1StopPipelineExecutionResponse(data, context); + const response: StopPipelineExecutionCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StartNotebookInstanceCommandError = async ( +const deserializeAws_json1_1StopPipelineExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9550,10 +13093,10 @@ const deserializeAws_json1_1StartNotebookInstanceCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -9575,24 +13118,24 @@ const deserializeAws_json1_1StartNotebookInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopAutoMLJobCommand = async ( +export const deserializeAws_json1_1StopProcessingJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopAutoMLJobCommandError(output, context); + return deserializeAws_json1_1StopProcessingJobCommandError(output, context); } await collectBody(output.body, context); - const response: StopAutoMLJobCommandOutput = { + const response: StopProcessingJobCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopAutoMLJobCommandError = async ( +const deserializeAws_json1_1StopProcessingJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9627,24 +13170,24 @@ const deserializeAws_json1_1StopAutoMLJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopCompilationJobCommand = async ( +export const deserializeAws_json1_1StopTrainingJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopCompilationJobCommandError(output, context); + return deserializeAws_json1_1StopTrainingJobCommandError(output, context); } await collectBody(output.body, context); - const response: StopCompilationJobCommandOutput = { + const response: StopTrainingJobCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopCompilationJobCommandError = async ( +const deserializeAws_json1_1StopTrainingJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9679,24 +13222,24 @@ const deserializeAws_json1_1StopCompilationJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopHyperParameterTuningJobCommand = async ( +export const deserializeAws_json1_1StopTransformJobCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopHyperParameterTuningJobCommandError(output, context); + return deserializeAws_json1_1StopTransformJobCommandError(output, context); } await collectBody(output.body, context); - const response: StopHyperParameterTuningJobCommandOutput = { + const response: StopTransformJobCommandOutput = { $metadata: deserializeMetadata(output), }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopHyperParameterTuningJobCommandError = async ( +const deserializeAws_json1_1StopTransformJobCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9731,24 +13274,27 @@ const deserializeAws_json1_1StopHyperParameterTuningJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopLabelingJobCommand = async ( +export const deserializeAws_json1_1UpdateActionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopLabelingJobCommandError(output, context); + return deserializeAws_json1_1UpdateActionCommandError(output, context); } - await collectBody(output.body, context); - const response: StopLabelingJobCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateActionResponse(data, context); + const response: UpdateActionCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopLabelingJobCommandError = async ( +const deserializeAws_json1_1UpdateActionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9758,6 +13304,14 @@ const deserializeAws_json1_1StopLabelingJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ConflictException": + case "com.amazonaws.sagemaker#ConflictException": + response = { + ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -9783,24 +13337,27 @@ const deserializeAws_json1_1StopLabelingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopMonitoringScheduleCommand = async ( +export const deserializeAws_json1_1UpdateAppImageConfigCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopMonitoringScheduleCommandError(output, context); + return deserializeAws_json1_1UpdateAppImageConfigCommandError(output, context); } - await collectBody(output.body, context); - const response: StopMonitoringScheduleCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateAppImageConfigResponse(data, context); + const response: UpdateAppImageConfigCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopMonitoringScheduleCommandError = async ( +const deserializeAws_json1_1UpdateAppImageConfigCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9835,24 +13392,27 @@ const deserializeAws_json1_1StopMonitoringScheduleCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopNotebookInstanceCommand = async ( +export const deserializeAws_json1_1UpdateArtifactCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopNotebookInstanceCommandError(output, context); + return deserializeAws_json1_1UpdateArtifactCommandError(output, context); } - await collectBody(output.body, context); - const response: StopNotebookInstanceCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateArtifactResponse(data, context); + const response: UpdateArtifactCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopNotebookInstanceCommandError = async ( +const deserializeAws_json1_1UpdateArtifactCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9862,6 +13422,22 @@ const deserializeAws_json1_1StopNotebookInstanceCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ConflictException": + case "com.amazonaws.sagemaker#ConflictException": + response = { + ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9879,24 +13455,27 @@ const deserializeAws_json1_1StopNotebookInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopProcessingJobCommand = async ( +export const deserializeAws_json1_1UpdateCodeRepositoryCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopProcessingJobCommandError(output, context); + return deserializeAws_json1_1UpdateCodeRepositoryCommandError(output, context); } - await collectBody(output.body, context); - const response: StopProcessingJobCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateCodeRepositoryOutput(data, context); + const response: UpdateCodeRepositoryCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopProcessingJobCommandError = async ( +const deserializeAws_json1_1UpdateCodeRepositoryCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9906,14 +13485,6 @@ const deserializeAws_json1_1StopProcessingJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -9931,24 +13502,27 @@ const deserializeAws_json1_1StopProcessingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopTrainingJobCommand = async ( +export const deserializeAws_json1_1UpdateContextCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopTrainingJobCommandError(output, context); + return deserializeAws_json1_1UpdateContextCommandError(output, context); } - await collectBody(output.body, context); - const response: StopTrainingJobCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateContextResponse(data, context); + const response: UpdateContextCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopTrainingJobCommandError = async ( +const deserializeAws_json1_1UpdateContextCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -9958,6 +13532,14 @@ const deserializeAws_json1_1StopTrainingJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ConflictException": + case "com.amazonaws.sagemaker#ConflictException": + response = { + ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -9983,24 +13565,27 @@ const deserializeAws_json1_1StopTrainingJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1StopTransformJobCommand = async ( +export const deserializeAws_json1_1UpdateDomainCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1StopTransformJobCommandError(output, context); + return deserializeAws_json1_1UpdateDomainCommandError(output, context); } - await collectBody(output.body, context); - const response: StopTransformJobCommandOutput = { + const data: any = await parseBody(output.body, context); + let contents: any = {}; + contents = deserializeAws_json1_1UpdateDomainResponse(data, context); + const response: UpdateDomainCommandOutput = { $metadata: deserializeMetadata(output), + ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1StopTransformJobCommandError = async ( +const deserializeAws_json1_1UpdateDomainCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10010,6 +13595,22 @@ const deserializeAws_json1_1StopTransformJobCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": + response = { + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; case "ResourceNotFound": case "com.amazonaws.sagemaker#ResourceNotFound": response = { @@ -10035,27 +13636,27 @@ const deserializeAws_json1_1StopTransformJobCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateAppImageConfigCommand = async ( +export const deserializeAws_json1_1UpdateEndpointCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateAppImageConfigCommandError(output, context); + return deserializeAws_json1_1UpdateEndpointCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateAppImageConfigResponse(data, context); - const response: UpdateAppImageConfigCommandOutput = { + contents = deserializeAws_json1_1UpdateEndpointOutput(data, context); + const response: UpdateEndpointCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateAppImageConfigCommandError = async ( +const deserializeAws_json1_1UpdateEndpointCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10065,10 +13666,10 @@ const deserializeAws_json1_1UpdateAppImageConfigCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10090,27 +13691,27 @@ const deserializeAws_json1_1UpdateAppImageConfigCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateCodeRepositoryCommand = async ( +export const deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateCodeRepositoryCommandError(output, context); + return deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateCodeRepositoryOutput(data, context); - const response: UpdateCodeRepositoryCommandOutput = { + contents = deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesOutput(data, context); + const response: UpdateEndpointWeightsAndCapacitiesCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateCodeRepositoryCommandError = async ( +const deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10120,6 +13721,14 @@ const deserializeAws_json1_1UpdateCodeRepositoryCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": + response = { + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -10137,27 +13746,27 @@ const deserializeAws_json1_1UpdateCodeRepositoryCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateDomainCommand = async ( +export const deserializeAws_json1_1UpdateExperimentCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateDomainCommandError(output, context); + return deserializeAws_json1_1UpdateExperimentCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateDomainResponse(data, context); - const response: UpdateDomainCommandOutput = { + contents = deserializeAws_json1_1UpdateExperimentResponse(data, context); + const response: UpdateExperimentCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateDomainCommandError = async ( +const deserializeAws_json1_1UpdateExperimentCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10167,18 +13776,10 @@ const deserializeAws_json1_1UpdateDomainCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ConflictException": + case "com.amazonaws.sagemaker#ConflictException": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10208,27 +13809,27 @@ const deserializeAws_json1_1UpdateDomainCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateEndpointCommand = async ( +export const deserializeAws_json1_1UpdateImageCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateEndpointCommandError(output, context); + return deserializeAws_json1_1UpdateImageCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateEndpointOutput(data, context); - const response: UpdateEndpointCommandOutput = { + contents = deserializeAws_json1_1UpdateImageResponse(data, context); + const response: UpdateImageCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateEndpointCommandError = async ( +const deserializeAws_json1_1UpdateImageCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10238,10 +13839,18 @@ const deserializeAws_json1_1UpdateEndpointCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ResourceInUse": + case "com.amazonaws.sagemaker#ResourceInUse": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), + name: errorCode, + $metadata: deserializeMetadata(output), + }; + break; + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": + response = { + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10263,44 +13872,36 @@ const deserializeAws_json1_1UpdateEndpointCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommand = async ( +export const deserializeAws_json1_1UpdateModelPackageCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommandError(output, context); + return deserializeAws_json1_1UpdateModelPackageCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesOutput(data, context); - const response: UpdateEndpointWeightsAndCapacitiesCommandOutput = { + contents = deserializeAws_json1_1UpdateModelPackageOutput(data, context); + const response: UpdateModelPackageCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommandError = async ( +const deserializeAws_json1_1UpdateModelPackageCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), - }; - let response: __SmithyException & __MetadataBearer & { [key: string]: any }; - let errorCode: string = "UnknownError"; - const errorTypeParts: String = parsedOutput.body["__type"].split("#"); - errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; - switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": - response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; + }; + let response: __SmithyException & __MetadataBearer & { [key: string]: any }; + let errorCode: string = "UnknownError"; + const errorTypeParts: String = parsedOutput.body["__type"].split("#"); + errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; + switch (errorCode) { default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -10318,27 +13919,27 @@ const deserializeAws_json1_1UpdateEndpointWeightsAndCapacitiesCommandError = asy return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateExperimentCommand = async ( +export const deserializeAws_json1_1UpdateMonitoringScheduleCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateExperimentCommandError(output, context); + return deserializeAws_json1_1UpdateMonitoringScheduleCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateExperimentResponse(data, context); - const response: UpdateExperimentCommandOutput = { + contents = deserializeAws_json1_1UpdateMonitoringScheduleResponse(data, context); + const response: UpdateMonitoringScheduleCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateExperimentCommandError = async ( +const deserializeAws_json1_1UpdateMonitoringScheduleCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10348,10 +13949,10 @@ const deserializeAws_json1_1UpdateExperimentCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ConflictException": - case "com.amazonaws.sagemaker#ConflictException": + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": response = { - ...(await deserializeAws_json1_1ConflictExceptionResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10381,27 +13982,27 @@ const deserializeAws_json1_1UpdateExperimentCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateImageCommand = async ( +export const deserializeAws_json1_1UpdateNotebookInstanceCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateImageCommandError(output, context); + return deserializeAws_json1_1UpdateNotebookInstanceCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateImageResponse(data, context); - const response: UpdateImageCommandOutput = { + contents = deserializeAws_json1_1UpdateNotebookInstanceOutput(data, context); + const response: UpdateNotebookInstanceCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateImageCommandError = async ( +const deserializeAws_json1_1UpdateNotebookInstanceCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10411,18 +14012,10 @@ const deserializeAws_json1_1UpdateImageCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceInUse": - case "com.amazonaws.sagemaker#ResourceInUse": - response = { - ...(await deserializeAws_json1_1ResourceInUseResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": + case "ResourceLimitExceeded": + case "com.amazonaws.sagemaker#ResourceLimitExceeded": response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10444,27 +14037,27 @@ const deserializeAws_json1_1UpdateImageCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateMonitoringScheduleCommand = async ( +export const deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateMonitoringScheduleCommandError(output, context); + return deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateMonitoringScheduleResponse(data, context); - const response: UpdateMonitoringScheduleCommandOutput = { + contents = deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigOutput(data, context); + const response: UpdateNotebookInstanceLifecycleConfigCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateMonitoringScheduleCommandError = async ( +const deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10482,14 +14075,6 @@ const deserializeAws_json1_1UpdateMonitoringScheduleCommandError = async ( $metadata: deserializeMetadata(output), }; break; - case "ResourceNotFound": - case "com.amazonaws.sagemaker#ResourceNotFound": - response = { - ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), - name: errorCode, - $metadata: deserializeMetadata(output), - }; - break; default: const parsedBody = parsedOutput.body; errorCode = parsedBody.code || parsedBody.Code || errorCode; @@ -10507,27 +14092,27 @@ const deserializeAws_json1_1UpdateMonitoringScheduleCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateNotebookInstanceCommand = async ( +export const deserializeAws_json1_1UpdatePipelineCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateNotebookInstanceCommandError(output, context); + return deserializeAws_json1_1UpdatePipelineCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateNotebookInstanceOutput(data, context); - const response: UpdateNotebookInstanceCommandOutput = { + contents = deserializeAws_json1_1UpdatePipelineResponse(data, context); + const response: UpdatePipelineCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateNotebookInstanceCommandError = async ( +const deserializeAws_json1_1UpdatePipelineCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10537,10 +14122,10 @@ const deserializeAws_json1_1UpdateNotebookInstanceCommandError = async ( const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10562,27 +14147,27 @@ const deserializeAws_json1_1UpdateNotebookInstanceCommandError = async ( return Promise.reject(Object.assign(new Error(message), response)); }; -export const deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommand = async ( +export const deserializeAws_json1_1UpdatePipelineExecutionCommand = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { if (output.statusCode >= 300) { - return deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommandError(output, context); + return deserializeAws_json1_1UpdatePipelineExecutionCommandError(output, context); } const data: any = await parseBody(output.body, context); let contents: any = {}; - contents = deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigOutput(data, context); - const response: UpdateNotebookInstanceLifecycleConfigCommandOutput = { + contents = deserializeAws_json1_1UpdatePipelineExecutionResponse(data, context); + const response: UpdatePipelineExecutionCommandOutput = { $metadata: deserializeMetadata(output), ...contents, }; return Promise.resolve(response); }; -const deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommandError = async ( +const deserializeAws_json1_1UpdatePipelineExecutionCommandError = async ( output: __HttpResponse, context: __SerdeContext -): Promise => { +): Promise => { const parsedOutput: any = { ...output, body: await parseBody(output.body, context), @@ -10592,10 +14177,10 @@ const deserializeAws_json1_1UpdateNotebookInstanceLifecycleConfigCommandError = const errorTypeParts: String = parsedOutput.body["__type"].split("#"); errorCode = errorTypeParts[1] === undefined ? errorTypeParts[0] : errorTypeParts[1]; switch (errorCode) { - case "ResourceLimitExceeded": - case "com.amazonaws.sagemaker#ResourceLimitExceeded": + case "ResourceNotFound": + case "com.amazonaws.sagemaker#ResourceNotFound": response = { - ...(await deserializeAws_json1_1ResourceLimitExceededResponse(parsedOutput, context)), + ...(await deserializeAws_json1_1ResourceNotFoundResponse(parsedOutput, context)), name: errorCode, $metadata: deserializeMetadata(output), }; @@ -10976,6 +14561,22 @@ const deserializeAws_json1_1ResourceNotFoundResponse = async ( return contents; }; +const serializeAws_json1_1ActionSource = (input: ActionSource, context: __SerdeContext): any => { + return { + ...(input.SourceId !== undefined && { SourceId: input.SourceId }), + ...(input.SourceType !== undefined && { SourceType: input.SourceType }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + +const serializeAws_json1_1AddAssociationRequest = (input: AddAssociationRequest, context: __SerdeContext): any => { + return { + ...(input.AssociationType !== undefined && { AssociationType: input.AssociationType }), + ...(input.DestinationArn !== undefined && { DestinationArn: input.DestinationArn }), + ...(input.SourceArn !== undefined && { SourceArn: input.SourceArn }), + }; +}; + const serializeAws_json1_1AdditionalCodeRepositoryNamesOrUrls = (input: string[], context: __SerdeContext): any => { return input.map((entry) => entry); }; @@ -10987,6 +14588,16 @@ const serializeAws_json1_1AddTagsInput = (input: AddTagsInput, context: __SerdeC }; }; +const serializeAws_json1_1Alarm = (input: Alarm, context: __SerdeContext): any => { + return { + ...(input.AlarmName !== undefined && { AlarmName: input.AlarmName }), + }; +}; + +const serializeAws_json1_1AlarmList = (input: Alarm[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1Alarm(entry, context)); +}; + const serializeAws_json1_1AlgorithmSpecification = (input: AlgorithmSpecification, context: __SerdeContext): any => { return { ...(input.AlgorithmName !== undefined && { AlgorithmName: input.AlgorithmName }), @@ -11058,6 +14669,26 @@ const serializeAws_json1_1AppSpecification = (input: AppSpecification, context: }; }; +const serializeAws_json1_1ArtifactSource = (input: ArtifactSource, context: __SerdeContext): any => { + return { + ...(input.SourceTypes !== undefined && { + SourceTypes: serializeAws_json1_1ArtifactSourceTypes(input.SourceTypes, context), + }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + +const serializeAws_json1_1ArtifactSourceType = (input: ArtifactSourceType, context: __SerdeContext): any => { + return { + ...(input.SourceIdType !== undefined && { SourceIdType: input.SourceIdType }), + ...(input.Value !== undefined && { Value: input.Value }), + }; +}; + +const serializeAws_json1_1ArtifactSourceTypes = (input: ArtifactSourceType[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1ArtifactSourceType(entry, context)); +}; + const serializeAws_json1_1AssociateTrialComponentRequest = ( input: AssociateTrialComponentRequest, context: __SerdeContext @@ -11068,6 +14699,19 @@ const serializeAws_json1_1AssociateTrialComponentRequest = ( }; }; +const serializeAws_json1_1AthenaDatasetDefinition = (input: AthenaDatasetDefinition, context: __SerdeContext): any => { + return { + ...(input.Catalog !== undefined && { Catalog: input.Catalog }), + ...(input.Database !== undefined && { Database: input.Database }), + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + ...(input.OutputCompression !== undefined && { OutputCompression: input.OutputCompression }), + ...(input.OutputFormat !== undefined && { OutputFormat: input.OutputFormat }), + ...(input.OutputS3Uri !== undefined && { OutputS3Uri: input.OutputS3Uri }), + ...(input.QueryString !== undefined && { QueryString: input.QueryString }), + ...(input.WorkGroup !== undefined && { WorkGroup: input.WorkGroup }), + }; +}; + const serializeAws_json1_1AttributeNames = (input: string[], context: __SerdeContext): any => { return input.map((entry) => entry); }; @@ -11150,6 +14794,37 @@ const serializeAws_json1_1AutoMLSecurityConfig = (input: AutoMLSecurityConfig, c }; }; +const serializeAws_json1_1AutoRollbackConfig = (input: AutoRollbackConfig, context: __SerdeContext): any => { + return { + ...(input.Alarms !== undefined && { Alarms: serializeAws_json1_1AlarmList(input.Alarms, context) }), + }; +}; + +const serializeAws_json1_1Bias = (input: Bias, context: __SerdeContext): any => { + return { + ...(input.Report !== undefined && { Report: serializeAws_json1_1MetricsSource(input.Report, context) }), + }; +}; + +const serializeAws_json1_1BlueGreenUpdatePolicy = (input: BlueGreenUpdatePolicy, context: __SerdeContext): any => { + return { + ...(input.MaximumExecutionTimeoutInSeconds !== undefined && { + MaximumExecutionTimeoutInSeconds: input.MaximumExecutionTimeoutInSeconds, + }), + ...(input.TerminationWaitInSeconds !== undefined && { TerminationWaitInSeconds: input.TerminationWaitInSeconds }), + ...(input.TrafficRoutingConfiguration !== undefined && { + TrafficRoutingConfiguration: serializeAws_json1_1TrafficRoutingConfig(input.TrafficRoutingConfiguration, context), + }), + }; +}; + +const serializeAws_json1_1CapacitySize = (input: CapacitySize, context: __SerdeContext): any => { + return { + ...(input.Type !== undefined && { Type: input.Type }), + ...(input.Value !== undefined && { Value: input.Value }), + }; +}; + const serializeAws_json1_1CaptureContentTypeHeader = ( input: CaptureContentTypeHeader, context: __SerdeContext @@ -11330,6 +15005,14 @@ const serializeAws_json1_1ContentTypes = (input: string[], context: __SerdeConte return input.map((entry) => entry); }; +const serializeAws_json1_1ContextSource = (input: ContextSource, context: __SerdeContext): any => { + return { + ...(input.SourceId !== undefined && { SourceId: input.SourceId }), + ...(input.SourceType !== undefined && { SourceType: input.SourceType }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + const serializeAws_json1_1ContinuousParameterRange = ( input: ContinuousParameterRange, context: __SerdeContext @@ -11359,6 +15042,23 @@ const serializeAws_json1_1ContinuousParameterRangeSpecification = ( }; }; +const serializeAws_json1_1CreateActionRequest = (input: CreateActionRequest, context: __SerdeContext): any => { + return { + ...(input.ActionName !== undefined && { ActionName: input.ActionName }), + ...(input.ActionType !== undefined && { ActionType: input.ActionType }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.MetadataProperties !== undefined && { + MetadataProperties: serializeAws_json1_1MetadataProperties(input.MetadataProperties, context), + }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.Source !== undefined && { Source: serializeAws_json1_1ActionSource(input.Source, context) }), + ...(input.Status !== undefined && { Status: input.Status }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateAlgorithmInput = (input: CreateAlgorithmInput, context: __SerdeContext): any => { return { ...(input.AlgorithmDescription !== undefined && { AlgorithmDescription: input.AlgorithmDescription }), @@ -11367,6 +15067,7 @@ const serializeAws_json1_1CreateAlgorithmInput = (input: CreateAlgorithmInput, c ...(input.InferenceSpecification !== undefined && { InferenceSpecification: serializeAws_json1_1InferenceSpecification(input.InferenceSpecification, context), }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), ...(input.TrainingSpecification !== undefined && { TrainingSpecification: serializeAws_json1_1TrainingSpecification(input.TrainingSpecification, context), }), @@ -11405,6 +15106,21 @@ const serializeAws_json1_1CreateAppRequest = (input: CreateAppRequest, context: }; }; +const serializeAws_json1_1CreateArtifactRequest = (input: CreateArtifactRequest, context: __SerdeContext): any => { + return { + ...(input.ArtifactName !== undefined && { ArtifactName: input.ArtifactName }), + ...(input.ArtifactType !== undefined && { ArtifactType: input.ArtifactType }), + ...(input.MetadataProperties !== undefined && { + MetadataProperties: serializeAws_json1_1MetadataProperties(input.MetadataProperties, context), + }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.Source !== undefined && { Source: serializeAws_json1_1ArtifactSource(input.Source, context) }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateAutoMLJobRequest = (input: CreateAutoMLJobRequest, context: __SerdeContext): any => { return { ...(input.AutoMLJobConfig !== undefined && { @@ -11436,6 +15152,7 @@ const serializeAws_json1_1CreateCodeRepositoryInput = ( return { ...(input.CodeRepositoryName !== undefined && { CodeRepositoryName: input.CodeRepositoryName }), ...(input.GitConfig !== undefined && { GitConfig: serializeAws_json1_1GitConfig(input.GitConfig, context) }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), }; }; @@ -11459,6 +15176,19 @@ const serializeAws_json1_1CreateCompilationJobRequest = ( }; }; +const serializeAws_json1_1CreateContextRequest = (input: CreateContextRequest, context: __SerdeContext): any => { + return { + ...(input.ContextName !== undefined && { ContextName: input.ContextName }), + ...(input.ContextType !== undefined && { ContextType: input.ContextType }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.Source !== undefined && { Source: serializeAws_json1_1ContextSource(input.Source, context) }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateDomainRequest = (input: CreateDomainRequest, context: __SerdeContext): any => { return { ...(input.AppNetworkAccessType !== undefined && { AppNetworkAccessType: input.AppNetworkAccessType }), @@ -11511,6 +15241,31 @@ const serializeAws_json1_1CreateExperimentRequest = (input: CreateExperimentRequ }; }; +const serializeAws_json1_1CreateFeatureGroupRequest = ( + input: CreateFeatureGroupRequest, + context: __SerdeContext +): any => { + return { + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.EventTimeFeatureName !== undefined && { EventTimeFeatureName: input.EventTimeFeatureName }), + ...(input.FeatureDefinitions !== undefined && { + FeatureDefinitions: serializeAws_json1_1FeatureDefinitions(input.FeatureDefinitions, context), + }), + ...(input.FeatureGroupName !== undefined && { FeatureGroupName: input.FeatureGroupName }), + ...(input.OfflineStoreConfig !== undefined && { + OfflineStoreConfig: serializeAws_json1_1OfflineStoreConfig(input.OfflineStoreConfig, context), + }), + ...(input.OnlineStoreConfig !== undefined && { + OnlineStoreConfig: serializeAws_json1_1OnlineStoreConfig(input.OnlineStoreConfig, context), + }), + ...(input.RecordIdentifierFeatureName !== undefined && { + RecordIdentifierFeatureName: input.RecordIdentifierFeatureName, + }), + ...(input.RoleArn !== undefined && { RoleArn: input.RoleArn }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateFlowDefinitionRequest = ( input: CreateFlowDefinitionRequest, context: __SerdeContext @@ -11649,13 +15404,35 @@ const serializeAws_json1_1CreateModelInput = (input: CreateModelInput, context: }; }; +const serializeAws_json1_1CreateModelPackageGroupInput = ( + input: CreateModelPackageGroupInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupDescription !== undefined && { + ModelPackageGroupDescription: input.ModelPackageGroupDescription, + }), + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateModelPackageInput = (input: CreateModelPackageInput, context: __SerdeContext): any => { return { ...(input.CertifyForMarketplace !== undefined && { CertifyForMarketplace: input.CertifyForMarketplace }), + ClientToken: input.ClientToken ?? generateIdempotencyToken(), ...(input.InferenceSpecification !== undefined && { InferenceSpecification: serializeAws_json1_1InferenceSpecification(input.InferenceSpecification, context), }), + ...(input.MetadataProperties !== undefined && { + MetadataProperties: serializeAws_json1_1MetadataProperties(input.MetadataProperties, context), + }), + ...(input.ModelApprovalStatus !== undefined && { ModelApprovalStatus: input.ModelApprovalStatus }), + ...(input.ModelMetrics !== undefined && { + ModelMetrics: serializeAws_json1_1ModelMetrics(input.ModelMetrics, context), + }), ...(input.ModelPackageDescription !== undefined && { ModelPackageDescription: input.ModelPackageDescription }), + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), ...(input.ModelPackageName !== undefined && { ModelPackageName: input.ModelPackageName }), ...(input.SourceAlgorithmSpecification !== undefined && { SourceAlgorithmSpecification: serializeAws_json1_1SourceAlgorithmSpecification( @@ -11663,6 +15440,7 @@ const serializeAws_json1_1CreateModelPackageInput = (input: CreateModelPackageIn context ), }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), ...(input.ValidationSpecification !== undefined && { ValidationSpecification: serializeAws_json1_1ModelPackageValidationSpecification( input.ValidationSpecification, @@ -11733,6 +15511,18 @@ const serializeAws_json1_1CreateNotebookInstanceLifecycleConfigInput = ( }; }; +const serializeAws_json1_1CreatePipelineRequest = (input: CreatePipelineRequest, context: __SerdeContext): any => { + return { + ClientRequestToken: input.ClientRequestToken ?? generateIdempotencyToken(), + ...(input.PipelineDefinition !== undefined && { PipelineDefinition: input.PipelineDefinition }), + ...(input.PipelineDescription !== undefined && { PipelineDescription: input.PipelineDescription }), + ...(input.PipelineDisplayName !== undefined && { PipelineDisplayName: input.PipelineDisplayName }), + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + ...(input.RoleArn !== undefined && { RoleArn: input.RoleArn }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreatePresignedDomainUrlRequest = ( input: CreatePresignedDomainUrlRequest, context: __SerdeContext @@ -11793,6 +15583,20 @@ const serializeAws_json1_1CreateProcessingJobRequest = ( }; }; +const serializeAws_json1_1CreateProjectInput = (input: CreateProjectInput, context: __SerdeContext): any => { + return { + ...(input.ProjectDescription !== undefined && { ProjectDescription: input.ProjectDescription }), + ...(input.ProjectName !== undefined && { ProjectName: input.ProjectName }), + ...(input.ServiceCatalogProvisioningDetails !== undefined && { + ServiceCatalogProvisioningDetails: serializeAws_json1_1ServiceCatalogProvisioningDetails( + input.ServiceCatalogProvisioningDetails, + context + ), + }), + ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), + }; +}; + const serializeAws_json1_1CreateTrainingJobRequest = ( input: CreateTrainingJobRequest, context: __SerdeContext @@ -11890,6 +15694,9 @@ const serializeAws_json1_1CreateTrialComponentRequest = ( ...(input.InputArtifacts !== undefined && { InputArtifacts: serializeAws_json1_1TrialComponentArtifacts(input.InputArtifacts, context), }), + ...(input.MetadataProperties !== undefined && { + MetadataProperties: serializeAws_json1_1MetadataProperties(input.MetadataProperties, context), + }), ...(input.OutputArtifacts !== undefined && { OutputArtifacts: serializeAws_json1_1TrialComponentArtifacts(input.OutputArtifacts, context), }), @@ -11907,6 +15714,9 @@ const serializeAws_json1_1CreateTrialRequest = (input: CreateTrialRequest, conte return { ...(input.DisplayName !== undefined && { DisplayName: input.DisplayName }), ...(input.ExperimentName !== undefined && { ExperimentName: input.ExperimentName }), + ...(input.MetadataProperties !== undefined && { + MetadataProperties: serializeAws_json1_1MetadataProperties(input.MetadataProperties, context), + }), ...(input.Tags !== undefined && { Tags: serializeAws_json1_1TagList(input.Tags, context) }), ...(input.TrialName !== undefined && { TrialName: input.TrialName }), }; @@ -11995,6 +15805,14 @@ const serializeAws_json1_1DataCaptureConfig = (input: DataCaptureConfig, context }; }; +const serializeAws_json1_1DataCatalogConfig = (input: DataCatalogConfig, context: __SerdeContext): any => { + return { + ...(input.Catalog !== undefined && { Catalog: input.Catalog }), + ...(input.Database !== undefined && { Database: input.Database }), + ...(input.TableName !== undefined && { TableName: input.TableName }), + }; +}; + const serializeAws_json1_1DataProcessing = (input: DataProcessing, context: __SerdeContext): any => { return { ...(input.InputFilter !== undefined && { InputFilter: input.InputFilter }), @@ -12003,6 +15821,23 @@ const serializeAws_json1_1DataProcessing = (input: DataProcessing, context: __Se }; }; +const serializeAws_json1_1DatasetDefinition = (input: DatasetDefinition, context: __SerdeContext): any => { + return { + ...(input.AthenaDatasetDefinition !== undefined && { + AthenaDatasetDefinition: serializeAws_json1_1AthenaDatasetDefinition(input.AthenaDatasetDefinition, context), + }), + ...(input.DataDistributionType !== undefined && { DataDistributionType: input.DataDistributionType }), + ...(input.InputMode !== undefined && { InputMode: input.InputMode }), + ...(input.LocalPath !== undefined && { LocalPath: input.LocalPath }), + ...(input.RedshiftDatasetDefinition !== undefined && { + RedshiftDatasetDefinition: serializeAws_json1_1RedshiftDatasetDefinition( + input.RedshiftDatasetDefinition, + context + ), + }), + }; +}; + const serializeAws_json1_1DataSource = (input: DataSource, context: __SerdeContext): any => { return { ...(input.FileSystemDataSource !== undefined && { @@ -12045,6 +15880,12 @@ const serializeAws_json1_1DebugRuleConfigurations = (input: DebugRuleConfigurati return input.map((entry) => serializeAws_json1_1DebugRuleConfiguration(entry, context)); }; +const serializeAws_json1_1DeleteActionRequest = (input: DeleteActionRequest, context: __SerdeContext): any => { + return { + ...(input.ActionName !== undefined && { ActionName: input.ActionName }), + }; +}; + const serializeAws_json1_1DeleteAlgorithmInput = (input: DeleteAlgorithmInput, context: __SerdeContext): any => { return { ...(input.AlgorithmName !== undefined && { AlgorithmName: input.AlgorithmName }), @@ -12069,6 +15910,23 @@ const serializeAws_json1_1DeleteAppRequest = (input: DeleteAppRequest, context: }; }; +const serializeAws_json1_1DeleteArtifactRequest = (input: DeleteArtifactRequest, context: __SerdeContext): any => { + return { + ...(input.ArtifactArn !== undefined && { ArtifactArn: input.ArtifactArn }), + ...(input.Source !== undefined && { Source: serializeAws_json1_1ArtifactSource(input.Source, context) }), + }; +}; + +const serializeAws_json1_1DeleteAssociationRequest = ( + input: DeleteAssociationRequest, + context: __SerdeContext +): any => { + return { + ...(input.DestinationArn !== undefined && { DestinationArn: input.DestinationArn }), + ...(input.SourceArn !== undefined && { SourceArn: input.SourceArn }), + }; +}; + const serializeAws_json1_1DeleteCodeRepositoryInput = ( input: DeleteCodeRepositoryInput, context: __SerdeContext @@ -12078,6 +15936,12 @@ const serializeAws_json1_1DeleteCodeRepositoryInput = ( }; }; +const serializeAws_json1_1DeleteContextRequest = (input: DeleteContextRequest, context: __SerdeContext): any => { + return { + ...(input.ContextName !== undefined && { ContextName: input.ContextName }), + }; +}; + const serializeAws_json1_1DeleteDomainRequest = (input: DeleteDomainRequest, context: __SerdeContext): any => { return { ...(input.DomainId !== undefined && { DomainId: input.DomainId }), @@ -12108,6 +15972,15 @@ const serializeAws_json1_1DeleteExperimentRequest = (input: DeleteExperimentRequ }; }; +const serializeAws_json1_1DeleteFeatureGroupRequest = ( + input: DeleteFeatureGroupRequest, + context: __SerdeContext +): any => { + return { + ...(input.FeatureGroupName !== undefined && { FeatureGroupName: input.FeatureGroupName }), + }; +}; + const serializeAws_json1_1DeleteFlowDefinitionRequest = ( input: DeleteFlowDefinitionRequest, context: __SerdeContext @@ -12148,6 +16021,24 @@ const serializeAws_json1_1DeleteModelInput = (input: DeleteModelInput, context: }; }; +const serializeAws_json1_1DeleteModelPackageGroupInput = ( + input: DeleteModelPackageGroupInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + }; +}; + +const serializeAws_json1_1DeleteModelPackageGroupPolicyInput = ( + input: DeleteModelPackageGroupPolicyInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + }; +}; + const serializeAws_json1_1DeleteModelPackageInput = (input: DeleteModelPackageInput, context: __SerdeContext): any => { return { ...(input.ModelPackageName !== undefined && { ModelPackageName: input.ModelPackageName }), @@ -12183,6 +16074,19 @@ const serializeAws_json1_1DeleteNotebookInstanceLifecycleConfigInput = ( }; }; +const serializeAws_json1_1DeletePipelineRequest = (input: DeletePipelineRequest, context: __SerdeContext): any => { + return { + ClientRequestToken: input.ClientRequestToken ?? generateIdempotencyToken(), + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + }; +}; + +const serializeAws_json1_1DeleteProjectInput = (input: DeleteProjectInput, context: __SerdeContext): any => { + return { + ...(input.ProjectName !== undefined && { ProjectName: input.ProjectName }), + }; +}; + const serializeAws_json1_1DeleteTagsInput = (input: DeleteTagsInput, context: __SerdeContext): any => { return { ...(input.ResourceArn !== undefined && { ResourceArn: input.ResourceArn }), @@ -12227,6 +16131,23 @@ const serializeAws_json1_1DeleteWorkteamRequest = (input: DeleteWorkteamRequest, }; }; +const serializeAws_json1_1DeploymentConfig = (input: DeploymentConfig, context: __SerdeContext): any => { + return { + ...(input.AutoRollbackConfiguration !== undefined && { + AutoRollbackConfiguration: serializeAws_json1_1AutoRollbackConfig(input.AutoRollbackConfiguration, context), + }), + ...(input.BlueGreenUpdatePolicy !== undefined && { + BlueGreenUpdatePolicy: serializeAws_json1_1BlueGreenUpdatePolicy(input.BlueGreenUpdatePolicy, context), + }), + }; +}; + +const serializeAws_json1_1DescribeActionRequest = (input: DescribeActionRequest, context: __SerdeContext): any => { + return { + ...(input.ActionName !== undefined && { ActionName: input.ActionName }), + }; +}; + const serializeAws_json1_1DescribeAlgorithmInput = (input: DescribeAlgorithmInput, context: __SerdeContext): any => { return { ...(input.AlgorithmName !== undefined && { AlgorithmName: input.AlgorithmName }), @@ -12251,6 +16172,12 @@ const serializeAws_json1_1DescribeAppRequest = (input: DescribeAppRequest, conte }; }; +const serializeAws_json1_1DescribeArtifactRequest = (input: DescribeArtifactRequest, context: __SerdeContext): any => { + return { + ...(input.ArtifactArn !== undefined && { ArtifactArn: input.ArtifactArn }), + }; +}; + const serializeAws_json1_1DescribeAutoMLJobRequest = ( input: DescribeAutoMLJobRequest, context: __SerdeContext @@ -12278,6 +16205,12 @@ const serializeAws_json1_1DescribeCompilationJobRequest = ( }; }; +const serializeAws_json1_1DescribeContextRequest = (input: DescribeContextRequest, context: __SerdeContext): any => { + return { + ...(input.ContextName !== undefined && { ContextName: input.ContextName }), + }; +}; + const serializeAws_json1_1DescribeDomainRequest = (input: DescribeDomainRequest, context: __SerdeContext): any => { return { ...(input.DomainId !== undefined && { DomainId: input.DomainId }), @@ -12308,6 +16241,16 @@ const serializeAws_json1_1DescribeExperimentRequest = ( }; }; +const serializeAws_json1_1DescribeFeatureGroupRequest = ( + input: DescribeFeatureGroupRequest, + context: __SerdeContext +): any => { + return { + ...(input.FeatureGroupName !== undefined && { FeatureGroupName: input.FeatureGroupName }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + }; +}; + const serializeAws_json1_1DescribeFlowDefinitionRequest = ( input: DescribeFlowDefinitionRequest, context: __SerdeContext @@ -12368,6 +16311,15 @@ const serializeAws_json1_1DescribeModelInput = (input: DescribeModelInput, conte }; }; +const serializeAws_json1_1DescribeModelPackageGroupInput = ( + input: DescribeModelPackageGroupInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + }; +}; + const serializeAws_json1_1DescribeModelPackageInput = ( input: DescribeModelPackageInput, context: __SerdeContext @@ -12406,6 +16358,30 @@ const serializeAws_json1_1DescribeNotebookInstanceLifecycleConfigInput = ( }; }; +const serializeAws_json1_1DescribePipelineDefinitionForExecutionRequest = ( + input: DescribePipelineDefinitionForExecutionRequest, + context: __SerdeContext +): any => { + return { + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + }; +}; + +const serializeAws_json1_1DescribePipelineExecutionRequest = ( + input: DescribePipelineExecutionRequest, + context: __SerdeContext +): any => { + return { + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + }; +}; + +const serializeAws_json1_1DescribePipelineRequest = (input: DescribePipelineRequest, context: __SerdeContext): any => { + return { + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + }; +}; + const serializeAws_json1_1DescribeProcessingJobRequest = ( input: DescribeProcessingJobRequest, context: __SerdeContext @@ -12415,6 +16391,12 @@ const serializeAws_json1_1DescribeProcessingJobRequest = ( }; }; +const serializeAws_json1_1DescribeProjectInput = (input: DescribeProjectInput, context: __SerdeContext): any => { + return { + ...(input.ProjectName !== undefined && { ProjectName: input.ProjectName }), + }; +}; + const serializeAws_json1_1DescribeSubscribedWorkteamRequest = ( input: DescribeSubscribedWorkteamRequest, context: __SerdeContext @@ -12500,6 +16482,13 @@ const serializeAws_json1_1DesiredWeightAndCapacityList = ( return input.map((entry) => serializeAws_json1_1DesiredWeightAndCapacity(entry, context)); }; +const serializeAws_json1_1DisableSagemakerServicecatalogPortfolioInput = ( + input: DisableSagemakerServicecatalogPortfolioInput, + context: __SerdeContext +): any => { + return {}; +}; + const serializeAws_json1_1DisassociateTrialComponentRequest = ( input: DisassociateTrialComponentRequest, context: __SerdeContext @@ -12510,6 +16499,13 @@ const serializeAws_json1_1DisassociateTrialComponentRequest = ( }; }; +const serializeAws_json1_1EnableSagemakerServicecatalogPortfolioInput = ( + input: EnableSagemakerServicecatalogPortfolioInput, + context: __SerdeContext +): any => { + return {}; +}; + const serializeAws_json1_1EndpointInput = (input: EndpointInput, context: __SerdeContext): any => { return { ...(input.EndpointName !== undefined && { EndpointName: input.EndpointName }), @@ -12539,6 +16535,23 @@ const serializeAws_json1_1ExperimentConfig = (input: ExperimentConfig, context: }; }; +const serializeAws_json1_1Explainability = (input: Explainability, context: __SerdeContext): any => { + return { + ...(input.Report !== undefined && { Report: serializeAws_json1_1MetricsSource(input.Report, context) }), + }; +}; + +const serializeAws_json1_1FeatureDefinition = (input: FeatureDefinition, context: __SerdeContext): any => { + return { + ...(input.FeatureName !== undefined && { FeatureName: input.FeatureName }), + ...(input.FeatureType !== undefined && { FeatureType: input.FeatureType }), + }; +}; + +const serializeAws_json1_1FeatureDefinitions = (input: FeatureDefinition[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1FeatureDefinition(entry, context)); +}; + const serializeAws_json1_1FileSystemConfig = (input: FileSystemConfig, context: __SerdeContext): any => { return { ...(input.DefaultGid !== undefined && { DefaultGid: input.DefaultGid }), @@ -12582,6 +16595,22 @@ const serializeAws_json1_1FlowDefinitionTaskKeywords = (input: string[], context return input.map((entry) => entry); }; +const serializeAws_json1_1GetModelPackageGroupPolicyInput = ( + input: GetModelPackageGroupPolicyInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + }; +}; + +const serializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusInput = ( + input: GetSagemakerServicecatalogPortfolioStatusInput, + context: __SerdeContext +): any => { + return {}; +}; + const serializeAws_json1_1GetSearchSuggestionsRequest = ( input: GetSearchSuggestionsRequest, context: __SerdeContext @@ -13096,6 +17125,32 @@ const serializeAws_json1_1LabelingJobStoppingConditions = ( }; }; +const serializeAws_json1_1LineageEntityParameters = ( + input: { [key: string]: string }, + context: __SerdeContext +): any => { + return Object.entries(input).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + +const serializeAws_json1_1ListActionsRequest = (input: ListActionsRequest, context: __SerdeContext): any => { + return { + ...(input.ActionType !== undefined && { ActionType: input.ActionType }), + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + const serializeAws_json1_1ListAlgorithmsInput = (input: ListAlgorithmsInput, context: __SerdeContext): any => { return { ...(input.CreationTimeAfter !== undefined && { @@ -13148,6 +17203,35 @@ const serializeAws_json1_1ListAppsRequest = (input: ListAppsRequest, context: __ }; }; +const serializeAws_json1_1ListArtifactsRequest = (input: ListArtifactsRequest, context: __SerdeContext): any => { + return { + ...(input.ArtifactType !== undefined && { ArtifactType: input.ArtifactType }), + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + +const serializeAws_json1_1ListAssociationsRequest = (input: ListAssociationsRequest, context: __SerdeContext): any => { + return { + ...(input.AssociationType !== undefined && { AssociationType: input.AssociationType }), + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.DestinationArn !== undefined && { DestinationArn: input.DestinationArn }), + ...(input.DestinationType !== undefined && { DestinationType: input.DestinationType }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + ...(input.SourceArn !== undefined && { SourceArn: input.SourceArn }), + ...(input.SourceType !== undefined && { SourceType: input.SourceType }), + }; +}; + const serializeAws_json1_1ListAutoMLJobsRequest = (input: ListAutoMLJobsRequest, context: __SerdeContext): any => { return { ...(input.CreationTimeAfter !== undefined && { @@ -13237,6 +17321,19 @@ const serializeAws_json1_1ListCompilationJobsRequest = ( }; }; +const serializeAws_json1_1ListContextsRequest = (input: ListContextsRequest, context: __SerdeContext): any => { + return { + ...(input.ContextType !== undefined && { ContextType: input.ContextType }), + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + ...(input.SourceUri !== undefined && { SourceUri: input.SourceUri }), + }; +}; + const serializeAws_json1_1ListDomainsRequest = (input: ListDomainsRequest, context: __SerdeContext): any => { return { ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), @@ -13297,6 +17394,27 @@ const serializeAws_json1_1ListExperimentsRequest = (input: ListExperimentsReques }; }; +const serializeAws_json1_1ListFeatureGroupsRequest = ( + input: ListFeatureGroupsRequest, + context: __SerdeContext +): any => { + return { + ...(input.CreationTimeAfter !== undefined && { + CreationTimeAfter: Math.round(input.CreationTimeAfter.getTime() / 1000), + }), + ...(input.CreationTimeBefore !== undefined && { + CreationTimeBefore: Math.round(input.CreationTimeBefore.getTime() / 1000), + }), + ...(input.FeatureGroupStatusEquals !== undefined && { FeatureGroupStatusEquals: input.FeatureGroupStatusEquals }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NameContains !== undefined && { NameContains: input.NameContains }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.OfflineStoreStatusEquals !== undefined && { OfflineStoreStatusEquals: input.OfflineStoreStatusEquals }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + }; +}; + const serializeAws_json1_1ListFlowDefinitionsRequest = ( input: ListFlowDefinitionsRequest, context: __SerdeContext @@ -13444,6 +17562,29 @@ const serializeAws_json1_1ListLabelingJobsRequest = (input: ListLabelingJobsRequ }; }; +const serializeAws_json1_1ListLineageEntityParameterKey = (input: string[], context: __SerdeContext): any => { + return input.map((entry) => entry); +}; + +const serializeAws_json1_1ListModelPackageGroupsInput = ( + input: ListModelPackageGroupsInput, + context: __SerdeContext +): any => { + return { + ...(input.CreationTimeAfter !== undefined && { + CreationTimeAfter: Math.round(input.CreationTimeAfter.getTime() / 1000), + }), + ...(input.CreationTimeBefore !== undefined && { + CreationTimeBefore: Math.round(input.CreationTimeBefore.getTime() / 1000), + }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NameContains !== undefined && { NameContains: input.NameContains }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + }; +}; + const serializeAws_json1_1ListModelPackagesInput = (input: ListModelPackagesInput, context: __SerdeContext): any => { return { ...(input.CreationTimeAfter !== undefined && { @@ -13453,6 +17594,9 @@ const serializeAws_json1_1ListModelPackagesInput = (input: ListModelPackagesInpu CreationTimeBefore: Math.round(input.CreationTimeBefore.getTime() / 1000), }), ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.ModelApprovalStatus !== undefined && { ModelApprovalStatus: input.ModelApprovalStatus }), + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + ...(input.ModelPackageType !== undefined && { ModelPackageType: input.ModelPackageType }), ...(input.NameContains !== undefined && { NameContains: input.NameContains }), ...(input.NextToken !== undefined && { NextToken: input.NextToken }), ...(input.SortBy !== undefined && { SortBy: input.SortBy }), @@ -13596,6 +17740,56 @@ const serializeAws_json1_1ListNotebookInstancesInput = ( }; }; +const serializeAws_json1_1ListPipelineExecutionsRequest = ( + input: ListPipelineExecutionsRequest, + context: __SerdeContext +): any => { + return { + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + }; +}; + +const serializeAws_json1_1ListPipelineExecutionStepsRequest = ( + input: ListPipelineExecutionStepsRequest, + context: __SerdeContext +): any => { + return { + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + }; +}; + +const serializeAws_json1_1ListPipelineParametersForExecutionRequest = ( + input: ListPipelineParametersForExecutionRequest, + context: __SerdeContext +): any => { + return { + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + }; +}; + +const serializeAws_json1_1ListPipelinesRequest = (input: ListPipelinesRequest, context: __SerdeContext): any => { + return { + ...(input.CreatedAfter !== undefined && { CreatedAfter: Math.round(input.CreatedAfter.getTime() / 1000) }), + ...(input.CreatedBefore !== undefined && { CreatedBefore: Math.round(input.CreatedBefore.getTime() / 1000) }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.PipelineNamePrefix !== undefined && { PipelineNamePrefix: input.PipelineNamePrefix }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + }; +}; + const serializeAws_json1_1ListProcessingJobsRequest = ( input: ListProcessingJobsRequest, context: __SerdeContext @@ -13607,18 +17801,34 @@ const serializeAws_json1_1ListProcessingJobsRequest = ( ...(input.CreationTimeBefore !== undefined && { CreationTimeBefore: Math.round(input.CreationTimeBefore.getTime() / 1000), }), - ...(input.LastModifiedTimeAfter !== undefined && { - LastModifiedTimeAfter: Math.round(input.LastModifiedTimeAfter.getTime() / 1000), - }), - ...(input.LastModifiedTimeBefore !== undefined && { - LastModifiedTimeBefore: Math.round(input.LastModifiedTimeBefore.getTime() / 1000), - }), + ...(input.LastModifiedTimeAfter !== undefined && { + LastModifiedTimeAfter: Math.round(input.LastModifiedTimeAfter.getTime() / 1000), + }), + ...(input.LastModifiedTimeBefore !== undefined && { + LastModifiedTimeBefore: Math.round(input.LastModifiedTimeBefore.getTime() / 1000), + }), + ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), + ...(input.NameContains !== undefined && { NameContains: input.NameContains }), + ...(input.NextToken !== undefined && { NextToken: input.NextToken }), + ...(input.SortBy !== undefined && { SortBy: input.SortBy }), + ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), + ...(input.StatusEquals !== undefined && { StatusEquals: input.StatusEquals }), + }; +}; + +const serializeAws_json1_1ListProjectsInput = (input: ListProjectsInput, context: __SerdeContext): any => { + return { + ...(input.CreationTimeAfter !== undefined && { + CreationTimeAfter: Math.round(input.CreationTimeAfter.getTime() / 1000), + }), + ...(input.CreationTimeBefore !== undefined && { + CreationTimeBefore: Math.round(input.CreationTimeBefore.getTime() / 1000), + }), ...(input.MaxResults !== undefined && { MaxResults: input.MaxResults }), ...(input.NameContains !== undefined && { NameContains: input.NameContains }), ...(input.NextToken !== undefined && { NextToken: input.NextToken }), ...(input.SortBy !== undefined && { SortBy: input.SortBy }), ...(input.SortOrder !== undefined && { SortOrder: input.SortOrder }), - ...(input.StatusEquals !== undefined && { StatusEquals: input.StatusEquals }), }; }; @@ -13786,6 +17996,15 @@ const serializeAws_json1_1MemberDefinitions = (input: MemberDefinition[], contex return input.map((entry) => serializeAws_json1_1MemberDefinition(entry, context)); }; +const serializeAws_json1_1MetadataProperties = (input: MetadataProperties, context: __SerdeContext): any => { + return { + ...(input.CommitId !== undefined && { CommitId: input.CommitId }), + ...(input.GeneratedBy !== undefined && { GeneratedBy: input.GeneratedBy }), + ...(input.ProjectId !== undefined && { ProjectId: input.ProjectId }), + ...(input.Repository !== undefined && { Repository: input.Repository }), + }; +}; + const serializeAws_json1_1MetricDefinition = (input: MetricDefinition, context: __SerdeContext): any => { return { ...(input.Name !== undefined && { Name: input.Name }), @@ -13797,6 +18016,14 @@ const serializeAws_json1_1MetricDefinitionList = (input: MetricDefinition[], con return input.map((entry) => serializeAws_json1_1MetricDefinition(entry, context)); }; +const serializeAws_json1_1MetricsSource = (input: MetricsSource, context: __SerdeContext): any => { + return { + ...(input.ContentDigest !== undefined && { ContentDigest: input.ContentDigest }), + ...(input.ContentType !== undefined && { ContentType: input.ContentType }), + ...(input.S3Uri !== undefined && { S3Uri: input.S3Uri }), + }; +}; + const serializeAws_json1_1ModelClientConfig = (input: ModelClientConfig, context: __SerdeContext): any => { return { ...(input.InvocationsMaxRetries !== undefined && { InvocationsMaxRetries: input.InvocationsMaxRetries }), @@ -13806,6 +18033,30 @@ const serializeAws_json1_1ModelClientConfig = (input: ModelClientConfig, context }; }; +const serializeAws_json1_1ModelDataQuality = (input: ModelDataQuality, context: __SerdeContext): any => { + return { + ...(input.Constraints !== undefined && { + Constraints: serializeAws_json1_1MetricsSource(input.Constraints, context), + }), + ...(input.Statistics !== undefined && { Statistics: serializeAws_json1_1MetricsSource(input.Statistics, context) }), + }; +}; + +const serializeAws_json1_1ModelMetrics = (input: ModelMetrics, context: __SerdeContext): any => { + return { + ...(input.Bias !== undefined && { Bias: serializeAws_json1_1Bias(input.Bias, context) }), + ...(input.Explainability !== undefined && { + Explainability: serializeAws_json1_1Explainability(input.Explainability, context), + }), + ...(input.ModelDataQuality !== undefined && { + ModelDataQuality: serializeAws_json1_1ModelDataQuality(input.ModelDataQuality, context), + }), + ...(input.ModelQuality !== undefined && { + ModelQuality: serializeAws_json1_1ModelQuality(input.ModelQuality, context), + }), + }; +}; + const serializeAws_json1_1ModelPackageContainerDefinition = ( input: ModelPackageContainerDefinition, context: __SerdeContext @@ -13857,6 +18108,15 @@ const serializeAws_json1_1ModelPackageValidationSpecification = ( }; }; +const serializeAws_json1_1ModelQuality = (input: ModelQuality, context: __SerdeContext): any => { + return { + ...(input.Constraints !== undefined && { + Constraints: serializeAws_json1_1MetricsSource(input.Constraints, context), + }), + ...(input.Statistics !== undefined && { Statistics: serializeAws_json1_1MetricsSource(input.Statistics, context) }), + }; +}; + const serializeAws_json1_1MonitoringAppSpecification = ( input: MonitoringAppSpecification, context: __SerdeContext @@ -14092,6 +18352,18 @@ const serializeAws_json1_1NotificationConfiguration = ( }; }; +const serializeAws_json1_1OfflineStoreConfig = (input: OfflineStoreConfig, context: __SerdeContext): any => { + return { + ...(input.DataCatalogConfig !== undefined && { + DataCatalogConfig: serializeAws_json1_1DataCatalogConfig(input.DataCatalogConfig, context), + }), + ...(input.DisableGlueTableCreation !== undefined && { DisableGlueTableCreation: input.DisableGlueTableCreation }), + ...(input.S3StorageConfig !== undefined && { + S3StorageConfig: serializeAws_json1_1S3StorageConfig(input.S3StorageConfig, context), + }), + }; +}; + const serializeAws_json1_1OidcConfig = (input: OidcConfig, context: __SerdeContext): any => { return { ...(input.AuthorizationEndpoint !== undefined && { AuthorizationEndpoint: input.AuthorizationEndpoint }), @@ -14111,9 +18383,28 @@ const serializeAws_json1_1OidcMemberDefinition = (input: OidcMemberDefinition, c }; }; +const serializeAws_json1_1OnlineStoreConfig = (input: OnlineStoreConfig, context: __SerdeContext): any => { + return { + ...(input.EnableOnlineStore !== undefined && { EnableOnlineStore: input.EnableOnlineStore }), + ...(input.SecurityConfig !== undefined && { + SecurityConfig: serializeAws_json1_1OnlineStoreSecurityConfig(input.SecurityConfig, context), + }), + }; +}; + +const serializeAws_json1_1OnlineStoreSecurityConfig = ( + input: OnlineStoreSecurityConfig, + context: __SerdeContext +): any => { + return { + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + }; +}; + const serializeAws_json1_1OutputConfig = (input: OutputConfig, context: __SerdeContext): any => { return { ...(input.CompilerOptions !== undefined && { CompilerOptions: input.CompilerOptions }), + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), ...(input.S3OutputLocation !== undefined && { S3OutputLocation: input.S3OutputLocation }), ...(input.TargetDevice !== undefined && { TargetDevice: input.TargetDevice }), ...(input.TargetPlatform !== undefined && { @@ -14129,6 +18420,17 @@ const serializeAws_json1_1OutputDataConfig = (input: OutputDataConfig, context: }; }; +const serializeAws_json1_1Parameter = (input: Parameter, context: __SerdeContext): any => { + return { + ...(input.Name !== undefined && { Name: input.Name }), + ...(input.Value !== undefined && { Value: input.Value }), + }; +}; + +const serializeAws_json1_1ParameterList = (input: Parameter[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1Parameter(entry, context)); +}; + const serializeAws_json1_1ParameterRange = (input: ParameterRange, context: __SerdeContext): any => { return { ...(input.CategoricalParameterRangeSpecification !== undefined && { @@ -14216,8 +18518,21 @@ const serializeAws_json1_1ProcessingEnvironmentMap = ( ); }; +const serializeAws_json1_1ProcessingFeatureStoreOutput = ( + input: ProcessingFeatureStoreOutput, + context: __SerdeContext +): any => { + return { + ...(input.FeatureGroupName !== undefined && { FeatureGroupName: input.FeatureGroupName }), + }; +}; + const serializeAws_json1_1ProcessingInput = (input: ProcessingInput, context: __SerdeContext): any => { return { + ...(input.AppManaged !== undefined && { AppManaged: input.AppManaged }), + ...(input.DatasetDefinition !== undefined && { + DatasetDefinition: serializeAws_json1_1DatasetDefinition(input.DatasetDefinition, context), + }), ...(input.InputName !== undefined && { InputName: input.InputName }), ...(input.S3Input !== undefined && { S3Input: serializeAws_json1_1ProcessingS3Input(input.S3Input, context) }), }; @@ -14229,6 +18544,10 @@ const serializeAws_json1_1ProcessingInputs = (input: ProcessingInput[], context: const serializeAws_json1_1ProcessingOutput = (input: ProcessingOutput, context: __SerdeContext): any => { return { + ...(input.AppManaged !== undefined && { AppManaged: input.AppManaged }), + ...(input.FeatureStoreOutput !== undefined && { + FeatureStoreOutput: serializeAws_json1_1ProcessingFeatureStoreOutput(input.FeatureStoreOutput, context), + }), ...(input.OutputName !== undefined && { OutputName: input.OutputName }), ...(input.S3Output !== undefined && { S3Output: serializeAws_json1_1ProcessingS3Output(input.S3Output, context) }), }; @@ -14302,6 +18621,17 @@ const serializeAws_json1_1PropertyNameQuery = (input: PropertyNameQuery, context }; }; +const serializeAws_json1_1ProvisioningParameter = (input: ProvisioningParameter, context: __SerdeContext): any => { + return { + ...(input.Key !== undefined && { Key: input.Key }), + ...(input.Value !== undefined && { Value: input.Value }), + }; +}; + +const serializeAws_json1_1ProvisioningParameters = (input: ProvisioningParameter[], context: __SerdeContext): any => { + return input.map((entry) => serializeAws_json1_1ProvisioningParameter(entry, context)); +}; + const serializeAws_json1_1PublicWorkforceTaskPrice = ( input: PublicWorkforceTaskPrice, context: __SerdeContext @@ -14311,6 +18641,16 @@ const serializeAws_json1_1PublicWorkforceTaskPrice = ( }; }; +const serializeAws_json1_1PutModelPackageGroupPolicyInput = ( + input: PutModelPackageGroupPolicyInput, + context: __SerdeContext +): any => { + return { + ...(input.ModelPackageGroupName !== undefined && { ModelPackageGroupName: input.ModelPackageGroupName }), + ...(input.ResourcePolicy !== undefined && { ResourcePolicy: input.ResourcePolicy }), + }; +}; + const serializeAws_json1_1RealtimeInferenceInstanceTypes = ( input: (ProductionVariantInstanceType | string)[], context: __SerdeContext @@ -14318,6 +18658,23 @@ const serializeAws_json1_1RealtimeInferenceInstanceTypes = ( return input.map((entry) => entry); }; +const serializeAws_json1_1RedshiftDatasetDefinition = ( + input: RedshiftDatasetDefinition, + context: __SerdeContext +): any => { + return { + ...(input.ClusterId !== undefined && { ClusterId: input.ClusterId }), + ...(input.ClusterRoleArn !== undefined && { ClusterRoleArn: input.ClusterRoleArn }), + ...(input.Database !== undefined && { Database: input.Database }), + ...(input.DbUser !== undefined && { DbUser: input.DbUser }), + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + ...(input.OutputCompression !== undefined && { OutputCompression: input.OutputCompression }), + ...(input.OutputFormat !== undefined && { OutputFormat: input.OutputFormat }), + ...(input.OutputS3Uri !== undefined && { OutputS3Uri: input.OutputS3Uri }), + ...(input.QueryString !== undefined && { QueryString: input.QueryString }), + }; +}; + const serializeAws_json1_1RenderableTask = (input: RenderableTask, context: __SerdeContext): any => { return { ...(input.Input !== undefined && { Input: input.Input }), @@ -14388,6 +18745,13 @@ const serializeAws_json1_1S3DataSource = (input: S3DataSource, context: __SerdeC }; }; +const serializeAws_json1_1S3StorageConfig = (input: S3StorageConfig, context: __SerdeContext): any => { + return { + ...(input.KmsKeyId !== undefined && { KmsKeyId: input.KmsKeyId }), + ...(input.S3Uri !== undefined && { S3Uri: input.S3Uri }), + }; +}; + const serializeAws_json1_1ScheduleConfig = (input: ScheduleConfig, context: __SerdeContext): any => { return { ...(input.ScheduleExpression !== undefined && { ScheduleExpression: input.ScheduleExpression }), @@ -14428,6 +18792,20 @@ const serializeAws_json1_1SecurityGroupIds = (input: string[], context: __SerdeC return input.map((entry) => entry); }; +const serializeAws_json1_1ServiceCatalogProvisioningDetails = ( + input: ServiceCatalogProvisioningDetails, + context: __SerdeContext +): any => { + return { + ...(input.PathId !== undefined && { PathId: input.PathId }), + ...(input.ProductId !== undefined && { ProductId: input.ProductId }), + ...(input.ProvisioningArtifactId !== undefined && { ProvisioningArtifactId: input.ProvisioningArtifactId }), + ...(input.ProvisioningParameters !== undefined && { + ProvisioningParameters: serializeAws_json1_1ProvisioningParameters(input.ProvisioningParameters, context), + }), + }; +}; + const serializeAws_json1_1SharingSettings = (input: SharingSettings, context: __SerdeContext): any => { return { ...(input.NotebookOutputOption !== undefined && { NotebookOutputOption: input.NotebookOutputOption }), @@ -14488,6 +18866,25 @@ const serializeAws_json1_1StartNotebookInstanceInput = ( }; }; +const serializeAws_json1_1StartPipelineExecutionRequest = ( + input: StartPipelineExecutionRequest, + context: __SerdeContext +): any => { + return { + ClientRequestToken: input.ClientRequestToken ?? generateIdempotencyToken(), + ...(input.PipelineExecutionDescription !== undefined && { + PipelineExecutionDescription: input.PipelineExecutionDescription, + }), + ...(input.PipelineExecutionDisplayName !== undefined && { + PipelineExecutionDisplayName: input.PipelineExecutionDisplayName, + }), + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + ...(input.PipelineParameters !== undefined && { + PipelineParameters: serializeAws_json1_1ParameterList(input.PipelineParameters, context), + }), + }; +}; + const serializeAws_json1_1StopAutoMLJobRequest = (input: StopAutoMLJobRequest, context: __SerdeContext): any => { return { ...(input.AutoMLJobName !== undefined && { AutoMLJobName: input.AutoMLJobName }), @@ -14545,6 +18942,16 @@ const serializeAws_json1_1StoppingCondition = (input: StoppingCondition, context }; }; +const serializeAws_json1_1StopPipelineExecutionRequest = ( + input: StopPipelineExecutionRequest, + context: __SerdeContext +): any => { + return { + ClientRequestToken: input.ClientRequestToken ?? generateIdempotencyToken(), + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + }; +}; + const serializeAws_json1_1StopProcessingJobRequest = ( input: StopProcessingJobRequest, context: __SerdeContext @@ -14620,6 +19027,14 @@ const serializeAws_json1_1TensorBoardOutputConfig = (input: TensorBoardOutputCon }; }; +const serializeAws_json1_1TrafficRoutingConfig = (input: TrafficRoutingConfig, context: __SerdeContext): any => { + return { + ...(input.CanarySize !== undefined && { CanarySize: serializeAws_json1_1CapacitySize(input.CanarySize, context) }), + ...(input.Type !== undefined && { Type: input.Type }), + ...(input.WaitIntervalInSeconds !== undefined && { WaitIntervalInSeconds: input.WaitIntervalInSeconds }), + }; +}; + const serializeAws_json1_1TrainingInstanceTypes = ( input: (TrainingInstanceType | string)[], context: __SerdeContext @@ -14802,10 +19217,11 @@ const serializeAws_json1_1TrialComponentParameterValue = ( input: TrialComponentParameterValue, context: __SerdeContext ): any => { - return { - ...(input.NumberValue !== undefined && { NumberValue: input.NumberValue }), - ...(input.StringValue !== undefined && { StringValue: input.StringValue }), - }; + return TrialComponentParameterValue.visit(input, { + NumberValue: (value) => ({ NumberValue: value }), + StringValue: (value) => ({ StringValue: value }), + _: (name, value) => ({ name: value } as any), + }); }; const serializeAws_json1_1TrialComponentStatus = (input: TrialComponentStatus, context: __SerdeContext): any => { @@ -14839,6 +19255,20 @@ const serializeAws_json1_1UiTemplate = (input: UiTemplate, context: __SerdeConte }; }; +const serializeAws_json1_1UpdateActionRequest = (input: UpdateActionRequest, context: __SerdeContext): any => { + return { + ...(input.ActionName !== undefined && { ActionName: input.ActionName }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.PropertiesToRemove !== undefined && { + PropertiesToRemove: serializeAws_json1_1ListLineageEntityParameterKey(input.PropertiesToRemove, context), + }), + ...(input.Status !== undefined && { Status: input.Status }), + }; +}; + const serializeAws_json1_1UpdateAppImageConfigRequest = ( input: UpdateAppImageConfigRequest, context: __SerdeContext @@ -14851,6 +19281,19 @@ const serializeAws_json1_1UpdateAppImageConfigRequest = ( }; }; +const serializeAws_json1_1UpdateArtifactRequest = (input: UpdateArtifactRequest, context: __SerdeContext): any => { + return { + ...(input.ArtifactArn !== undefined && { ArtifactArn: input.ArtifactArn }), + ...(input.ArtifactName !== undefined && { ArtifactName: input.ArtifactName }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.PropertiesToRemove !== undefined && { + PropertiesToRemove: serializeAws_json1_1ListLineageEntityParameterKey(input.PropertiesToRemove, context), + }), + }; +}; + const serializeAws_json1_1UpdateCodeRepositoryInput = ( input: UpdateCodeRepositoryInput, context: __SerdeContext @@ -14863,6 +19306,19 @@ const serializeAws_json1_1UpdateCodeRepositoryInput = ( }; }; +const serializeAws_json1_1UpdateContextRequest = (input: UpdateContextRequest, context: __SerdeContext): any => { + return { + ...(input.ContextName !== undefined && { ContextName: input.ContextName }), + ...(input.Description !== undefined && { Description: input.Description }), + ...(input.Properties !== undefined && { + Properties: serializeAws_json1_1LineageEntityParameters(input.Properties, context), + }), + ...(input.PropertiesToRemove !== undefined && { + PropertiesToRemove: serializeAws_json1_1ListLineageEntityParameterKey(input.PropertiesToRemove, context), + }), + }; +}; + const serializeAws_json1_1UpdateDomainRequest = (input: UpdateDomainRequest, context: __SerdeContext): any => { return { ...(input.DefaultUserSettings !== undefined && { @@ -14874,6 +19330,9 @@ const serializeAws_json1_1UpdateDomainRequest = (input: UpdateDomainRequest, con const serializeAws_json1_1UpdateEndpointInput = (input: UpdateEndpointInput, context: __SerdeContext): any => { return { + ...(input.DeploymentConfig !== undefined && { + DeploymentConfig: serializeAws_json1_1DeploymentConfig(input.DeploymentConfig, context), + }), ...(input.EndpointConfigName !== undefined && { EndpointConfigName: input.EndpointConfigName }), ...(input.EndpointName !== undefined && { EndpointName: input.EndpointName }), ...(input.ExcludeRetainedVariantProperties !== undefined && { @@ -14923,6 +19382,14 @@ const serializeAws_json1_1UpdateImageRequest = (input: UpdateImageRequest, conte }; }; +const serializeAws_json1_1UpdateModelPackageInput = (input: UpdateModelPackageInput, context: __SerdeContext): any => { + return { + ...(input.ApprovalDescription !== undefined && { ApprovalDescription: input.ApprovalDescription }), + ...(input.ModelApprovalStatus !== undefined && { ModelApprovalStatus: input.ModelApprovalStatus }), + ...(input.ModelPackageArn !== undefined && { ModelPackageArn: input.ModelPackageArn }), + }; +}; + const serializeAws_json1_1UpdateMonitoringScheduleRequest = ( input: UpdateMonitoringScheduleRequest, context: __SerdeContext @@ -14988,6 +19455,31 @@ const serializeAws_json1_1UpdateNotebookInstanceLifecycleConfigInput = ( }; }; +const serializeAws_json1_1UpdatePipelineExecutionRequest = ( + input: UpdatePipelineExecutionRequest, + context: __SerdeContext +): any => { + return { + ...(input.PipelineExecutionArn !== undefined && { PipelineExecutionArn: input.PipelineExecutionArn }), + ...(input.PipelineExecutionDescription !== undefined && { + PipelineExecutionDescription: input.PipelineExecutionDescription, + }), + ...(input.PipelineExecutionDisplayName !== undefined && { + PipelineExecutionDisplayName: input.PipelineExecutionDisplayName, + }), + }; +}; + +const serializeAws_json1_1UpdatePipelineRequest = (input: UpdatePipelineRequest, context: __SerdeContext): any => { + return { + ...(input.PipelineDefinition !== undefined && { PipelineDefinition: input.PipelineDefinition }), + ...(input.PipelineDescription !== undefined && { PipelineDescription: input.PipelineDescription }), + ...(input.PipelineDisplayName !== undefined && { PipelineDisplayName: input.PipelineDisplayName }), + ...(input.PipelineName !== undefined && { PipelineName: input.PipelineName }), + ...(input.RoleArn !== undefined && { RoleArn: input.RoleArn }), + }; +}; + const serializeAws_json1_1UpdateTrialComponentRequest = ( input: UpdateTrialComponentRequest, context: __SerdeContext @@ -15117,6 +19609,47 @@ const serializeAws_json1_1VpcSecurityGroupIds = (input: string[], context: __Ser return input.map((entry) => entry); }; +const deserializeAws_json1_1ActionSource = (output: any, context: __SerdeContext): ActionSource => { + return { + SourceId: output.SourceId !== undefined && output.SourceId !== null ? output.SourceId : undefined, + SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, + SourceUri: output.SourceUri !== undefined && output.SourceUri !== null ? output.SourceUri : undefined, + } as any; +}; + +const deserializeAws_json1_1ActionSummaries = (output: any, context: __SerdeContext): ActionSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ActionSummary(entry, context)); +}; + +const deserializeAws_json1_1ActionSummary = (output: any, context: __SerdeContext): ActionSummary => { + return { + ActionArn: output.ActionArn !== undefined && output.ActionArn !== null ? output.ActionArn : undefined, + ActionName: output.ActionName !== undefined && output.ActionName !== null ? output.ActionName : undefined, + ActionType: output.ActionType !== undefined && output.ActionType !== null ? output.ActionType : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ActionSource(output.Source, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + +const deserializeAws_json1_1AddAssociationResponse = (output: any, context: __SerdeContext): AddAssociationResponse => { + return { + DestinationArn: + output.DestinationArn !== undefined && output.DestinationArn !== null ? output.DestinationArn : undefined, + SourceArn: output.SourceArn !== undefined && output.SourceArn !== null ? output.SourceArn : undefined, + } as any; +}; + const deserializeAws_json1_1AdditionalCodeRepositoryNamesOrUrls = (output: any, context: __SerdeContext): string[] => { return (output || []).map((entry: any) => entry); }; @@ -15130,6 +19663,16 @@ const deserializeAws_json1_1AddTagsOutput = (output: any, context: __SerdeContex } as any; }; +const deserializeAws_json1_1Alarm = (output: any, context: __SerdeContext): Alarm => { + return { + AlarmName: output.AlarmName !== undefined && output.AlarmName !== null ? output.AlarmName : undefined, + } as any; +}; + +const deserializeAws_json1_1AlarmList = (output: any, context: __SerdeContext): Alarm[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Alarm(entry, context)); +}; + const deserializeAws_json1_1AlgorithmSpecification = (output: any, context: __SerdeContext): AlgorithmSpecification => { return { AlgorithmName: @@ -15289,38 +19832,130 @@ const deserializeAws_json1_1AppImageConfigDetails = (output: any, context: __Ser } as any; }; -const deserializeAws_json1_1AppImageConfigList = (output: any, context: __SerdeContext): AppImageConfigDetails[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1AppImageConfigDetails(entry, context)); -}; - -const deserializeAws_json1_1AppList = (output: any, context: __SerdeContext): AppDetails[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1AppDetails(entry, context)); +const deserializeAws_json1_1AppImageConfigList = (output: any, context: __SerdeContext): AppImageConfigDetails[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1AppImageConfigDetails(entry, context)); +}; + +const deserializeAws_json1_1AppList = (output: any, context: __SerdeContext): AppDetails[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1AppDetails(entry, context)); +}; + +const deserializeAws_json1_1AppSpecification = (output: any, context: __SerdeContext): AppSpecification => { + return { + ContainerArguments: + output.ContainerArguments !== undefined && output.ContainerArguments !== null + ? deserializeAws_json1_1ContainerArguments(output.ContainerArguments, context) + : undefined, + ContainerEntrypoint: + output.ContainerEntrypoint !== undefined && output.ContainerEntrypoint !== null + ? deserializeAws_json1_1ContainerEntrypoint(output.ContainerEntrypoint, context) + : undefined, + ImageUri: output.ImageUri !== undefined && output.ImageUri !== null ? output.ImageUri : undefined, + } as any; +}; + +const deserializeAws_json1_1ArtifactSource = (output: any, context: __SerdeContext): ArtifactSource => { + return { + SourceTypes: + output.SourceTypes !== undefined && output.SourceTypes !== null + ? deserializeAws_json1_1ArtifactSourceTypes(output.SourceTypes, context) + : undefined, + SourceUri: output.SourceUri !== undefined && output.SourceUri !== null ? output.SourceUri : undefined, + } as any; +}; + +const deserializeAws_json1_1ArtifactSourceType = (output: any, context: __SerdeContext): ArtifactSourceType => { + return { + SourceIdType: output.SourceIdType !== undefined && output.SourceIdType !== null ? output.SourceIdType : undefined, + Value: output.Value !== undefined && output.Value !== null ? output.Value : undefined, + } as any; +}; + +const deserializeAws_json1_1ArtifactSourceTypes = (output: any, context: __SerdeContext): ArtifactSourceType[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ArtifactSourceType(entry, context)); +}; + +const deserializeAws_json1_1ArtifactSummaries = (output: any, context: __SerdeContext): ArtifactSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ArtifactSummary(entry, context)); +}; + +const deserializeAws_json1_1ArtifactSummary = (output: any, context: __SerdeContext): ArtifactSummary => { + return { + ArtifactArn: output.ArtifactArn !== undefined && output.ArtifactArn !== null ? output.ArtifactArn : undefined, + ArtifactName: output.ArtifactName !== undefined && output.ArtifactName !== null ? output.ArtifactName : undefined, + ArtifactType: output.ArtifactType !== undefined && output.ArtifactType !== null ? output.ArtifactType : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ArtifactSource(output.Source, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1AssociateTrialComponentResponse = ( + output: any, + context: __SerdeContext +): AssociateTrialComponentResponse => { + return { + TrialArn: output.TrialArn !== undefined && output.TrialArn !== null ? output.TrialArn : undefined, + TrialComponentArn: + output.TrialComponentArn !== undefined && output.TrialComponentArn !== null + ? output.TrialComponentArn + : undefined, + } as any; +}; + +const deserializeAws_json1_1AssociationSummaries = (output: any, context: __SerdeContext): AssociationSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1AssociationSummary(entry, context)); }; -const deserializeAws_json1_1AppSpecification = (output: any, context: __SerdeContext): AppSpecification => { +const deserializeAws_json1_1AssociationSummary = (output: any, context: __SerdeContext): AssociationSummary => { return { - ContainerArguments: - output.ContainerArguments !== undefined && output.ContainerArguments !== null - ? deserializeAws_json1_1ContainerArguments(output.ContainerArguments, context) + AssociationType: + output.AssociationType !== undefined && output.AssociationType !== null ? output.AssociationType : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) : undefined, - ContainerEntrypoint: - output.ContainerEntrypoint !== undefined && output.ContainerEntrypoint !== null - ? deserializeAws_json1_1ContainerEntrypoint(output.ContainerEntrypoint, context) + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) : undefined, - ImageUri: output.ImageUri !== undefined && output.ImageUri !== null ? output.ImageUri : undefined, + DestinationArn: + output.DestinationArn !== undefined && output.DestinationArn !== null ? output.DestinationArn : undefined, + DestinationName: + output.DestinationName !== undefined && output.DestinationName !== null ? output.DestinationName : undefined, + DestinationType: + output.DestinationType !== undefined && output.DestinationType !== null ? output.DestinationType : undefined, + SourceArn: output.SourceArn !== undefined && output.SourceArn !== null ? output.SourceArn : undefined, + SourceName: output.SourceName !== undefined && output.SourceName !== null ? output.SourceName : undefined, + SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, } as any; }; -const deserializeAws_json1_1AssociateTrialComponentResponse = ( +const deserializeAws_json1_1AthenaDatasetDefinition = ( output: any, context: __SerdeContext -): AssociateTrialComponentResponse => { +): AthenaDatasetDefinition => { return { - TrialArn: output.TrialArn !== undefined && output.TrialArn !== null ? output.TrialArn : undefined, - TrialComponentArn: - output.TrialComponentArn !== undefined && output.TrialComponentArn !== null - ? output.TrialComponentArn + Catalog: output.Catalog !== undefined && output.Catalog !== null ? output.Catalog : undefined, + Database: output.Database !== undefined && output.Database !== null ? output.Database : undefined, + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + OutputCompression: + output.OutputCompression !== undefined && output.OutputCompression !== null + ? output.OutputCompression : undefined, + OutputFormat: output.OutputFormat !== undefined && output.OutputFormat !== null ? output.OutputFormat : undefined, + OutputS3Uri: output.OutputS3Uri !== undefined && output.OutputS3Uri !== null ? output.OutputS3Uri : undefined, + QueryString: output.QueryString !== undefined && output.QueryString !== null ? output.QueryString : undefined, + WorkGroup: output.WorkGroup !== undefined && output.WorkGroup !== null ? output.WorkGroup : undefined, } as any; }; @@ -15541,10 +20176,61 @@ const deserializeAws_json1_1AutoMLSecurityConfig = (output: any, context: __Serd } as any; }; +const deserializeAws_json1_1AutoRollbackConfig = (output: any, context: __SerdeContext): AutoRollbackConfig => { + return { + Alarms: + output.Alarms !== undefined && output.Alarms !== null + ? deserializeAws_json1_1AlarmList(output.Alarms, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1Bias = (output: any, context: __SerdeContext): Bias => { + return { + Report: + output.Report !== undefined && output.Report !== null + ? deserializeAws_json1_1MetricsSource(output.Report, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1BlueGreenUpdatePolicy = (output: any, context: __SerdeContext): BlueGreenUpdatePolicy => { + return { + MaximumExecutionTimeoutInSeconds: + output.MaximumExecutionTimeoutInSeconds !== undefined && output.MaximumExecutionTimeoutInSeconds !== null + ? output.MaximumExecutionTimeoutInSeconds + : undefined, + TerminationWaitInSeconds: + output.TerminationWaitInSeconds !== undefined && output.TerminationWaitInSeconds !== null + ? output.TerminationWaitInSeconds + : undefined, + TrafficRoutingConfiguration: + output.TrafficRoutingConfiguration !== undefined && output.TrafficRoutingConfiguration !== null + ? deserializeAws_json1_1TrafficRoutingConfig(output.TrafficRoutingConfiguration, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1CacheHitResult = (output: any, context: __SerdeContext): CacheHitResult => { + return { + SourcePipelineExecutionArn: + output.SourcePipelineExecutionArn !== undefined && output.SourcePipelineExecutionArn !== null + ? output.SourcePipelineExecutionArn + : undefined, + } as any; +}; + const deserializeAws_json1_1CandidateSteps = (output: any, context: __SerdeContext): AutoMLCandidateStep[] => { return (output || []).map((entry: any) => deserializeAws_json1_1AutoMLCandidateStep(entry, context)); }; +const deserializeAws_json1_1CapacitySize = (output: any, context: __SerdeContext): CapacitySize => { + return { + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + Value: output.Value !== undefined && output.Value !== null ? output.Value : undefined, + } as any; +}; + const deserializeAws_json1_1CaptureContentTypeHeader = ( output: any, context: __SerdeContext @@ -15804,6 +20490,12 @@ const deserializeAws_json1_1CompressionTypes = (output: any, context: __SerdeCon return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1ConditionStepMetadata = (output: any, context: __SerdeContext): ConditionStepMetadata => { + return { + Outcome: output.Outcome !== undefined && output.Outcome !== null ? output.Outcome : undefined, + } as any; +}; + const deserializeAws_json1_1ConflictException = (output: any, context: __SerdeContext): ConflictException => { return { Message: output.Message !== undefined && output.Message !== null ? output.Message : undefined, @@ -15855,6 +20547,38 @@ const deserializeAws_json1_1ContentTypes = (output: any, context: __SerdeContext return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1ContextSource = (output: any, context: __SerdeContext): ContextSource => { + return { + SourceId: output.SourceId !== undefined && output.SourceId !== null ? output.SourceId : undefined, + SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, + SourceUri: output.SourceUri !== undefined && output.SourceUri !== null ? output.SourceUri : undefined, + } as any; +}; + +const deserializeAws_json1_1ContextSummaries = (output: any, context: __SerdeContext): ContextSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ContextSummary(entry, context)); +}; + +const deserializeAws_json1_1ContextSummary = (output: any, context: __SerdeContext): ContextSummary => { + return { + ContextArn: output.ContextArn !== undefined && output.ContextArn !== null ? output.ContextArn : undefined, + ContextName: output.ContextName !== undefined && output.ContextName !== null ? output.ContextName : undefined, + ContextType: output.ContextType !== undefined && output.ContextType !== null ? output.ContextType : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ContextSource(output.Source, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1ContinuousParameterRange = ( output: any, context: __SerdeContext @@ -15884,6 +20608,12 @@ const deserializeAws_json1_1ContinuousParameterRangeSpecification = ( } as any; }; +const deserializeAws_json1_1CreateActionResponse = (output: any, context: __SerdeContext): CreateActionResponse => { + return { + ActionArn: output.ActionArn !== undefined && output.ActionArn !== null ? output.ActionArn : undefined, + } as any; +}; + const deserializeAws_json1_1CreateAlgorithmOutput = (output: any, context: __SerdeContext): CreateAlgorithmOutput => { return { AlgorithmArn: output.AlgorithmArn !== undefined && output.AlgorithmArn !== null ? output.AlgorithmArn : undefined, @@ -15908,6 +20638,12 @@ const deserializeAws_json1_1CreateAppResponse = (output: any, context: __SerdeCo } as any; }; +const deserializeAws_json1_1CreateArtifactResponse = (output: any, context: __SerdeContext): CreateArtifactResponse => { + return { + ArtifactArn: output.ArtifactArn !== undefined && output.ArtifactArn !== null ? output.ArtifactArn : undefined, + } as any; +}; + const deserializeAws_json1_1CreateAutoMLJobResponse = ( output: any, context: __SerdeContext @@ -15941,6 +20677,12 @@ const deserializeAws_json1_1CreateCompilationJobResponse = ( } as any; }; +const deserializeAws_json1_1CreateContextResponse = (output: any, context: __SerdeContext): CreateContextResponse => { + return { + ContextArn: output.ContextArn !== undefined && output.ContextArn !== null ? output.ContextArn : undefined, + } as any; +}; + const deserializeAws_json1_1CreateDomainResponse = (output: any, context: __SerdeContext): CreateDomainResponse => { return { DomainArn: output.DomainArn !== undefined && output.DomainArn !== null ? output.DomainArn : undefined, @@ -15976,6 +20718,16 @@ const deserializeAws_json1_1CreateExperimentResponse = ( } as any; }; +const deserializeAws_json1_1CreateFeatureGroupResponse = ( + output: any, + context: __SerdeContext +): CreateFeatureGroupResponse => { + return { + FeatureGroupArn: + output.FeatureGroupArn !== undefined && output.FeatureGroupArn !== null ? output.FeatureGroupArn : undefined, + } as any; +}; + const deserializeAws_json1_1CreateFlowDefinitionResponse = ( output: any, context: __SerdeContext @@ -16042,6 +20794,18 @@ const deserializeAws_json1_1CreateModelOutput = (output: any, context: __SerdeCo } as any; }; +const deserializeAws_json1_1CreateModelPackageGroupOutput = ( + output: any, + context: __SerdeContext +): CreateModelPackageGroupOutput => { + return { + ModelPackageGroupArn: + output.ModelPackageGroupArn !== undefined && output.ModelPackageGroupArn !== null + ? output.ModelPackageGroupArn + : undefined, + } as any; +}; + const deserializeAws_json1_1CreateModelPackageOutput = ( output: any, context: __SerdeContext @@ -16088,6 +20852,12 @@ const deserializeAws_json1_1CreateNotebookInstanceOutput = ( } as any; }; +const deserializeAws_json1_1CreatePipelineResponse = (output: any, context: __SerdeContext): CreatePipelineResponse => { + return { + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + } as any; +}; + const deserializeAws_json1_1CreatePresignedDomainUrlResponse = ( output: any, context: __SerdeContext @@ -16118,6 +20888,13 @@ const deserializeAws_json1_1CreateProcessingJobResponse = ( } as any; }; +const deserializeAws_json1_1CreateProjectOutput = (output: any, context: __SerdeContext): CreateProjectOutput => { + return { + ProjectArn: output.ProjectArn !== undefined && output.ProjectArn !== null ? output.ProjectArn : undefined, + ProjectId: output.ProjectId !== undefined && output.ProjectId !== null ? output.ProjectId : undefined, + } as any; +}; + const deserializeAws_json1_1CreateTrainingJobResponse = ( output: any, context: __SerdeContext @@ -16244,6 +21021,14 @@ const deserializeAws_json1_1DataCaptureConfigSummary = ( } as any; }; +const deserializeAws_json1_1DataCatalogConfig = (output: any, context: __SerdeContext): DataCatalogConfig => { + return { + Catalog: output.Catalog !== undefined && output.Catalog !== null ? output.Catalog : undefined, + Database: output.Database !== undefined && output.Database !== null ? output.Database : undefined, + TableName: output.TableName !== undefined && output.TableName !== null ? output.TableName : undefined, + } as any; +}; + const deserializeAws_json1_1DataProcessing = (output: any, context: __SerdeContext): DataProcessing => { return { InputFilter: output.InputFilter !== undefined && output.InputFilter !== null ? output.InputFilter : undefined, @@ -16252,6 +21037,25 @@ const deserializeAws_json1_1DataProcessing = (output: any, context: __SerdeConte } as any; }; +const deserializeAws_json1_1DatasetDefinition = (output: any, context: __SerdeContext): DatasetDefinition => { + return { + AthenaDatasetDefinition: + output.AthenaDatasetDefinition !== undefined && output.AthenaDatasetDefinition !== null + ? deserializeAws_json1_1AthenaDatasetDefinition(output.AthenaDatasetDefinition, context) + : undefined, + DataDistributionType: + output.DataDistributionType !== undefined && output.DataDistributionType !== null + ? output.DataDistributionType + : undefined, + InputMode: output.InputMode !== undefined && output.InputMode !== null ? output.InputMode : undefined, + LocalPath: output.LocalPath !== undefined && output.LocalPath !== null ? output.LocalPath : undefined, + RedshiftDatasetDefinition: + output.RedshiftDatasetDefinition !== undefined && output.RedshiftDatasetDefinition !== null + ? deserializeAws_json1_1RedshiftDatasetDefinition(output.RedshiftDatasetDefinition, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1DataSource = (output: any, context: __SerdeContext): DataSource => { return { FileSystemDataSource: @@ -16342,6 +21146,35 @@ const deserializeAws_json1_1DebugRuleEvaluationStatuses = ( return (output || []).map((entry: any) => deserializeAws_json1_1DebugRuleEvaluationStatus(entry, context)); }; +const deserializeAws_json1_1DeleteActionResponse = (output: any, context: __SerdeContext): DeleteActionResponse => { + return { + ActionArn: output.ActionArn !== undefined && output.ActionArn !== null ? output.ActionArn : undefined, + } as any; +}; + +const deserializeAws_json1_1DeleteArtifactResponse = (output: any, context: __SerdeContext): DeleteArtifactResponse => { + return { + ArtifactArn: output.ArtifactArn !== undefined && output.ArtifactArn !== null ? output.ArtifactArn : undefined, + } as any; +}; + +const deserializeAws_json1_1DeleteAssociationResponse = ( + output: any, + context: __SerdeContext +): DeleteAssociationResponse => { + return { + DestinationArn: + output.DestinationArn !== undefined && output.DestinationArn !== null ? output.DestinationArn : undefined, + SourceArn: output.SourceArn !== undefined && output.SourceArn !== null ? output.SourceArn : undefined, + } as any; +}; + +const deserializeAws_json1_1DeleteContextResponse = (output: any, context: __SerdeContext): DeleteContextResponse => { + return { + ContextArn: output.ContextArn !== undefined && output.ContextArn !== null ? output.ContextArn : undefined, + } as any; +}; + const deserializeAws_json1_1DeleteExperimentResponse = ( output: any, context: __SerdeContext @@ -16377,6 +21210,12 @@ const deserializeAws_json1_1DeleteImageVersionResponse = ( return {} as any; }; +const deserializeAws_json1_1DeletePipelineResponse = (output: any, context: __SerdeContext): DeletePipelineResponse => { + return { + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + } as any; +}; + const deserializeAws_json1_1DeleteTagsOutput = (output: any, context: __SerdeContext): DeleteTagsOutput => { return {} as any; }; @@ -16429,6 +21268,57 @@ const deserializeAws_json1_1DeployedImages = (output: any, context: __SerdeConte return (output || []).map((entry: any) => deserializeAws_json1_1DeployedImage(entry, context)); }; +const deserializeAws_json1_1DeploymentConfig = (output: any, context: __SerdeContext): DeploymentConfig => { + return { + AutoRollbackConfiguration: + output.AutoRollbackConfiguration !== undefined && output.AutoRollbackConfiguration !== null + ? deserializeAws_json1_1AutoRollbackConfig(output.AutoRollbackConfiguration, context) + : undefined, + BlueGreenUpdatePolicy: + output.BlueGreenUpdatePolicy !== undefined && output.BlueGreenUpdatePolicy !== null + ? deserializeAws_json1_1BlueGreenUpdatePolicy(output.BlueGreenUpdatePolicy, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeActionResponse = (output: any, context: __SerdeContext): DescribeActionResponse => { + return { + ActionArn: output.ActionArn !== undefined && output.ActionArn !== null ? output.ActionArn : undefined, + ActionName: output.ActionName !== undefined && output.ActionName !== null ? output.ActionName : undefined, + ActionType: output.ActionType !== undefined && output.ActionType !== null ? output.ActionType : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, + Properties: + output.Properties !== undefined && output.Properties !== null + ? deserializeAws_json1_1LineageEntityParameters(output.Properties, context) + : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ActionSource(output.Source, context) + : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeAlgorithmOutput = ( output: any, context: __SerdeContext @@ -16529,6 +21419,45 @@ const deserializeAws_json1_1DescribeAppResponse = (output: any, context: __Serde } as any; }; +const deserializeAws_json1_1DescribeArtifactResponse = ( + output: any, + context: __SerdeContext +): DescribeArtifactResponse => { + return { + ArtifactArn: output.ArtifactArn !== undefined && output.ArtifactArn !== null ? output.ArtifactArn : undefined, + ArtifactName: output.ArtifactName !== undefined && output.ArtifactName !== null ? output.ArtifactName : undefined, + ArtifactType: output.ArtifactType !== undefined && output.ArtifactType !== null ? output.ArtifactType : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, + Properties: + output.Properties !== undefined && output.Properties !== null + ? deserializeAws_json1_1LineageEntityParameters(output.Properties, context) + : undefined, + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ArtifactSource(output.Source, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeAutoMLJobResponse = ( output: any, context: __SerdeContext @@ -16659,18 +21588,58 @@ const deserializeAws_json1_1DescribeCompilationJobResponse = ( output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) : undefined, - ModelArtifacts: - output.ModelArtifacts !== undefined && output.ModelArtifacts !== null - ? deserializeAws_json1_1ModelArtifacts(output.ModelArtifacts, context) - : undefined, - OutputConfig: - output.OutputConfig !== undefined && output.OutputConfig !== null - ? deserializeAws_json1_1OutputConfig(output.OutputConfig, context) + ModelArtifacts: + output.ModelArtifacts !== undefined && output.ModelArtifacts !== null + ? deserializeAws_json1_1ModelArtifacts(output.ModelArtifacts, context) + : undefined, + ModelDigests: + output.ModelDigests !== undefined && output.ModelDigests !== null + ? deserializeAws_json1_1ModelDigests(output.ModelDigests, context) + : undefined, + OutputConfig: + output.OutputConfig !== undefined && output.OutputConfig !== null + ? deserializeAws_json1_1OutputConfig(output.OutputConfig, context) + : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + StoppingCondition: + output.StoppingCondition !== undefined && output.StoppingCondition !== null + ? deserializeAws_json1_1StoppingCondition(output.StoppingCondition, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribeContextResponse = ( + output: any, + context: __SerdeContext +): DescribeContextResponse => { + return { + ContextArn: output.ContextArn !== undefined && output.ContextArn !== null ? output.ContextArn : undefined, + ContextName: output.ContextName !== undefined && output.ContextName !== null ? output.ContextName : undefined, + ContextType: output.ContextType !== undefined && output.ContextType !== null ? output.ContextType : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + Properties: + output.Properties !== undefined && output.Properties !== null + ? deserializeAws_json1_1LineageEntityParameters(output.Properties, context) : undefined, - RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, - StoppingCondition: - output.StoppingCondition !== undefined && output.StoppingCondition !== null - ? deserializeAws_json1_1StoppingCondition(output.StoppingCondition, context) + Source: + output.Source !== undefined && output.Source !== null + ? deserializeAws_json1_1ContextSource(output.Source, context) : undefined, } as any; }; @@ -16772,6 +21741,10 @@ const deserializeAws_json1_1DescribeEndpointOutput = (output: any, context: __Se output.EndpointStatus !== undefined && output.EndpointStatus !== null ? output.EndpointStatus : undefined, FailureReason: output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + LastDeploymentConfig: + output.LastDeploymentConfig !== undefined && output.LastDeploymentConfig !== null + ? deserializeAws_json1_1DeploymentConfig(output.LastDeploymentConfig, context) + : undefined, LastModifiedTime: output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) @@ -16817,6 +21790,55 @@ const deserializeAws_json1_1DescribeExperimentResponse = ( } as any; }; +const deserializeAws_json1_1DescribeFeatureGroupResponse = ( + output: any, + context: __SerdeContext +): DescribeFeatureGroupResponse => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + EventTimeFeatureName: + output.EventTimeFeatureName !== undefined && output.EventTimeFeatureName !== null + ? output.EventTimeFeatureName + : undefined, + FailureReason: + output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + FeatureDefinitions: + output.FeatureDefinitions !== undefined && output.FeatureDefinitions !== null + ? deserializeAws_json1_1FeatureDefinitions(output.FeatureDefinitions, context) + : undefined, + FeatureGroupArn: + output.FeatureGroupArn !== undefined && output.FeatureGroupArn !== null ? output.FeatureGroupArn : undefined, + FeatureGroupName: + output.FeatureGroupName !== undefined && output.FeatureGroupName !== null ? output.FeatureGroupName : undefined, + FeatureGroupStatus: + output.FeatureGroupStatus !== undefined && output.FeatureGroupStatus !== null + ? output.FeatureGroupStatus + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + OfflineStoreConfig: + output.OfflineStoreConfig !== undefined && output.OfflineStoreConfig !== null + ? deserializeAws_json1_1OfflineStoreConfig(output.OfflineStoreConfig, context) + : undefined, + OfflineStoreStatus: + output.OfflineStoreStatus !== undefined && output.OfflineStoreStatus !== null + ? deserializeAws_json1_1OfflineStoreStatus(output.OfflineStoreStatus, context) + : undefined, + OnlineStoreConfig: + output.OnlineStoreConfig !== undefined && output.OnlineStoreConfig !== null + ? deserializeAws_json1_1OnlineStoreConfig(output.OnlineStoreConfig, context) + : undefined, + RecordIdentifierFeatureName: + output.RecordIdentifierFeatureName !== undefined && output.RecordIdentifierFeatureName !== null + ? output.RecordIdentifierFeatureName + : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeFlowDefinitionResponse = ( output: any, context: __SerdeContext @@ -17098,15 +22120,55 @@ const deserializeAws_json1_1DescribeModelOutput = (output: any, context: __Serde } as any; }; +const deserializeAws_json1_1DescribeModelPackageGroupOutput = ( + output: any, + context: __SerdeContext +): DescribeModelPackageGroupOutput => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + ModelPackageGroupArn: + output.ModelPackageGroupArn !== undefined && output.ModelPackageGroupArn !== null + ? output.ModelPackageGroupArn + : undefined, + ModelPackageGroupDescription: + output.ModelPackageGroupDescription !== undefined && output.ModelPackageGroupDescription !== null + ? output.ModelPackageGroupDescription + : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, + ModelPackageGroupStatus: + output.ModelPackageGroupStatus !== undefined && output.ModelPackageGroupStatus !== null + ? output.ModelPackageGroupStatus + : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeModelPackageOutput = ( output: any, context: __SerdeContext ): DescribeModelPackageOutput => { return { + ApprovalDescription: + output.ApprovalDescription !== undefined && output.ApprovalDescription !== null + ? output.ApprovalDescription + : undefined, CertifyForMarketplace: output.CertifyForMarketplace !== undefined && output.CertifyForMarketplace !== null ? output.CertifyForMarketplace : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, CreationTime: output.CreationTime !== undefined && output.CreationTime !== null ? new Date(Math.round(output.CreationTime * 1000)) @@ -17115,12 +22177,36 @@ const deserializeAws_json1_1DescribeModelPackageOutput = ( output.InferenceSpecification !== undefined && output.InferenceSpecification !== null ? deserializeAws_json1_1InferenceSpecification(output.InferenceSpecification, context) : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, + ModelApprovalStatus: + output.ModelApprovalStatus !== undefined && output.ModelApprovalStatus !== null + ? output.ModelApprovalStatus + : undefined, + ModelMetrics: + output.ModelMetrics !== undefined && output.ModelMetrics !== null + ? deserializeAws_json1_1ModelMetrics(output.ModelMetrics, context) + : undefined, ModelPackageArn: output.ModelPackageArn !== undefined && output.ModelPackageArn !== null ? output.ModelPackageArn : undefined, ModelPackageDescription: output.ModelPackageDescription !== undefined && output.ModelPackageDescription !== null ? output.ModelPackageDescription : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, ModelPackageName: output.ModelPackageName !== undefined && output.ModelPackageName !== null ? output.ModelPackageName : undefined, ModelPackageStatus: @@ -17131,6 +22217,10 @@ const deserializeAws_json1_1DescribeModelPackageOutput = ( output.ModelPackageStatusDetails !== undefined && output.ModelPackageStatusDetails !== null ? deserializeAws_json1_1ModelPackageStatusDetails(output.ModelPackageStatusDetails, context) : undefined, + ModelPackageVersion: + output.ModelPackageVersion !== undefined && output.ModelPackageVersion !== null + ? output.ModelPackageVersion + : undefined, SourceAlgorithmSpecification: output.SourceAlgorithmSpecification !== undefined && output.SourceAlgorithmSpecification !== null ? deserializeAws_json1_1SourceAlgorithmSpecification(output.SourceAlgorithmSpecification, context) @@ -17279,6 +22369,108 @@ const deserializeAws_json1_1DescribeNotebookInstanceOutput = ( } as any; }; +const deserializeAws_json1_1DescribePipelineDefinitionForExecutionResponse = ( + output: any, + context: __SerdeContext +): DescribePipelineDefinitionForExecutionResponse => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + PipelineDefinition: + output.PipelineDefinition !== undefined && output.PipelineDefinition !== null + ? output.PipelineDefinition + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribePipelineExecutionResponse = ( + output: any, + context: __SerdeContext +): DescribePipelineExecutionResponse => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + PipelineExecutionDescription: + output.PipelineExecutionDescription !== undefined && output.PipelineExecutionDescription !== null + ? output.PipelineExecutionDescription + : undefined, + PipelineExecutionDisplayName: + output.PipelineExecutionDisplayName !== undefined && output.PipelineExecutionDisplayName !== null + ? output.PipelineExecutionDisplayName + : undefined, + PipelineExecutionStatus: + output.PipelineExecutionStatus !== undefined && output.PipelineExecutionStatus !== null + ? output.PipelineExecutionStatus + : undefined, + } as any; +}; + +const deserializeAws_json1_1DescribePipelineResponse = ( + output: any, + context: __SerdeContext +): DescribePipelineResponse => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + LastRunTime: + output.LastRunTime !== undefined && output.LastRunTime !== null + ? new Date(Math.round(output.LastRunTime * 1000)) + : undefined, + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + PipelineDefinition: + output.PipelineDefinition !== undefined && output.PipelineDefinition !== null + ? output.PipelineDefinition + : undefined, + PipelineDescription: + output.PipelineDescription !== undefined && output.PipelineDescription !== null + ? output.PipelineDescription + : undefined, + PipelineDisplayName: + output.PipelineDisplayName !== undefined && output.PipelineDisplayName !== null + ? output.PipelineDisplayName + : undefined, + PipelineName: output.PipelineName !== undefined && output.PipelineName !== null ? output.PipelineName : undefined, + PipelineStatus: + output.PipelineStatus !== undefined && output.PipelineStatus !== null ? output.PipelineStatus : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeProcessingJobResponse = ( output: any, context: __SerdeContext @@ -17356,6 +22548,40 @@ const deserializeAws_json1_1DescribeProcessingJobResponse = ( } as any; }; +const deserializeAws_json1_1DescribeProjectOutput = (output: any, context: __SerdeContext): DescribeProjectOutput => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + ProjectArn: output.ProjectArn !== undefined && output.ProjectArn !== null ? output.ProjectArn : undefined, + ProjectDescription: + output.ProjectDescription !== undefined && output.ProjectDescription !== null + ? output.ProjectDescription + : undefined, + ProjectId: output.ProjectId !== undefined && output.ProjectId !== null ? output.ProjectId : undefined, + ProjectName: output.ProjectName !== undefined && output.ProjectName !== null ? output.ProjectName : undefined, + ProjectStatus: + output.ProjectStatus !== undefined && output.ProjectStatus !== null ? output.ProjectStatus : undefined, + ServiceCatalogProvisionedProductDetails: + output.ServiceCatalogProvisionedProductDetails !== undefined && + output.ServiceCatalogProvisionedProductDetails !== null + ? deserializeAws_json1_1ServiceCatalogProvisionedProductDetails( + output.ServiceCatalogProvisionedProductDetails, + context + ) + : undefined, + ServiceCatalogProvisioningDetails: + output.ServiceCatalogProvisioningDetails !== undefined && output.ServiceCatalogProvisioningDetails !== null + ? deserializeAws_json1_1ServiceCatalogProvisioningDetails(output.ServiceCatalogProvisioningDetails, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1DescribeSubscribedWorkteamResponse = ( output: any, context: __SerdeContext @@ -17592,6 +22818,10 @@ const deserializeAws_json1_1DescribeTrialComponentResponse = ( output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, Metrics: output.Metrics !== undefined && output.Metrics !== null ? deserializeAws_json1_1TrialComponentMetricSummaries(output.Metrics, context) @@ -17648,6 +22878,10 @@ const deserializeAws_json1_1DescribeTrialResponse = (output: any, context: __Ser output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, Source: output.Source !== undefined && output.Source !== null ? deserializeAws_json1_1TrialSource(output.Source, context) @@ -17721,6 +22955,13 @@ const deserializeAws_json1_1DescribeWorkteamResponse = ( } as any; }; +const deserializeAws_json1_1DisableSagemakerServicecatalogPortfolioOutput = ( + output: any, + context: __SerdeContext +): DisableSagemakerServicecatalogPortfolioOutput => { + return {} as any; +}; + const deserializeAws_json1_1DisassociateTrialComponentResponse = ( output: any, context: __SerdeContext @@ -17756,6 +22997,52 @@ const deserializeAws_json1_1DomainList = (output: any, context: __SerdeContext): return (output || []).map((entry: any) => deserializeAws_json1_1DomainDetails(entry, context)); }; +const deserializeAws_json1_1EnableSagemakerServicecatalogPortfolioOutput = ( + output: any, + context: __SerdeContext +): EnableSagemakerServicecatalogPortfolioOutput => { + return {} as any; +}; + +const deserializeAws_json1_1Endpoint = (output: any, context: __SerdeContext): Endpoint => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + DataCaptureConfig: + output.DataCaptureConfig !== undefined && output.DataCaptureConfig !== null + ? deserializeAws_json1_1DataCaptureConfigSummary(output.DataCaptureConfig, context) + : undefined, + EndpointArn: output.EndpointArn !== undefined && output.EndpointArn !== null ? output.EndpointArn : undefined, + EndpointConfigName: + output.EndpointConfigName !== undefined && output.EndpointConfigName !== null + ? output.EndpointConfigName + : undefined, + EndpointName: output.EndpointName !== undefined && output.EndpointName !== null ? output.EndpointName : undefined, + EndpointStatus: + output.EndpointStatus !== undefined && output.EndpointStatus !== null ? output.EndpointStatus : undefined, + FailureReason: + output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + MonitoringSchedules: + output.MonitoringSchedules !== undefined && output.MonitoringSchedules !== null + ? deserializeAws_json1_1MonitoringScheduleList(output.MonitoringSchedules, context) + : undefined, + ProductionVariants: + output.ProductionVariants !== undefined && output.ProductionVariants !== null + ? deserializeAws_json1_1ProductionVariantSummaryList(output.ProductionVariants, context) + : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1EndpointConfigSummary = (output: any, context: __SerdeContext): EndpointConfigSummary => { return { CreationTime: @@ -17866,39 +23153,133 @@ const deserializeAws_json1_1ExperimentConfig = (output: any, context: __SerdeCon output.TrialComponentDisplayName !== undefined && output.TrialComponentDisplayName !== null ? output.TrialComponentDisplayName : undefined, - TrialName: output.TrialName !== undefined && output.TrialName !== null ? output.TrialName : undefined, - } as any; -}; - -const deserializeAws_json1_1ExperimentSource = (output: any, context: __SerdeContext): ExperimentSource => { - return { - SourceArn: output.SourceArn !== undefined && output.SourceArn !== null ? output.SourceArn : undefined, - SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, + TrialName: output.TrialName !== undefined && output.TrialName !== null ? output.TrialName : undefined, + } as any; +}; + +const deserializeAws_json1_1ExperimentSource = (output: any, context: __SerdeContext): ExperimentSource => { + return { + SourceArn: output.SourceArn !== undefined && output.SourceArn !== null ? output.SourceArn : undefined, + SourceType: output.SourceType !== undefined && output.SourceType !== null ? output.SourceType : undefined, + } as any; +}; + +const deserializeAws_json1_1ExperimentSummaries = (output: any, context: __SerdeContext): ExperimentSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ExperimentSummary(entry, context)); +}; + +const deserializeAws_json1_1ExperimentSummary = (output: any, context: __SerdeContext): ExperimentSummary => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + DisplayName: output.DisplayName !== undefined && output.DisplayName !== null ? output.DisplayName : undefined, + ExperimentArn: + output.ExperimentArn !== undefined && output.ExperimentArn !== null ? output.ExperimentArn : undefined, + ExperimentName: + output.ExperimentName !== undefined && output.ExperimentName !== null ? output.ExperimentName : undefined, + ExperimentSource: + output.ExperimentSource !== undefined && output.ExperimentSource !== null + ? deserializeAws_json1_1ExperimentSource(output.ExperimentSource, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + } as any; +}; + +const deserializeAws_json1_1Explainability = (output: any, context: __SerdeContext): Explainability => { + return { + Report: + output.Report !== undefined && output.Report !== null + ? deserializeAws_json1_1MetricsSource(output.Report, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1FeatureDefinition = (output: any, context: __SerdeContext): FeatureDefinition => { + return { + FeatureName: output.FeatureName !== undefined && output.FeatureName !== null ? output.FeatureName : undefined, + FeatureType: output.FeatureType !== undefined && output.FeatureType !== null ? output.FeatureType : undefined, + } as any; +}; + +const deserializeAws_json1_1FeatureDefinitions = (output: any, context: __SerdeContext): FeatureDefinition[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1FeatureDefinition(entry, context)); +}; + +const deserializeAws_json1_1FeatureGroup = (output: any, context: __SerdeContext): FeatureGroup => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + Description: output.Description !== undefined && output.Description !== null ? output.Description : undefined, + EventTimeFeatureName: + output.EventTimeFeatureName !== undefined && output.EventTimeFeatureName !== null + ? output.EventTimeFeatureName + : undefined, + FailureReason: + output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + FeatureDefinitions: + output.FeatureDefinitions !== undefined && output.FeatureDefinitions !== null + ? deserializeAws_json1_1FeatureDefinitions(output.FeatureDefinitions, context) + : undefined, + FeatureGroupArn: + output.FeatureGroupArn !== undefined && output.FeatureGroupArn !== null ? output.FeatureGroupArn : undefined, + FeatureGroupName: + output.FeatureGroupName !== undefined && output.FeatureGroupName !== null ? output.FeatureGroupName : undefined, + FeatureGroupStatus: + output.FeatureGroupStatus !== undefined && output.FeatureGroupStatus !== null + ? output.FeatureGroupStatus + : undefined, + OfflineStoreConfig: + output.OfflineStoreConfig !== undefined && output.OfflineStoreConfig !== null + ? deserializeAws_json1_1OfflineStoreConfig(output.OfflineStoreConfig, context) + : undefined, + OfflineStoreStatus: + output.OfflineStoreStatus !== undefined && output.OfflineStoreStatus !== null + ? deserializeAws_json1_1OfflineStoreStatus(output.OfflineStoreStatus, context) + : undefined, + OnlineStoreConfig: + output.OnlineStoreConfig !== undefined && output.OnlineStoreConfig !== null + ? deserializeAws_json1_1OnlineStoreConfig(output.OnlineStoreConfig, context) + : undefined, + RecordIdentifierFeatureName: + output.RecordIdentifierFeatureName !== undefined && output.RecordIdentifierFeatureName !== null + ? output.RecordIdentifierFeatureName + : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) + : undefined, } as any; }; -const deserializeAws_json1_1ExperimentSummaries = (output: any, context: __SerdeContext): ExperimentSummary[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1ExperimentSummary(entry, context)); +const deserializeAws_json1_1FeatureGroupSummaries = (output: any, context: __SerdeContext): FeatureGroupSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1FeatureGroupSummary(entry, context)); }; -const deserializeAws_json1_1ExperimentSummary = (output: any, context: __SerdeContext): ExperimentSummary => { +const deserializeAws_json1_1FeatureGroupSummary = (output: any, context: __SerdeContext): FeatureGroupSummary => { return { CreationTime: output.CreationTime !== undefined && output.CreationTime !== null ? new Date(Math.round(output.CreationTime * 1000)) : undefined, - DisplayName: output.DisplayName !== undefined && output.DisplayName !== null ? output.DisplayName : undefined, - ExperimentArn: - output.ExperimentArn !== undefined && output.ExperimentArn !== null ? output.ExperimentArn : undefined, - ExperimentName: - output.ExperimentName !== undefined && output.ExperimentName !== null ? output.ExperimentName : undefined, - ExperimentSource: - output.ExperimentSource !== undefined && output.ExperimentSource !== null - ? deserializeAws_json1_1ExperimentSource(output.ExperimentSource, context) + FeatureGroupArn: + output.FeatureGroupArn !== undefined && output.FeatureGroupArn !== null ? output.FeatureGroupArn : undefined, + FeatureGroupName: + output.FeatureGroupName !== undefined && output.FeatureGroupName !== null ? output.FeatureGroupName : undefined, + FeatureGroupStatus: + output.FeatureGroupStatus !== undefined && output.FeatureGroupStatus !== null + ? output.FeatureGroupStatus : undefined, - LastModifiedTime: - output.LastModifiedTime !== undefined && output.LastModifiedTime !== null - ? new Date(Math.round(output.LastModifiedTime * 1000)) + OfflineStoreStatus: + output.OfflineStoreStatus !== undefined && output.OfflineStoreStatus !== null + ? deserializeAws_json1_1OfflineStoreStatus(output.OfflineStoreStatus, context) : undefined, } as any; }; @@ -17995,6 +23376,25 @@ const deserializeAws_json1_1FlowDefinitionTaskKeywords = (output: any, context: return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1GetModelPackageGroupPolicyOutput = ( + output: any, + context: __SerdeContext +): GetModelPackageGroupPolicyOutput => { + return { + ResourcePolicy: + output.ResourcePolicy !== undefined && output.ResourcePolicy !== null ? output.ResourcePolicy : undefined, + } as any; +}; + +const deserializeAws_json1_1GetSagemakerServicecatalogPortfolioStatusOutput = ( + output: any, + context: __SerdeContext +): GetSagemakerServicecatalogPortfolioStatusOutput => { + return { + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + const deserializeAws_json1_1GetSearchSuggestionsResponse = ( output: any, context: __SerdeContext @@ -18871,6 +24271,29 @@ const deserializeAws_json1_1LabelingJobSummaryList = (output: any, context: __Se return (output || []).map((entry: any) => deserializeAws_json1_1LabelingJobSummary(entry, context)); }; +const deserializeAws_json1_1LineageEntityParameters = ( + output: any, + context: __SerdeContext +): { [key: string]: string } => { + return Object.entries(output).reduce( + (acc: { [key: string]: string }, [key, value]: [string, any]) => ({ + ...acc, + [key]: value, + }), + {} + ); +}; + +const deserializeAws_json1_1ListActionsResponse = (output: any, context: __SerdeContext): ListActionsResponse => { + return { + ActionSummaries: + output.ActionSummaries !== undefined && output.ActionSummaries !== null + ? deserializeAws_json1_1ActionSummaries(output.ActionSummaries, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + const deserializeAws_json1_1ListAlgorithmsOutput = (output: any, context: __SerdeContext): ListAlgorithmsOutput => { return { AlgorithmSummaryList: @@ -18904,6 +24327,29 @@ const deserializeAws_json1_1ListAppsResponse = (output: any, context: __SerdeCon } as any; }; +const deserializeAws_json1_1ListArtifactsResponse = (output: any, context: __SerdeContext): ListArtifactsResponse => { + return { + ArtifactSummaries: + output.ArtifactSummaries !== undefined && output.ArtifactSummaries !== null + ? deserializeAws_json1_1ArtifactSummaries(output.ArtifactSummaries, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + +const deserializeAws_json1_1ListAssociationsResponse = ( + output: any, + context: __SerdeContext +): ListAssociationsResponse => { + return { + AssociationSummaries: + output.AssociationSummaries !== undefined && output.AssociationSummaries !== null + ? deserializeAws_json1_1AssociationSummaries(output.AssociationSummaries, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + const deserializeAws_json1_1ListAutoMLJobsResponse = (output: any, context: __SerdeContext): ListAutoMLJobsResponse => { return { AutoMLJobSummaries: @@ -18953,6 +24399,16 @@ const deserializeAws_json1_1ListCompilationJobsResponse = ( } as any; }; +const deserializeAws_json1_1ListContextsResponse = (output: any, context: __SerdeContext): ListContextsResponse => { + return { + ContextSummaries: + output.ContextSummaries !== undefined && output.ContextSummaries !== null + ? deserializeAws_json1_1ContextSummaries(output.ContextSummaries, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + const deserializeAws_json1_1ListDomainsResponse = (output: any, context: __SerdeContext): ListDomainsResponse => { return { Domains: @@ -18999,6 +24455,19 @@ const deserializeAws_json1_1ListExperimentsResponse = ( } as any; }; +const deserializeAws_json1_1ListFeatureGroupsResponse = ( + output: any, + context: __SerdeContext +): ListFeatureGroupsResponse => { + return { + FeatureGroupSummaries: + output.FeatureGroupSummaries !== undefined && output.FeatureGroupSummaries !== null + ? deserializeAws_json1_1FeatureGroupSummaries(output.FeatureGroupSummaries, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + const deserializeAws_json1_1ListFlowDefinitionsResponse = ( output: any, context: __SerdeContext @@ -19087,6 +24556,19 @@ const deserializeAws_json1_1ListLabelingJobsResponse = ( } as any; }; +const deserializeAws_json1_1ListModelPackageGroupsOutput = ( + output: any, + context: __SerdeContext +): ListModelPackageGroupsOutput => { + return { + ModelPackageGroupSummaryList: + output.ModelPackageGroupSummaryList !== undefined && output.ModelPackageGroupSummaryList !== null + ? deserializeAws_json1_1ModelPackageGroupSummaryList(output.ModelPackageGroupSummaryList, context) + : undefined, + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + } as any; +}; + const deserializeAws_json1_1ListModelPackagesOutput = ( output: any, context: __SerdeContext @@ -19165,6 +24647,55 @@ const deserializeAws_json1_1ListNotebookInstancesOutput = ( } as any; }; +const deserializeAws_json1_1ListPipelineExecutionsResponse = ( + output: any, + context: __SerdeContext +): ListPipelineExecutionsResponse => { + return { + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + PipelineExecutionSummaries: + output.PipelineExecutionSummaries !== undefined && output.PipelineExecutionSummaries !== null + ? deserializeAws_json1_1PipelineExecutionSummaryList(output.PipelineExecutionSummaries, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ListPipelineExecutionStepsResponse = ( + output: any, + context: __SerdeContext +): ListPipelineExecutionStepsResponse => { + return { + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + PipelineExecutionSteps: + output.PipelineExecutionSteps !== undefined && output.PipelineExecutionSteps !== null + ? deserializeAws_json1_1PipelineExecutionStepList(output.PipelineExecutionSteps, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ListPipelineParametersForExecutionResponse = ( + output: any, + context: __SerdeContext +): ListPipelineParametersForExecutionResponse => { + return { + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + PipelineParameters: + output.PipelineParameters !== undefined && output.PipelineParameters !== null + ? deserializeAws_json1_1ParameterList(output.PipelineParameters, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ListPipelinesResponse = (output: any, context: __SerdeContext): ListPipelinesResponse => { + return { + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + PipelineSummaries: + output.PipelineSummaries !== undefined && output.PipelineSummaries !== null + ? deserializeAws_json1_1PipelineSummaryList(output.PipelineSummaries, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1ListProcessingJobsResponse = ( output: any, context: __SerdeContext @@ -19178,6 +24709,16 @@ const deserializeAws_json1_1ListProcessingJobsResponse = ( } as any; }; +const deserializeAws_json1_1ListProjectsOutput = (output: any, context: __SerdeContext): ListProjectsOutput => { + return { + NextToken: output.NextToken !== undefined && output.NextToken !== null ? output.NextToken : undefined, + ProjectSummaryList: + output.ProjectSummaryList !== undefined && output.ProjectSummaryList !== null + ? deserializeAws_json1_1ProjectSummaryList(output.ProjectSummaryList, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1ListSubscribedWorkteamsResponse = ( output: any, context: __SerdeContext @@ -19313,6 +24854,15 @@ const deserializeAws_json1_1MemberDefinitions = (output: any, context: __SerdeCo return (output || []).map((entry: any) => deserializeAws_json1_1MemberDefinition(entry, context)); }; +const deserializeAws_json1_1MetadataProperties = (output: any, context: __SerdeContext): MetadataProperties => { + return { + CommitId: output.CommitId !== undefined && output.CommitId !== null ? output.CommitId : undefined, + GeneratedBy: output.GeneratedBy !== undefined && output.GeneratedBy !== null ? output.GeneratedBy : undefined, + ProjectId: output.ProjectId !== undefined && output.ProjectId !== null ? output.ProjectId : undefined, + Repository: output.Repository !== undefined && output.Repository !== null ? output.Repository : undefined, + } as any; +}; + const deserializeAws_json1_1MetricData = (output: any, context: __SerdeContext): MetricData => { return { MetricName: output.MetricName !== undefined && output.MetricName !== null ? output.MetricName : undefined, @@ -19335,6 +24885,15 @@ const deserializeAws_json1_1MetricDefinitionList = (output: any, context: __Serd return (output || []).map((entry: any) => deserializeAws_json1_1MetricDefinition(entry, context)); }; +const deserializeAws_json1_1MetricsSource = (output: any, context: __SerdeContext): MetricsSource => { + return { + ContentDigest: + output.ContentDigest !== undefined && output.ContentDigest !== null ? output.ContentDigest : undefined, + ContentType: output.ContentType !== undefined && output.ContentType !== null ? output.ContentType : undefined, + S3Uri: output.S3Uri !== undefined && output.S3Uri !== null ? output.S3Uri : undefined, + } as any; +}; + const deserializeAws_json1_1ModelArtifacts = (output: any, context: __SerdeContext): ModelArtifacts => { return { S3ModelArtifacts: @@ -19348,34 +24907,222 @@ const deserializeAws_json1_1ModelClientConfig = (output: any, context: __SerdeCo output.InvocationsMaxRetries !== undefined && output.InvocationsMaxRetries !== null ? output.InvocationsMaxRetries : undefined, - InvocationsTimeoutInSeconds: - output.InvocationsTimeoutInSeconds !== undefined && output.InvocationsTimeoutInSeconds !== null - ? output.InvocationsTimeoutInSeconds + InvocationsTimeoutInSeconds: + output.InvocationsTimeoutInSeconds !== undefined && output.InvocationsTimeoutInSeconds !== null + ? output.InvocationsTimeoutInSeconds + : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelDataQuality = (output: any, context: __SerdeContext): ModelDataQuality => { + return { + Constraints: + output.Constraints !== undefined && output.Constraints !== null + ? deserializeAws_json1_1MetricsSource(output.Constraints, context) + : undefined, + Statistics: + output.Statistics !== undefined && output.Statistics !== null + ? deserializeAws_json1_1MetricsSource(output.Statistics, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelDigests = (output: any, context: __SerdeContext): ModelDigests => { + return { + ArtifactDigest: + output.ArtifactDigest !== undefined && output.ArtifactDigest !== null ? output.ArtifactDigest : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelMetrics = (output: any, context: __SerdeContext): ModelMetrics => { + return { + Bias: + output.Bias !== undefined && output.Bias !== null ? deserializeAws_json1_1Bias(output.Bias, context) : undefined, + Explainability: + output.Explainability !== undefined && output.Explainability !== null + ? deserializeAws_json1_1Explainability(output.Explainability, context) + : undefined, + ModelDataQuality: + output.ModelDataQuality !== undefined && output.ModelDataQuality !== null + ? deserializeAws_json1_1ModelDataQuality(output.ModelDataQuality, context) + : undefined, + ModelQuality: + output.ModelQuality !== undefined && output.ModelQuality !== null + ? deserializeAws_json1_1ModelQuality(output.ModelQuality, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelPackage = (output: any, context: __SerdeContext): ModelPackage => { + return { + ApprovalDescription: + output.ApprovalDescription !== undefined && output.ApprovalDescription !== null + ? output.ApprovalDescription + : undefined, + CertifyForMarketplace: + output.CertifyForMarketplace !== undefined && output.CertifyForMarketplace !== null + ? output.CertifyForMarketplace + : undefined, + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + InferenceSpecification: + output.InferenceSpecification !== undefined && output.InferenceSpecification !== null + ? deserializeAws_json1_1InferenceSpecification(output.InferenceSpecification, context) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, + ModelApprovalStatus: + output.ModelApprovalStatus !== undefined && output.ModelApprovalStatus !== null + ? output.ModelApprovalStatus + : undefined, + ModelMetrics: + output.ModelMetrics !== undefined && output.ModelMetrics !== null + ? deserializeAws_json1_1ModelMetrics(output.ModelMetrics, context) + : undefined, + ModelPackageArn: + output.ModelPackageArn !== undefined && output.ModelPackageArn !== null ? output.ModelPackageArn : undefined, + ModelPackageDescription: + output.ModelPackageDescription !== undefined && output.ModelPackageDescription !== null + ? output.ModelPackageDescription + : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, + ModelPackageName: + output.ModelPackageName !== undefined && output.ModelPackageName !== null ? output.ModelPackageName : undefined, + ModelPackageStatus: + output.ModelPackageStatus !== undefined && output.ModelPackageStatus !== null + ? output.ModelPackageStatus + : undefined, + ModelPackageStatusDetails: + output.ModelPackageStatusDetails !== undefined && output.ModelPackageStatusDetails !== null + ? deserializeAws_json1_1ModelPackageStatusDetails(output.ModelPackageStatusDetails, context) + : undefined, + ModelPackageVersion: + output.ModelPackageVersion !== undefined && output.ModelPackageVersion !== null + ? output.ModelPackageVersion + : undefined, + SourceAlgorithmSpecification: + output.SourceAlgorithmSpecification !== undefined && output.SourceAlgorithmSpecification !== null + ? deserializeAws_json1_1SourceAlgorithmSpecification(output.SourceAlgorithmSpecification, context) + : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) + : undefined, + ValidationSpecification: + output.ValidationSpecification !== undefined && output.ValidationSpecification !== null + ? deserializeAws_json1_1ModelPackageValidationSpecification(output.ValidationSpecification, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelPackageContainerDefinition = ( + output: any, + context: __SerdeContext +): ModelPackageContainerDefinition => { + return { + ContainerHostname: + output.ContainerHostname !== undefined && output.ContainerHostname !== null + ? output.ContainerHostname + : undefined, + Image: output.Image !== undefined && output.Image !== null ? output.Image : undefined, + ImageDigest: output.ImageDigest !== undefined && output.ImageDigest !== null ? output.ImageDigest : undefined, + ModelDataUrl: output.ModelDataUrl !== undefined && output.ModelDataUrl !== null ? output.ModelDataUrl : undefined, + ProductId: output.ProductId !== undefined && output.ProductId !== null ? output.ProductId : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelPackageContainerDefinitionList = ( + output: any, + context: __SerdeContext +): ModelPackageContainerDefinition[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ModelPackageContainerDefinition(entry, context)); +}; + +const deserializeAws_json1_1ModelPackageGroup = (output: any, context: __SerdeContext): ModelPackageGroup => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + ModelPackageGroupArn: + output.ModelPackageGroupArn !== undefined && output.ModelPackageGroupArn !== null + ? output.ModelPackageGroupArn + : undefined, + ModelPackageGroupDescription: + output.ModelPackageGroupDescription !== undefined && output.ModelPackageGroupDescription !== null + ? output.ModelPackageGroupDescription + : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, + ModelPackageGroupStatus: + output.ModelPackageGroupStatus !== undefined && output.ModelPackageGroupStatus !== null + ? output.ModelPackageGroupStatus + : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) : undefined, } as any; }; -const deserializeAws_json1_1ModelPackageContainerDefinition = ( +const deserializeAws_json1_1ModelPackageGroupSummary = ( output: any, context: __SerdeContext -): ModelPackageContainerDefinition => { +): ModelPackageGroupSummary => { return { - ContainerHostname: - output.ContainerHostname !== undefined && output.ContainerHostname !== null - ? output.ContainerHostname + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + ModelPackageGroupArn: + output.ModelPackageGroupArn !== undefined && output.ModelPackageGroupArn !== null + ? output.ModelPackageGroupArn + : undefined, + ModelPackageGroupDescription: + output.ModelPackageGroupDescription !== undefined && output.ModelPackageGroupDescription !== null + ? output.ModelPackageGroupDescription + : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, + ModelPackageGroupStatus: + output.ModelPackageGroupStatus !== undefined && output.ModelPackageGroupStatus !== null + ? output.ModelPackageGroupStatus : undefined, - Image: output.Image !== undefined && output.Image !== null ? output.Image : undefined, - ImageDigest: output.ImageDigest !== undefined && output.ImageDigest !== null ? output.ImageDigest : undefined, - ModelDataUrl: output.ModelDataUrl !== undefined && output.ModelDataUrl !== null ? output.ModelDataUrl : undefined, - ProductId: output.ProductId !== undefined && output.ProductId !== null ? output.ProductId : undefined, } as any; }; -const deserializeAws_json1_1ModelPackageContainerDefinitionList = ( +const deserializeAws_json1_1ModelPackageGroupSummaryList = ( output: any, context: __SerdeContext -): ModelPackageContainerDefinition[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1ModelPackageContainerDefinition(entry, context)); +): ModelPackageGroupSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ModelPackageGroupSummary(entry, context)); }; const deserializeAws_json1_1ModelPackageStatusDetails = ( @@ -19416,18 +25163,30 @@ const deserializeAws_json1_1ModelPackageSummary = (output: any, context: __Serde output.CreationTime !== undefined && output.CreationTime !== null ? new Date(Math.round(output.CreationTime * 1000)) : undefined, + ModelApprovalStatus: + output.ModelApprovalStatus !== undefined && output.ModelApprovalStatus !== null + ? output.ModelApprovalStatus + : undefined, ModelPackageArn: output.ModelPackageArn !== undefined && output.ModelPackageArn !== null ? output.ModelPackageArn : undefined, ModelPackageDescription: output.ModelPackageDescription !== undefined && output.ModelPackageDescription !== null ? output.ModelPackageDescription : undefined, + ModelPackageGroupName: + output.ModelPackageGroupName !== undefined && output.ModelPackageGroupName !== null + ? output.ModelPackageGroupName + : undefined, ModelPackageName: output.ModelPackageName !== undefined && output.ModelPackageName !== null ? output.ModelPackageName : undefined, ModelPackageStatus: output.ModelPackageStatus !== undefined && output.ModelPackageStatus !== null ? output.ModelPackageStatus : undefined, + ModelPackageVersion: + output.ModelPackageVersion !== undefined && output.ModelPackageVersion !== null + ? output.ModelPackageVersion + : undefined, } as any; }; @@ -19469,6 +25228,25 @@ const deserializeAws_json1_1ModelPackageValidationSpecification = ( } as any; }; +const deserializeAws_json1_1ModelQuality = (output: any, context: __SerdeContext): ModelQuality => { + return { + Constraints: + output.Constraints !== undefined && output.Constraints !== null + ? deserializeAws_json1_1MetricsSource(output.Constraints, context) + : undefined, + Statistics: + output.Statistics !== undefined && output.Statistics !== null + ? deserializeAws_json1_1MetricsSource(output.Statistics, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ModelStepMetadata = (output: any, context: __SerdeContext): ModelStepMetadata => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + } as any; +}; + const deserializeAws_json1_1ModelSummary = (output: any, context: __SerdeContext): ModelSummary => { return { CreationTime: @@ -19700,6 +25478,46 @@ const deserializeAws_json1_1MonitoringS3Output = (output: any, context: __SerdeC } as any; }; +const deserializeAws_json1_1MonitoringSchedule = (output: any, context: __SerdeContext): MonitoringSchedule => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + EndpointName: output.EndpointName !== undefined && output.EndpointName !== null ? output.EndpointName : undefined, + FailureReason: + output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + LastMonitoringExecutionSummary: + output.LastMonitoringExecutionSummary !== undefined && output.LastMonitoringExecutionSummary !== null + ? deserializeAws_json1_1MonitoringExecutionSummary(output.LastMonitoringExecutionSummary, context) + : undefined, + MonitoringScheduleArn: + output.MonitoringScheduleArn !== undefined && output.MonitoringScheduleArn !== null + ? output.MonitoringScheduleArn + : undefined, + MonitoringScheduleConfig: + output.MonitoringScheduleConfig !== undefined && output.MonitoringScheduleConfig !== null + ? deserializeAws_json1_1MonitoringScheduleConfig(output.MonitoringScheduleConfig, context) + : undefined, + MonitoringScheduleName: + output.MonitoringScheduleName !== undefined && output.MonitoringScheduleName !== null + ? output.MonitoringScheduleName + : undefined, + MonitoringScheduleStatus: + output.MonitoringScheduleStatus !== undefined && output.MonitoringScheduleStatus !== null + ? output.MonitoringScheduleStatus + : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1MonitoringScheduleConfig = ( output: any, context: __SerdeContext @@ -19716,6 +25534,10 @@ const deserializeAws_json1_1MonitoringScheduleConfig = ( } as any; }; +const deserializeAws_json1_1MonitoringScheduleList = (output: any, context: __SerdeContext): MonitoringSchedule[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1MonitoringSchedule(entry, context)); +}; + const deserializeAws_json1_1MonitoringScheduleSummary = ( output: any, context: __SerdeContext @@ -19919,6 +25741,31 @@ const deserializeAws_json1_1ObjectiveStatusCounters = ( } as any; }; +const deserializeAws_json1_1OfflineStoreConfig = (output: any, context: __SerdeContext): OfflineStoreConfig => { + return { + DataCatalogConfig: + output.DataCatalogConfig !== undefined && output.DataCatalogConfig !== null + ? deserializeAws_json1_1DataCatalogConfig(output.DataCatalogConfig, context) + : undefined, + DisableGlueTableCreation: + output.DisableGlueTableCreation !== undefined && output.DisableGlueTableCreation !== null + ? output.DisableGlueTableCreation + : undefined, + S3StorageConfig: + output.S3StorageConfig !== undefined && output.S3StorageConfig !== null + ? deserializeAws_json1_1S3StorageConfig(output.S3StorageConfig, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1OfflineStoreStatus = (output: any, context: __SerdeContext): OfflineStoreStatus => { + return { + BlockedReason: + output.BlockedReason !== undefined && output.BlockedReason !== null ? output.BlockedReason : undefined, + Status: output.Status !== undefined && output.Status !== null ? output.Status : undefined, + } as any; +}; + const deserializeAws_json1_1OidcConfigForResponse = (output: any, context: __SerdeContext): OidcConfigForResponse => { return { AuthorizationEndpoint: @@ -19946,10 +25793,33 @@ const deserializeAws_json1_1OidcMemberDefinition = (output: any, context: __Serd } as any; }; +const deserializeAws_json1_1OnlineStoreConfig = (output: any, context: __SerdeContext): OnlineStoreConfig => { + return { + EnableOnlineStore: + output.EnableOnlineStore !== undefined && output.EnableOnlineStore !== null + ? output.EnableOnlineStore + : undefined, + SecurityConfig: + output.SecurityConfig !== undefined && output.SecurityConfig !== null + ? deserializeAws_json1_1OnlineStoreSecurityConfig(output.SecurityConfig, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1OnlineStoreSecurityConfig = ( + output: any, + context: __SerdeContext +): OnlineStoreSecurityConfig => { + return { + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + } as any; +}; + const deserializeAws_json1_1OutputConfig = (output: any, context: __SerdeContext): OutputConfig => { return { CompilerOptions: output.CompilerOptions !== undefined && output.CompilerOptions !== null ? output.CompilerOptions : undefined, + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, S3OutputLocation: output.S3OutputLocation !== undefined && output.S3OutputLocation !== null ? output.S3OutputLocation : undefined, TargetDevice: output.TargetDevice !== undefined && output.TargetDevice !== null ? output.TargetDevice : undefined, @@ -19957,91 +25827,315 @@ const deserializeAws_json1_1OutputConfig = (output: any, context: __SerdeContext output.TargetPlatform !== undefined && output.TargetPlatform !== null ? deserializeAws_json1_1TargetPlatform(output.TargetPlatform, context) : undefined, - } as any; -}; - -const deserializeAws_json1_1OutputDataConfig = (output: any, context: __SerdeContext): OutputDataConfig => { - return { - KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, - S3OutputPath: output.S3OutputPath !== undefined && output.S3OutputPath !== null ? output.S3OutputPath : undefined, - } as any; -}; - -const deserializeAws_json1_1ParameterRange = (output: any, context: __SerdeContext): ParameterRange => { - return { - CategoricalParameterRangeSpecification: - output.CategoricalParameterRangeSpecification !== undefined && - output.CategoricalParameterRangeSpecification !== null - ? deserializeAws_json1_1CategoricalParameterRangeSpecification( - output.CategoricalParameterRangeSpecification, - context - ) + } as any; +}; + +const deserializeAws_json1_1OutputDataConfig = (output: any, context: __SerdeContext): OutputDataConfig => { + return { + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + S3OutputPath: output.S3OutputPath !== undefined && output.S3OutputPath !== null ? output.S3OutputPath : undefined, + } as any; +}; + +const deserializeAws_json1_1Parameter = (output: any, context: __SerdeContext): Parameter => { + return { + Name: output.Name !== undefined && output.Name !== null ? output.Name : undefined, + Value: output.Value !== undefined && output.Value !== null ? output.Value : undefined, + } as any; +}; + +const deserializeAws_json1_1ParameterList = (output: any, context: __SerdeContext): Parameter[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Parameter(entry, context)); +}; + +const deserializeAws_json1_1ParameterRange = (output: any, context: __SerdeContext): ParameterRange => { + return { + CategoricalParameterRangeSpecification: + output.CategoricalParameterRangeSpecification !== undefined && + output.CategoricalParameterRangeSpecification !== null + ? deserializeAws_json1_1CategoricalParameterRangeSpecification( + output.CategoricalParameterRangeSpecification, + context + ) + : undefined, + ContinuousParameterRangeSpecification: + output.ContinuousParameterRangeSpecification !== undefined && + output.ContinuousParameterRangeSpecification !== null + ? deserializeAws_json1_1ContinuousParameterRangeSpecification( + output.ContinuousParameterRangeSpecification, + context + ) + : undefined, + IntegerParameterRangeSpecification: + output.IntegerParameterRangeSpecification !== undefined && output.IntegerParameterRangeSpecification !== null + ? deserializeAws_json1_1IntegerParameterRangeSpecification(output.IntegerParameterRangeSpecification, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ParameterRanges = (output: any, context: __SerdeContext): ParameterRanges => { + return { + CategoricalParameterRanges: + output.CategoricalParameterRanges !== undefined && output.CategoricalParameterRanges !== null + ? deserializeAws_json1_1CategoricalParameterRanges(output.CategoricalParameterRanges, context) + : undefined, + ContinuousParameterRanges: + output.ContinuousParameterRanges !== undefined && output.ContinuousParameterRanges !== null + ? deserializeAws_json1_1ContinuousParameterRanges(output.ContinuousParameterRanges, context) + : undefined, + IntegerParameterRanges: + output.IntegerParameterRanges !== undefined && output.IntegerParameterRanges !== null + ? deserializeAws_json1_1IntegerParameterRanges(output.IntegerParameterRanges, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1ParameterValues = (output: any, context: __SerdeContext): string[] => { + return (output || []).map((entry: any) => entry); +}; + +const deserializeAws_json1_1Parent = (output: any, context: __SerdeContext): Parent => { + return { + ExperimentName: + output.ExperimentName !== undefined && output.ExperimentName !== null ? output.ExperimentName : undefined, + TrialName: output.TrialName !== undefined && output.TrialName !== null ? output.TrialName : undefined, + } as any; +}; + +const deserializeAws_json1_1ParentHyperParameterTuningJob = ( + output: any, + context: __SerdeContext +): ParentHyperParameterTuningJob => { + return { + HyperParameterTuningJobName: + output.HyperParameterTuningJobName !== undefined && output.HyperParameterTuningJobName !== null + ? output.HyperParameterTuningJobName + : undefined, + } as any; +}; + +const deserializeAws_json1_1ParentHyperParameterTuningJobs = ( + output: any, + context: __SerdeContext +): ParentHyperParameterTuningJob[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ParentHyperParameterTuningJob(entry, context)); +}; + +const deserializeAws_json1_1Parents = (output: any, context: __SerdeContext): Parent[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1Parent(entry, context)); +}; + +const deserializeAws_json1_1Pipeline = (output: any, context: __SerdeContext): Pipeline => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + LastRunTime: + output.LastRunTime !== undefined && output.LastRunTime !== null + ? new Date(Math.round(output.LastRunTime * 1000)) + : undefined, + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + PipelineDescription: + output.PipelineDescription !== undefined && output.PipelineDescription !== null + ? output.PipelineDescription + : undefined, + PipelineDisplayName: + output.PipelineDisplayName !== undefined && output.PipelineDisplayName !== null + ? output.PipelineDisplayName + : undefined, + PipelineName: output.PipelineName !== undefined && output.PipelineName !== null ? output.PipelineName : undefined, + PipelineStatus: + output.PipelineStatus !== undefined && output.PipelineStatus !== null ? output.PipelineStatus : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + Tags: + output.Tags !== undefined && output.Tags !== null + ? deserializeAws_json1_1TagList(output.Tags, context) + : undefined, + } as any; +}; + +const deserializeAws_json1_1PipelineExecution = (output: any, context: __SerdeContext): PipelineExecution => { + return { + CreatedBy: + output.CreatedBy !== undefined && output.CreatedBy !== null + ? deserializeAws_json1_1UserContext(output.CreatedBy, context) + : undefined, + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastModifiedBy: + output.LastModifiedBy !== undefined && output.LastModifiedBy !== null + ? deserializeAws_json1_1UserContext(output.LastModifiedBy, context) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + PipelineExecutionDescription: + output.PipelineExecutionDescription !== undefined && output.PipelineExecutionDescription !== null + ? output.PipelineExecutionDescription + : undefined, + PipelineExecutionDisplayName: + output.PipelineExecutionDisplayName !== undefined && output.PipelineExecutionDisplayName !== null + ? output.PipelineExecutionDisplayName : undefined, - ContinuousParameterRangeSpecification: - output.ContinuousParameterRangeSpecification !== undefined && - output.ContinuousParameterRangeSpecification !== null - ? deserializeAws_json1_1ContinuousParameterRangeSpecification( - output.ContinuousParameterRangeSpecification, - context - ) + PipelineExecutionStatus: + output.PipelineExecutionStatus !== undefined && output.PipelineExecutionStatus !== null + ? output.PipelineExecutionStatus : undefined, - IntegerParameterRangeSpecification: - output.IntegerParameterRangeSpecification !== undefined && output.IntegerParameterRangeSpecification !== null - ? deserializeAws_json1_1IntegerParameterRangeSpecification(output.IntegerParameterRangeSpecification, context) + PipelineParameters: + output.PipelineParameters !== undefined && output.PipelineParameters !== null + ? deserializeAws_json1_1ParameterList(output.PipelineParameters, context) : undefined, } as any; }; -const deserializeAws_json1_1ParameterRanges = (output: any, context: __SerdeContext): ParameterRanges => { +const deserializeAws_json1_1PipelineExecutionStep = (output: any, context: __SerdeContext): PipelineExecutionStep => { return { - CategoricalParameterRanges: - output.CategoricalParameterRanges !== undefined && output.CategoricalParameterRanges !== null - ? deserializeAws_json1_1CategoricalParameterRanges(output.CategoricalParameterRanges, context) + CacheHitResult: + output.CacheHitResult !== undefined && output.CacheHitResult !== null + ? deserializeAws_json1_1CacheHitResult(output.CacheHitResult, context) : undefined, - ContinuousParameterRanges: - output.ContinuousParameterRanges !== undefined && output.ContinuousParameterRanges !== null - ? deserializeAws_json1_1ContinuousParameterRanges(output.ContinuousParameterRanges, context) + EndTime: + output.EndTime !== undefined && output.EndTime !== null ? new Date(Math.round(output.EndTime * 1000)) : undefined, + FailureReason: + output.FailureReason !== undefined && output.FailureReason !== null ? output.FailureReason : undefined, + Metadata: + output.Metadata !== undefined && output.Metadata !== null + ? deserializeAws_json1_1PipelineExecutionStepMetadata(output.Metadata, context) : undefined, - IntegerParameterRanges: - output.IntegerParameterRanges !== undefined && output.IntegerParameterRanges !== null - ? deserializeAws_json1_1IntegerParameterRanges(output.IntegerParameterRanges, context) + StartTime: + output.StartTime !== undefined && output.StartTime !== null + ? new Date(Math.round(output.StartTime * 1000)) : undefined, + StepName: output.StepName !== undefined && output.StepName !== null ? output.StepName : undefined, + StepStatus: output.StepStatus !== undefined && output.StepStatus !== null ? output.StepStatus : undefined, } as any; }; -const deserializeAws_json1_1ParameterValues = (output: any, context: __SerdeContext): string[] => { - return (output || []).map((entry: any) => entry); +const deserializeAws_json1_1PipelineExecutionStepList = ( + output: any, + context: __SerdeContext +): PipelineExecutionStep[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1PipelineExecutionStep(entry, context)); }; -const deserializeAws_json1_1Parent = (output: any, context: __SerdeContext): Parent => { +const deserializeAws_json1_1PipelineExecutionStepMetadata = ( + output: any, + context: __SerdeContext +): PipelineExecutionStepMetadata => { return { - ExperimentName: - output.ExperimentName !== undefined && output.ExperimentName !== null ? output.ExperimentName : undefined, - TrialName: output.TrialName !== undefined && output.TrialName !== null ? output.TrialName : undefined, + Condition: + output.Condition !== undefined && output.Condition !== null + ? deserializeAws_json1_1ConditionStepMetadata(output.Condition, context) + : undefined, + Model: + output.Model !== undefined && output.Model !== null + ? deserializeAws_json1_1ModelStepMetadata(output.Model, context) + : undefined, + ProcessingJob: + output.ProcessingJob !== undefined && output.ProcessingJob !== null + ? deserializeAws_json1_1ProcessingJobStepMetadata(output.ProcessingJob, context) + : undefined, + RegisterModel: + output.RegisterModel !== undefined && output.RegisterModel !== null + ? deserializeAws_json1_1RegisterModelStepMetadata(output.RegisterModel, context) + : undefined, + TrainingJob: + output.TrainingJob !== undefined && output.TrainingJob !== null + ? deserializeAws_json1_1TrainingJobStepMetadata(output.TrainingJob, context) + : undefined, + TransformJob: + output.TransformJob !== undefined && output.TransformJob !== null + ? deserializeAws_json1_1TransformJobStepMetadata(output.TransformJob, context) + : undefined, } as any; }; -const deserializeAws_json1_1ParentHyperParameterTuningJob = ( +const deserializeAws_json1_1PipelineExecutionSummary = ( output: any, context: __SerdeContext -): ParentHyperParameterTuningJob => { +): PipelineExecutionSummary => { return { - HyperParameterTuningJobName: - output.HyperParameterTuningJobName !== undefined && output.HyperParameterTuningJobName !== null - ? output.HyperParameterTuningJobName + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + PipelineExecutionDescription: + output.PipelineExecutionDescription !== undefined && output.PipelineExecutionDescription !== null + ? output.PipelineExecutionDescription + : undefined, + PipelineExecutionDisplayName: + output.PipelineExecutionDisplayName !== undefined && output.PipelineExecutionDisplayName !== null + ? output.PipelineExecutionDisplayName + : undefined, + PipelineExecutionStatus: + output.PipelineExecutionStatus !== undefined && output.PipelineExecutionStatus !== null + ? output.PipelineExecutionStatus + : undefined, + StartTime: + output.StartTime !== undefined && output.StartTime !== null + ? new Date(Math.round(output.StartTime * 1000)) : undefined, } as any; }; -const deserializeAws_json1_1ParentHyperParameterTuningJobs = ( +const deserializeAws_json1_1PipelineExecutionSummaryList = ( output: any, context: __SerdeContext -): ParentHyperParameterTuningJob[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1ParentHyperParameterTuningJob(entry, context)); +): PipelineExecutionSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1PipelineExecutionSummary(entry, context)); }; -const deserializeAws_json1_1Parents = (output: any, context: __SerdeContext): Parent[] => { - return (output || []).map((entry: any) => deserializeAws_json1_1Parent(entry, context)); +const deserializeAws_json1_1PipelineSummary = (output: any, context: __SerdeContext): PipelineSummary => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + LastExecutionTime: + output.LastExecutionTime !== undefined && output.LastExecutionTime !== null + ? new Date(Math.round(output.LastExecutionTime * 1000)) + : undefined, + LastModifiedTime: + output.LastModifiedTime !== undefined && output.LastModifiedTime !== null + ? new Date(Math.round(output.LastModifiedTime * 1000)) + : undefined, + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + PipelineDescription: + output.PipelineDescription !== undefined && output.PipelineDescription !== null + ? output.PipelineDescription + : undefined, + PipelineDisplayName: + output.PipelineDisplayName !== undefined && output.PipelineDisplayName !== null + ? output.PipelineDisplayName + : undefined, + PipelineName: output.PipelineName !== undefined && output.PipelineName !== null ? output.PipelineName : undefined, + RoleArn: output.RoleArn !== undefined && output.RoleArn !== null ? output.RoleArn : undefined, + } as any; +}; + +const deserializeAws_json1_1PipelineSummaryList = (output: any, context: __SerdeContext): PipelineSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1PipelineSummary(entry, context)); }; const deserializeAws_json1_1ProcessingClusterConfig = ( @@ -20072,8 +26166,23 @@ const deserializeAws_json1_1ProcessingEnvironmentMap = ( ); }; +const deserializeAws_json1_1ProcessingFeatureStoreOutput = ( + output: any, + context: __SerdeContext +): ProcessingFeatureStoreOutput => { + return { + FeatureGroupName: + output.FeatureGroupName !== undefined && output.FeatureGroupName !== null ? output.FeatureGroupName : undefined, + } as any; +}; + const deserializeAws_json1_1ProcessingInput = (output: any, context: __SerdeContext): ProcessingInput => { return { + AppManaged: output.AppManaged !== undefined && output.AppManaged !== null ? output.AppManaged : undefined, + DatasetDefinition: + output.DatasetDefinition !== undefined && output.DatasetDefinition !== null + ? deserializeAws_json1_1DatasetDefinition(output.DatasetDefinition, context) + : undefined, InputName: output.InputName !== undefined && output.InputName !== null ? output.InputName : undefined, S3Input: output.S3Input !== undefined && output.S3Input !== null @@ -20164,6 +26273,15 @@ const deserializeAws_json1_1ProcessingJob = (output: any, context: __SerdeContex } as any; }; +const deserializeAws_json1_1ProcessingJobStepMetadata = ( + output: any, + context: __SerdeContext +): ProcessingJobStepMetadata => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + } as any; +}; + const deserializeAws_json1_1ProcessingJobSummaries = (output: any, context: __SerdeContext): ProcessingJobSummary[] => { return (output || []).map((entry: any) => deserializeAws_json1_1ProcessingJobSummary(entry, context)); }; @@ -20200,6 +26318,11 @@ const deserializeAws_json1_1ProcessingJobSummary = (output: any, context: __Serd const deserializeAws_json1_1ProcessingOutput = (output: any, context: __SerdeContext): ProcessingOutput => { return { + AppManaged: output.AppManaged !== undefined && output.AppManaged !== null ? output.AppManaged : undefined, + FeatureStoreOutput: + output.FeatureStoreOutput !== undefined && output.FeatureStoreOutput !== null + ? deserializeAws_json1_1ProcessingFeatureStoreOutput(output.FeatureStoreOutput, context) + : undefined, OutputName: output.OutputName !== undefined && output.OutputName !== null ? output.OutputName : undefined, S3Output: output.S3Output !== undefined && output.S3Output !== null @@ -20326,6 +26449,28 @@ const deserializeAws_json1_1ProductListings = (output: any, context: __SerdeCont return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1ProjectSummary = (output: any, context: __SerdeContext): ProjectSummary => { + return { + CreationTime: + output.CreationTime !== undefined && output.CreationTime !== null + ? new Date(Math.round(output.CreationTime * 1000)) + : undefined, + ProjectArn: output.ProjectArn !== undefined && output.ProjectArn !== null ? output.ProjectArn : undefined, + ProjectDescription: + output.ProjectDescription !== undefined && output.ProjectDescription !== null + ? output.ProjectDescription + : undefined, + ProjectId: output.ProjectId !== undefined && output.ProjectId !== null ? output.ProjectId : undefined, + ProjectName: output.ProjectName !== undefined && output.ProjectName !== null ? output.ProjectName : undefined, + ProjectStatus: + output.ProjectStatus !== undefined && output.ProjectStatus !== null ? output.ProjectStatus : undefined, + } as any; +}; + +const deserializeAws_json1_1ProjectSummaryList = (output: any, context: __SerdeContext): ProjectSummary[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ProjectSummary(entry, context)); +}; + const deserializeAws_json1_1PropertyNameSuggestion = (output: any, context: __SerdeContext): PropertyNameSuggestion => { return { PropertyName: output.PropertyName !== undefined && output.PropertyName !== null ? output.PropertyName : undefined, @@ -20339,6 +26484,20 @@ const deserializeAws_json1_1PropertyNameSuggestionList = ( return (output || []).map((entry: any) => deserializeAws_json1_1PropertyNameSuggestion(entry, context)); }; +const deserializeAws_json1_1ProvisioningParameter = (output: any, context: __SerdeContext): ProvisioningParameter => { + return { + Key: output.Key !== undefined && output.Key !== null ? output.Key : undefined, + Value: output.Value !== undefined && output.Value !== null ? output.Value : undefined, + } as any; +}; + +const deserializeAws_json1_1ProvisioningParameters = ( + output: any, + context: __SerdeContext +): ProvisioningParameter[] => { + return (output || []).map((entry: any) => deserializeAws_json1_1ProvisioningParameter(entry, context)); +}; + const deserializeAws_json1_1PublicWorkforceTaskPrice = ( output: any, context: __SerdeContext @@ -20351,6 +26510,18 @@ const deserializeAws_json1_1PublicWorkforceTaskPrice = ( } as any; }; +const deserializeAws_json1_1PutModelPackageGroupPolicyOutput = ( + output: any, + context: __SerdeContext +): PutModelPackageGroupPolicyOutput => { + return { + ModelPackageGroupArn: + output.ModelPackageGroupArn !== undefined && output.ModelPackageGroupArn !== null + ? output.ModelPackageGroupArn + : undefined, + } as any; +}; + const deserializeAws_json1_1RealtimeInferenceInstanceTypes = ( output: any, context: __SerdeContext @@ -20358,6 +26529,36 @@ const deserializeAws_json1_1RealtimeInferenceInstanceTypes = ( return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1RedshiftDatasetDefinition = ( + output: any, + context: __SerdeContext +): RedshiftDatasetDefinition => { + return { + ClusterId: output.ClusterId !== undefined && output.ClusterId !== null ? output.ClusterId : undefined, + ClusterRoleArn: + output.ClusterRoleArn !== undefined && output.ClusterRoleArn !== null ? output.ClusterRoleArn : undefined, + Database: output.Database !== undefined && output.Database !== null ? output.Database : undefined, + DbUser: output.DbUser !== undefined && output.DbUser !== null ? output.DbUser : undefined, + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + OutputCompression: + output.OutputCompression !== undefined && output.OutputCompression !== null + ? output.OutputCompression + : undefined, + OutputFormat: output.OutputFormat !== undefined && output.OutputFormat !== null ? output.OutputFormat : undefined, + OutputS3Uri: output.OutputS3Uri !== undefined && output.OutputS3Uri !== null ? output.OutputS3Uri : undefined, + QueryString: output.QueryString !== undefined && output.QueryString !== null ? output.QueryString : undefined, + } as any; +}; + +const deserializeAws_json1_1RegisterModelStepMetadata = ( + output: any, + context: __SerdeContext +): RegisterModelStepMetadata => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + } as any; +}; + const deserializeAws_json1_1RenderingError = (output: any, context: __SerdeContext): RenderingError => { return { Code: output.Code !== undefined && output.Code !== null ? output.Code : undefined, @@ -20483,6 +26684,13 @@ const deserializeAws_json1_1S3DataSource = (output: any, context: __SerdeContext } as any; }; +const deserializeAws_json1_1S3StorageConfig = (output: any, context: __SerdeContext): S3StorageConfig => { + return { + KmsKeyId: output.KmsKeyId !== undefined && output.KmsKeyId !== null ? output.KmsKeyId : undefined, + S3Uri: output.S3Uri !== undefined && output.S3Uri !== null ? output.S3Uri : undefined, + } as any; +}; + const deserializeAws_json1_1ScheduleConfig = (output: any, context: __SerdeContext): ScheduleConfig => { return { ScheduleExpression: @@ -20494,10 +26702,34 @@ const deserializeAws_json1_1ScheduleConfig = (output: any, context: __SerdeConte const deserializeAws_json1_1SearchRecord = (output: any, context: __SerdeContext): SearchRecord => { return { + Endpoint: + output.Endpoint !== undefined && output.Endpoint !== null + ? deserializeAws_json1_1Endpoint(output.Endpoint, context) + : undefined, Experiment: output.Experiment !== undefined && output.Experiment !== null ? deserializeAws_json1_1Experiment(output.Experiment, context) : undefined, + FeatureGroup: + output.FeatureGroup !== undefined && output.FeatureGroup !== null + ? deserializeAws_json1_1FeatureGroup(output.FeatureGroup, context) + : undefined, + ModelPackage: + output.ModelPackage !== undefined && output.ModelPackage !== null + ? deserializeAws_json1_1ModelPackage(output.ModelPackage, context) + : undefined, + ModelPackageGroup: + output.ModelPackageGroup !== undefined && output.ModelPackageGroup !== null + ? deserializeAws_json1_1ModelPackageGroup(output.ModelPackageGroup, context) + : undefined, + Pipeline: + output.Pipeline !== undefined && output.Pipeline !== null + ? deserializeAws_json1_1Pipeline(output.Pipeline, context) + : undefined, + PipelineExecution: + output.PipelineExecution !== undefined && output.PipelineExecution !== null + ? deserializeAws_json1_1PipelineExecution(output.PipelineExecution, context) + : undefined, TrainingJob: output.TrainingJob !== undefined && output.TrainingJob !== null ? deserializeAws_json1_1TrainingJob(output.TrainingJob, context) @@ -20555,6 +26787,40 @@ const deserializeAws_json1_1SecurityGroupIds = (output: any, context: __SerdeCon return (output || []).map((entry: any) => entry); }; +const deserializeAws_json1_1ServiceCatalogProvisionedProductDetails = ( + output: any, + context: __SerdeContext +): ServiceCatalogProvisionedProductDetails => { + return { + ProvisionedProductId: + output.ProvisionedProductId !== undefined && output.ProvisionedProductId !== null + ? output.ProvisionedProductId + : undefined, + ProvisionedProductStatusMessage: + output.ProvisionedProductStatusMessage !== undefined && output.ProvisionedProductStatusMessage !== null + ? output.ProvisionedProductStatusMessage + : undefined, + } as any; +}; + +const deserializeAws_json1_1ServiceCatalogProvisioningDetails = ( + output: any, + context: __SerdeContext +): ServiceCatalogProvisioningDetails => { + return { + PathId: output.PathId !== undefined && output.PathId !== null ? output.PathId : undefined, + ProductId: output.ProductId !== undefined && output.ProductId !== null ? output.ProductId : undefined, + ProvisioningArtifactId: + output.ProvisioningArtifactId !== undefined && output.ProvisioningArtifactId !== null + ? output.ProvisioningArtifactId + : undefined, + ProvisioningParameters: + output.ProvisioningParameters !== undefined && output.ProvisioningParameters !== null + ? deserializeAws_json1_1ProvisioningParameters(output.ProvisioningParameters, context) + : undefined, + } as any; +}; + const deserializeAws_json1_1SharingSettings = (output: any, context: __SerdeContext): SharingSettings => { return { NotebookOutputOption: @@ -20605,6 +26871,18 @@ const deserializeAws_json1_1SourceIpConfig = (output: any, context: __SerdeConte } as any; }; +const deserializeAws_json1_1StartPipelineExecutionResponse = ( + output: any, + context: __SerdeContext +): StartPipelineExecutionResponse => { + return { + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + } as any; +}; + const deserializeAws_json1_1StoppingCondition = (output: any, context: __SerdeContext): StoppingCondition => { return { MaxRuntimeInSeconds: @@ -20618,6 +26896,18 @@ const deserializeAws_json1_1StoppingCondition = (output: any, context: __SerdeCo } as any; }; +const deserializeAws_json1_1StopPipelineExecutionResponse = ( + output: any, + context: __SerdeContext +): StopPipelineExecutionResponse => { + return { + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + } as any; +}; + const deserializeAws_json1_1Subnets = (output: any, context: __SerdeContext): string[] => { return (output || []).map((entry: any) => entry); }; @@ -20682,6 +26972,20 @@ const deserializeAws_json1_1TensorBoardOutputConfig = ( } as any; }; +const deserializeAws_json1_1TrafficRoutingConfig = (output: any, context: __SerdeContext): TrafficRoutingConfig => { + return { + CanarySize: + output.CanarySize !== undefined && output.CanarySize !== null + ? deserializeAws_json1_1CapacitySize(output.CanarySize, context) + : undefined, + Type: output.Type !== undefined && output.Type !== null ? output.Type : undefined, + WaitIntervalInSeconds: + output.WaitIntervalInSeconds !== undefined && output.WaitIntervalInSeconds !== null + ? output.WaitIntervalInSeconds + : undefined, + } as any; +}; + const deserializeAws_json1_1TrainingInstanceTypes = ( output: any, context: __SerdeContext @@ -20862,6 +27166,15 @@ const deserializeAws_json1_1TrainingJobStatusCounters = ( } as any; }; +const deserializeAws_json1_1TrainingJobStepMetadata = ( + output: any, + context: __SerdeContext +): TrainingJobStepMetadata => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + } as any; +}; + const deserializeAws_json1_1TrainingJobSummaries = (output: any, context: __SerdeContext): TrainingJobSummary[] => { return (output || []).map((entry: any) => deserializeAws_json1_1TrainingJobSummary(entry, context)); }; @@ -21068,6 +27381,15 @@ const deserializeAws_json1_1TransformJobDefinition = (output: any, context: __Se } as any; }; +const deserializeAws_json1_1TransformJobStepMetadata = ( + output: any, + context: __SerdeContext +): TransformJobStepMetadata => { + return { + Arn: output.Arn !== undefined && output.Arn !== null ? output.Arn : undefined, + } as any; +}; + const deserializeAws_json1_1TransformJobSummaries = (output: any, context: __SerdeContext): TransformJobSummary[] => { return (output || []).map((entry: any) => deserializeAws_json1_1TransformJobSummary(entry, context)); }; @@ -21146,6 +27468,10 @@ const deserializeAws_json1_1Trial = (output: any, context: __SerdeContext): Tria output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, Source: output.Source !== undefined && output.Source !== null ? deserializeAws_json1_1TrialSource(output.Source, context) @@ -21188,6 +27514,10 @@ const deserializeAws_json1_1TrialComponent = (output: any, context: __SerdeConte output.LastModifiedTime !== undefined && output.LastModifiedTime !== null ? new Date(Math.round(output.LastModifiedTime * 1000)) : undefined, + MetadataProperties: + output.MetadataProperties !== undefined && output.MetadataProperties !== null + ? deserializeAws_json1_1MetadataProperties(output.MetadataProperties, context) + : undefined, Metrics: output.Metrics !== undefined && output.Metrics !== null ? deserializeAws_json1_1TrialComponentMetricSummaries(output.Metrics, context) @@ -21299,10 +27629,17 @@ const deserializeAws_json1_1TrialComponentParameterValue = ( output: any, context: __SerdeContext ): TrialComponentParameterValue => { - return { - NumberValue: output.NumberValue !== undefined && output.NumberValue !== null ? output.NumberValue : undefined, - StringValue: output.StringValue !== undefined && output.StringValue !== null ? output.StringValue : undefined, - } as any; + if (output.NumberValue !== undefined && output.NumberValue !== null) { + return { + NumberValue: output.NumberValue, + }; + } + if (output.StringValue !== undefined && output.StringValue !== null) { + return { + StringValue: output.StringValue, + }; + } + return { $unknown: Object.entries(output)[0] }; }; const deserializeAws_json1_1TrialComponentSimpleSummaries = ( @@ -21487,6 +27824,12 @@ const deserializeAws_json1_1UiTemplateInfo = (output: any, context: __SerdeConte } as any; }; +const deserializeAws_json1_1UpdateActionResponse = (output: any, context: __SerdeContext): UpdateActionResponse => { + return { + ActionArn: output.ActionArn !== undefined && output.ActionArn !== null ? output.ActionArn : undefined, + } as any; +}; + const deserializeAws_json1_1UpdateAppImageConfigResponse = ( output: any, context: __SerdeContext @@ -21499,6 +27842,12 @@ const deserializeAws_json1_1UpdateAppImageConfigResponse = ( } as any; }; +const deserializeAws_json1_1UpdateArtifactResponse = (output: any, context: __SerdeContext): UpdateArtifactResponse => { + return { + ArtifactArn: output.ArtifactArn !== undefined && output.ArtifactArn !== null ? output.ArtifactArn : undefined, + } as any; +}; + const deserializeAws_json1_1UpdateCodeRepositoryOutput = ( output: any, context: __SerdeContext @@ -21511,6 +27860,12 @@ const deserializeAws_json1_1UpdateCodeRepositoryOutput = ( } as any; }; +const deserializeAws_json1_1UpdateContextResponse = (output: any, context: __SerdeContext): UpdateContextResponse => { + return { + ContextArn: output.ContextArn !== undefined && output.ContextArn !== null ? output.ContextArn : undefined, + } as any; +}; + const deserializeAws_json1_1UpdateDomainResponse = (output: any, context: __SerdeContext): UpdateDomainResponse => { return { DomainArn: output.DomainArn !== undefined && output.DomainArn !== null ? output.DomainArn : undefined, @@ -21548,6 +27903,16 @@ const deserializeAws_json1_1UpdateImageResponse = (output: any, context: __Serde } as any; }; +const deserializeAws_json1_1UpdateModelPackageOutput = ( + output: any, + context: __SerdeContext +): UpdateModelPackageOutput => { + return { + ModelPackageArn: + output.ModelPackageArn !== undefined && output.ModelPackageArn !== null ? output.ModelPackageArn : undefined, + } as any; +}; + const deserializeAws_json1_1UpdateMonitoringScheduleResponse = ( output: any, context: __SerdeContext @@ -21574,6 +27939,24 @@ const deserializeAws_json1_1UpdateNotebookInstanceOutput = ( return {} as any; }; +const deserializeAws_json1_1UpdatePipelineExecutionResponse = ( + output: any, + context: __SerdeContext +): UpdatePipelineExecutionResponse => { + return { + PipelineExecutionArn: + output.PipelineExecutionArn !== undefined && output.PipelineExecutionArn !== null + ? output.PipelineExecutionArn + : undefined, + } as any; +}; + +const deserializeAws_json1_1UpdatePipelineResponse = (output: any, context: __SerdeContext): UpdatePipelineResponse => { + return { + PipelineArn: output.PipelineArn !== undefined && output.PipelineArn !== null ? output.PipelineArn : undefined, + } as any; +}; + const deserializeAws_json1_1UpdateTrialComponentResponse = ( output: any, context: __SerdeContext