You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

awscdk-resources-mongodbatlas

Package Overview
Dependencies
Maintainers
1
Versions
28
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

awscdk-resources-mongodbatlas - npm Package Compare versions

Comparing version

to
3.8.0

10

lib/index.d.ts

@@ -5,3 +5,3 @@ export { CfnAccessListApiKey, CfnAccessListApiKeyProps, } from "./l1-resources/access-list-api-key";

export { CfnAuditing, CfnAuditingProps } from "./l1-resources/auditing";
export { CfnCloudBackUpRestoreJobs, CfnCloudBackUpRestoreJobsProps, CfnCloudBackUpRestoreJobsPropsDeliveryType, CfnCloudBackUpRestoreJobsPropsInstanceType, SynchronousCreationOptions, } from "./l1-resources/cloud-backup-restore-jobs";
export { CfnCloudBackUpRestoreJobs, CfnCloudBackUpRestoreJobsProps, CfnCloudBackUpRestoreJobsPropsLinks, CfnCloudBackUpRestoreJobsPropsDeliveryType, CfnCloudBackUpRestoreJobsPropsInstanceType, SynchronousCreationOptions, } from "./l1-resources/cloud-backup-restore-jobs";
export { ApiAtlasDiskBackupCopySettingView, ApiDeleteCopiedBackupsView, ApiPolicyItemView, ApiPolicyView, CfnCloudBackupSchedule, CfnCloudBackupScheduleProps, Export, Link, } from "./l1-resources/cloud-backup-schedule";

@@ -17,3 +17,3 @@ export { ApiAtlasDiskBackupShardedClusterSnapshotMemberView, ApiAtlasDiskBackupShardedClusterSnapshotMemberViewCloudProvider, ApiAtlasDiskBackupShardedClusterSnapshotView, ApiAtlasDiskBackupShardedClusterSnapshotViewFrequencyType, ApiAtlasDiskBackupShardedClusterSnapshotViewSnapshotType, ApiAtlasDiskBackupShardedClusterSnapshotViewStatus, ApiAtlasDiskBackupShardedClusterSnapshotViewType, CfnCloudBackupSnapshot, CfnCloudBackupSnapshotProps, CfnCloudBackupSnapshotPropsFrequencyType, CfnCloudBackupSnapshotPropsSnapshotType, CfnCloudBackupSnapshotPropsInstanceType, } from "./l1-resources/cloud-backup-snapshot";

export { CfnDataLakes, CfnDataLakesProps, DataLakeAwsCloudProviderConfigView, DataLakeCloudProviderConfigView, DataLakeDataProcessRegionView, DataLakeDataProcessRegionViewCloudProvider, DataLakeDataProcessRegionViewRegion, DataLakeDatabaseCollectionView, DataLakeDatabaseDataSourceView, DataLakeDatabaseDataSourceViewDefaultFormat, DataLakeDatabaseView, DataLakeStorageView, DataLakeViewView, StoreDetail, } from "./l1-resources/datalakes";
export { AwsKmsConfiguration, CfnEncryptionAtRest, CfnEncryptionAtRestProps, } from "./l1-resources/encryption-at-rest";
export { AwsKmsConfig, CfnEncryptionAtRest, CfnEncryptionAtRestProps, } from "./l1-resources/encryption-at-rest";
export { CfnFederatedDatabaseInstance, CfnFederatedDatabaseInstanceProps, CloudProviderConfig, DataProcessRegion, Storage, Database, Store, Collection, DataSource, ReadPreference, TagSet, View, } from "./l1-resources/federated-database-instance";

@@ -28,3 +28,3 @@ export { CfnFederatedQueryLimit, CfnFederatedQueryLimitProps, CfnFederatedQueryLimitPropsLimitName, } from "./l1-resources/federated-query-limit";

export { CfnNetworkPeering, CfnNetworkPeeringProps, } from "./l1-resources/network-peering";
export { CfnOnlineArchive, CfnOnlineArchiveProps, CfnOnlineArchivePropsCollectionType, CriteriaView, CriteriaViewDateFormat, CriteriaViewType, PartitionFieldView, PartitionFieldViewFieldType, ScheduleView, ScheduleViewType, } from "./l1-resources/online-archive";
export { CfnOnlineArchive, CfnOnlineArchiveProps, CfnOnlineArchivePropsCollectionType, CriteriaView, CriteriaViewDateFormat, CriteriaViewType, PartitionFieldView, ScheduleView, ScheduleViewType, } from "./l1-resources/online-archive";
export { CfnOrgInvitation, CfnOrgInvitationProps, CfnOrgInvitationPropsRoles, } from "./l1-resources/org-invitation";

@@ -42,5 +42,5 @@ export { CfnOrganization, CfnOrganizationProps, ApiKey, } from "./l1-resources/organization";

export { CfnSearchDeployment, CfnSearchDeploymentProps, ApiSearchDeploymentSpec, } from "./l1-resources/search-deployment";
export { ApiAtlasFtsAnalyzersViewManual, ApiAtlasFtsMappingsViewManual, ApiAtlasFtsSynonymMappingDefinitionView, CfnSearchIndex, CfnSearchIndexProps, SynonymSource, } from "./l1-resources/search-index";
export { ApiAtlasFtsAnalyzersTokenizer, ApiAtlasFtsAnalyzersViewManual, ApiAtlasFtsMappingsViewManual, ApiAtlasFtsSynonymMappingDefinitionView, CfnSearchIndex, CfnSearchIndexProps, SynonymSource, } from "./l1-resources/search-index";
export { CfnServerlessInstance, CfnServerlessInstanceProps, ServerlessInstanceConnectionStrings, ServerlessInstancePrivateEndpoint, ServerlessInstancePrivateEndpointEndpoint, ServerlessInstancePrivateEndpointType, ServerlessInstanceProviderSettings, ServerlessInstanceProviderSettingsProviderName, } from "./l1-resources/serverless-instance";
export { CfnServerlessPrivateEndpointProps, CfnServerlessPrivateEndpoint, ServerlessPrivateEndpoint, AwsPrivateEndpointConfig, } from "./l1-resources/serverless-private-endpoint";
export { CfnServerlessPrivateEndpointProps, CfnServerlessPrivateEndpoint, AwsPrivateEndpointConfig, } from "./l1-resources/serverless-private-endpoint";
export { CfnStreamConnection, CfnStreamConnectionProps, CfnStreamConnectionPropsType, DbRoleToExecute, DbRoleToExecuteType, StreamsKafkaAuthentication, StreamsKafkaSecurity, } from "./l1-resources/stream-connection";

@@ -47,0 +47,0 @@ export { CfnStreamInstance, StreamsDataProcessRegionCloudProvider, CfnStreamInstanceProps, StreamsDataProcessRegion, StreamConfig, StreamsConnection, StreamsConnectionType, } from "./l1-resources/stream-instance";

@@ -115,3 +115,2 @@ "use strict";

Object.defineProperty(exports, "CriteriaViewType", { enumerable: true, get: function () { return online_archive_1.CriteriaViewType; } });
Object.defineProperty(exports, "PartitionFieldViewFieldType", { enumerable: true, get: function () { return online_archive_1.PartitionFieldViewFieldType; } });
Object.defineProperty(exports, "ScheduleViewType", { enumerable: true, get: function () { return online_archive_1.ScheduleViewType; } });

@@ -187,2 +186,2 @@ var org_invitation_1 = require("./l1-resources/org-invitation");

__exportStar(require("./l3-resources/atlas-bootstrap"), exports);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\n// L1 Constructors\n\nexport {\n  CfnAccessListApiKey,\n  CfnAccessListApiKeyProps,\n} from \"./l1-resources/access-list-api-key\";\n\nexport {\n  CfnAlertConfiguration,\n  CfnAlertConfigurationProps,\n  IntegerThresholdView,\n  IntegerThresholdViewOperator,\n  Matcher,\n  MatcherFieldName,\n  MatcherOperator,\n  MetricThresholdView,\n  MetricThresholdViewMode,\n  MetricThresholdViewOperator,\n  NotificationView,\n  NotificationViewDatadogRegion,\n  NotificationViewTypeName,\n  NotificationViewOpsGenieRegion,\n  NotificationViewRoles,\n  NotificationViewSeverity,\n} from \"./l1-resources/alert-configuration\";\n\nexport {\n  CfnApiKey,\n  CfnApiKeyProps,\n  ProjectAssignment,\n} from \"./l1-resources/api-key\";\n\nexport { CfnAuditing, CfnAuditingProps } from \"./l1-resources/auditing\";\n\nexport {\n  CfnCloudBackUpRestoreJobs,\n  CfnCloudBackUpRestoreJobsProps,\n  CfnCloudBackUpRestoreJobsPropsDeliveryType,\n  CfnCloudBackUpRestoreJobsPropsInstanceType,\n  SynchronousCreationOptions,\n} from \"./l1-resources/cloud-backup-restore-jobs\";\n\nexport {\n  ApiAtlasDiskBackupCopySettingView,\n  ApiDeleteCopiedBackupsView,\n  ApiPolicyItemView,\n  ApiPolicyView,\n  CfnCloudBackupSchedule,\n  CfnCloudBackupScheduleProps,\n  Export,\n  Link,\n} from \"./l1-resources/cloud-backup-schedule\";\n\nexport {\n  ApiAtlasDiskBackupShardedClusterSnapshotMemberView,\n  ApiAtlasDiskBackupShardedClusterSnapshotMemberViewCloudProvider,\n  ApiAtlasDiskBackupShardedClusterSnapshotView,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewFrequencyType,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewSnapshotType,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewStatus,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewType,\n  CfnCloudBackupSnapshot,\n  CfnCloudBackupSnapshotProps,\n  CfnCloudBackupSnapshotPropsFrequencyType,\n  CfnCloudBackupSnapshotPropsSnapshotType,\n  CfnCloudBackupSnapshotPropsInstanceType,\n} from \"./l1-resources/cloud-backup-snapshot\";\n\nexport {\n  CfnCloudBackupSnapshotExportBucket,\n  CfnCloudBackupSnapshotExportBucketProps,\n} from \"./l1-resources/cloud-backup-snapshot-export-bucket\";\n\nexport {\n  CfnClusterOutageSimulation,\n  CfnClusterOutageSimulationProps,\n  Filter,\n  FilterCloudProvider,\n} from \"./l1-resources/cluster-outage-simulation\";\n\nexport {\n  CfnClusterProps,\n  ProcessArgs,\n  CfnClusterPropsBiConnector,\n  CfnClusterPropsLabels,\n  ConnectionStrings,\n  AdvancedReplicationSpec,\n  AdvancedAutoScaling,\n  Specs,\n  DiskGb,\n  Compute,\n  AdvancedRegionConfig,\n  CfnCluster,\n  CfnClusterPropsEncryptionAtRestProvider,\n  AdvancedRegionConfigProviderName,\n  Tag,\n} from \"./l1-resources/cluster\";\n\nexport {\n  Action,\n  CfnCustomDbRole,\n  CfnCustomDbRoleProps,\n  InheritedRole,\n  Resource,\n} from \"./l1-resources/custom-db-role\";\n\nexport {\n  CfnCustomDnsConfigurationClusterAws,\n  CfnCustomDnsConfigurationClusterAwsProps,\n} from \"./l1-resources/custom-dns-configuration-cluster-aws\";\n\nexport {\n  CfnDataLakePipeline,\n  CfnDataLakePipelineProps,\n  Sink,\n  SinkType,\n  Source,\n  SourceType,\n  Transformations,\n  PartitionFields,\n} from \"./l1-resources/data-lake-pipeline\";\n\nexport {\n  CfnDatabaseUser,\n  CfnDatabaseUserProps,\n  LabelDefinition,\n  RoleDefinition,\n  ScopeDefinition,\n  CfnDatabaseUserPropsX509Type,\n  CfnDatabaseUserPropsAwsiamType,\n  CfnDatabaseUserPropsLdapAuthType,\n  ScopeDefinitionType,\n} from \"./l1-resources/database-user\";\n\nexport {\n  CfnDataLakes,\n  CfnDataLakesProps,\n  DataLakeAwsCloudProviderConfigView,\n  DataLakeCloudProviderConfigView,\n  DataLakeDataProcessRegionView,\n  DataLakeDataProcessRegionViewCloudProvider,\n  DataLakeDataProcessRegionViewRegion,\n  DataLakeDatabaseCollectionView,\n  DataLakeDatabaseDataSourceView,\n  DataLakeDatabaseDataSourceViewDefaultFormat,\n  DataLakeDatabaseView,\n  DataLakeStorageView,\n  DataLakeViewView,\n  StoreDetail,\n} from \"./l1-resources/datalakes\";\n\nexport {\n  AwsKmsConfiguration,\n  CfnEncryptionAtRest,\n  CfnEncryptionAtRestProps,\n} from \"./l1-resources/encryption-at-rest\";\n\nexport {\n  CfnFederatedDatabaseInstance,\n  CfnFederatedDatabaseInstanceProps,\n  CloudProviderConfig,\n  DataProcessRegion,\n  Storage,\n  Database,\n  Store,\n  Collection,\n  DataSource,\n  ReadPreference,\n  TagSet,\n  View,\n} from \"./l1-resources/federated-database-instance\";\n\nexport {\n  CfnFederatedQueryLimit,\n  CfnFederatedQueryLimitProps,\n  CfnFederatedQueryLimitPropsLimitName,\n} from \"./l1-resources/federated-query-limit\";\n\nexport {\n  CfnFederatedSettingsOrgRoleMapping,\n  CfnFederatedSettingsOrgRoleMappingProps,\n  RoleAssignment,\n} from \"./l1-resources/federated-settings-org-role-mapping\";\n\nexport {\n  CfnGlobalClusterConfig,\n  CfnGlobalClusterConfigProps,\n  ManagedNamespace,\n  ZoneMapping,\n} from \"./l1-resources/global-cluster-config\";\n\nexport {\n  ApiAtlasNdsUserToDnMappingView,\n  CfnLdapConfiguration,\n  CfnLdapConfigurationProps,\n} from \"./l1-resources/ldap-configuration\";\n\nexport {\n  CfnLdapVerify,\n  CfnLdapVerifyProps,\n  Validation,\n} from \"./l1-resources/ldap-verify\";\n\nexport {\n  CfnMaintenanceWindow,\n  CfnMaintenanceWindowProps,\n} from \"./l1-resources/maintenance-window\";\n\nexport {\n  CfnNetworkContainer,\n  CfnNetworkContainerProps,\n} from \"./l1-resources/network-container\";\n\nexport {\n  CfnNetworkPeering,\n  CfnNetworkPeeringProps,\n} from \"./l1-resources/network-peering\";\n\nexport {\n  CfnOnlineArchive,\n  CfnOnlineArchiveProps,\n  CfnOnlineArchivePropsCollectionType,\n  CriteriaView,\n  CriteriaViewDateFormat,\n  CriteriaViewType,\n  PartitionFieldView,\n  PartitionFieldViewFieldType,\n  ScheduleView,\n  ScheduleViewType,\n} from \"./l1-resources/online-archive\";\n\nexport {\n  CfnOrgInvitation,\n  CfnOrgInvitationProps,\n  CfnOrgInvitationPropsRoles,\n} from \"./l1-resources/org-invitation\";\n\nexport {\n  CfnOrganization,\n  CfnOrganizationProps,\n  ApiKey,\n} from \"./l1-resources/organization\";\n\nexport {\n  CfnPrivateEndpointProps,\n  CfnPrivateEndpoint,\n  PrivateEndpoint,\n} from \"./l1-resources/private-endpoint\";\n\nexport {\n  CfnPrivateEndpointAdl,\n  CfnPrivateEndpointAdlProps,\n} from \"./l1-resources/private-endpoint-adl\";\n\nexport {\n  CfnPrivateEndpointAwsProps,\n  CfnPrivateEndpointAws,\n} from \"./l1-resources/private-endpoint-aws\";\n\nexport {\n  CfnPrivateEndPointRegionalMode,\n  CfnPrivateEndPointRegionalModeProps,\n} from \"./l1-resources/private-endpoint-regional-mode\";\n\nexport {\n  CfnPrivateEndpointService,\n  CfnPrivateEndpointServiceProps,\n  CfnPrivateEndpointServicePropsCloudProvider,\n} from \"./l1-resources/private-endpoint-service\";\n\nexport {\n  CfnPrivatelinkEndpointServiceDataFederationOnlineArchive,\n  CfnPrivatelinkEndpointServiceDataFederationOnlineArchiveProps,\n} from \"./l1-resources/privatelink-endpoint-service-data-federation-online-archive\";\n\nexport {\n  CfnProject,\n  CfnProjectProps,\n  ProjectApiKey,\n  ProjectSettings,\n  ProjectTeam,\n} from \"./l1-resources/project\";\n\nexport {\n  CfnProjectInvitation,\n  CfnProjectInvitationProps,\n  CfnProjectInvitationPropsRoles,\n} from \"./l1-resources/project-invitation\";\n\nexport {\n  AccessListDefinition,\n  CfnProjectIpAccessList,\n  CfnProjectIpAccessListProps,\n  ListOptions,\n} from \"./l1-resources/project-ip-access-list\";\n\nexport {\n  CfnSearchDeployment,\n  CfnSearchDeploymentProps,\n  ApiSearchDeploymentSpec,\n} from \"./l1-resources/search-deployment\";\n\nexport {\n  ApiAtlasFtsAnalyzersViewManual,\n  ApiAtlasFtsMappingsViewManual,\n  ApiAtlasFtsSynonymMappingDefinitionView,\n  CfnSearchIndex,\n  CfnSearchIndexProps,\n  SynonymSource,\n} from \"./l1-resources/search-index\";\n\nexport {\n  CfnServerlessInstance,\n  CfnServerlessInstanceProps,\n  ServerlessInstanceConnectionStrings,\n  ServerlessInstancePrivateEndpoint,\n  ServerlessInstancePrivateEndpointEndpoint,\n  ServerlessInstancePrivateEndpointType,\n  ServerlessInstanceProviderSettings,\n  ServerlessInstanceProviderSettingsProviderName,\n} from \"./l1-resources/serverless-instance\";\n\nexport {\n  CfnServerlessPrivateEndpointProps,\n  CfnServerlessPrivateEndpoint,\n  ServerlessPrivateEndpoint,\n  AwsPrivateEndpointConfig,\n} from \"./l1-resources/serverless-private-endpoint\";\n\nexport {\n  CfnStreamConnection,\n  CfnStreamConnectionProps,\n  CfnStreamConnectionPropsType,\n  DbRoleToExecute,\n  DbRoleToExecuteType,\n  StreamsKafkaAuthentication,\n  StreamsKafkaSecurity,\n} from \"./l1-resources/stream-connection\";\n\nexport {\n  CfnStreamInstance,\n  StreamsDataProcessRegionCloudProvider,\n  CfnStreamInstanceProps,\n  StreamsDataProcessRegion,\n  StreamConfig,\n  StreamsConnection,\n  StreamsConnectionType,\n} from \"./l1-resources/stream-instance\";\n\nexport {\n  CfnTeams,\n  CfnTeamsProps,\n  CfnTeamsPropsRoleNames,\n  AtlasRoleRoleName,\n  AtlasRole,\n  AtlasUser,\n} from \"./l1-resources/teams\";\n\nexport {\n  CfnThirdPartyIntegration,\n  CfnThirdPartyIntegrationProps,\n  CfnThirdPartyIntegrationPropsScheme,\n  CfnThirdPartyIntegrationPropsServiceDiscovery,\n  CfnThirdPartyIntegrationPropsType,\n} from \"./l1-resources/third-party-integration\";\n\nexport {\n  AuthConfig,\n  AuthConfigOperationType,\n  AuthConfigProviders,\n  CfnTrigger,\n  CfnTriggerProps,\n  DatabaseConfig,\n  DatabaseConfigOperationTypes,\n  Event,\n  EventAwseventbridge,\n  EventAwseventbridgeAwsConfig,\n  EventFunction,\n  EventFunctionFuncConfig,\n  ScheduleConfig,\n} from \"./l1-resources/trigger\";\n\nexport {\n  CfnX509AuthenticationDatabaseUser,\n  CfnX509AuthenticationDatabaseUserProps,\n  CustomerX509,\n} from \"./l1-resources/x509-authentication-database-user\";\n\n// L2 Constructors\n\nexport * from \"./l2-resources/encryption-at-rest\";\nexport * from \"./l2-resources/third-party-integration\";\n\n// L3 Constructors\n\nexport * from \"./l3-resources/common/props\";\n\nexport * from \"./l3-resources/atlas-basic\";\nexport * from \"./l3-resources/atlas-serverless-basic\";\nexport * from \"./l3-resources/atlas-basic-private-endpoint\";\nexport * from \"./l3-resources/encryption-at-rest-express\";\nexport * from \"./l3-resources/atlas-bootstrap\";\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA,6BAA6B;AAC7B,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,kDAAkD;AAClD,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;;;;;;;;;;;;AAEjC,kBAAkB;AAElB,0EAG4C;AAF1C,0HAAA,mBAAmB,OAAA;AAIrB,0EAiB4C;AAhB1C,4HAAA,qBAAqB,OAAA;AAGrB,mIAAA,4BAA4B,OAAA;AAE5B,uHAAA,gBAAgB,OAAA;AAChB,sHAAA,eAAe,OAAA;AAEf,8HAAA,uBAAuB,OAAA;AACvB,kIAAA,2BAA2B,OAAA;AAE3B,oIAAA,6BAA6B,OAAA;AAC7B,+HAAA,wBAAwB,OAAA;AACxB,qIAAA,8BAA8B,OAAA;AAC9B,4HAAA,qBAAqB,OAAA;AACrB,+HAAA,wBAAwB,OAAA;AAG1B,kDAIgC;AAH9B,oGAAA,SAAS,OAAA;AAKX,oDAAwE;AAA/D,uGAAA,WAAW,OAAA;AAEpB,sFAOkD;AANhD,sIAAA,yBAAyB,OAAA;AAGzB,uJAAA,0CAA0C,OAAA;AAC1C,uJAAA,0CAA0C,OAAA;AAI5C,8EAS8C;AAJ5C,+HAAA,sBAAsB,OAAA;AAMxB,8EAa8C;AAX5C,wKAAA,+DAA+D,OAAA;AAE/D,kKAAA,yDAAyD,OAAA;AACzD,iKAAA,wDAAwD,OAAA;AACxD,2JAAA,kDAAkD,OAAA;AAClD,yJAAA,gDAAgD,OAAA;AAChD,+HAAA,sBAAsB,OAAA;AAEtB,iJAAA,wCAAwC,OAAA;AACxC,gJAAA,uCAAuC,OAAA;AACvC,gJAAA,uCAAuC,OAAA;AAGzC,0GAG4D;AAF1D,yJAAA,kCAAkC,OAAA;AAIpC,sFAKkD;AAJhD,uIAAA,0BAA0B,OAAA;AAG1B,gIAAA,mBAAmB,OAAA;AAGrB,kDAgBgC;AAJ9B,qGAAA,UAAU,OAAA;AACV,kIAAA,uCAAuC,OAAA;AACvC,2HAAA,gCAAgC,OAAA;AAIlC,gEAMuC;AAJrC,iHAAA,eAAe,OAAA;AAMjB,4GAG6D;AAF3D,2JAAA,mCAAmC,OAAA;AAIrC,wEAS2C;AARzC,yHAAA,mBAAmB,OAAA;AAGnB,8GAAA,QAAQ,OAAA;AAER,gHAAA,UAAU,OAAA;AAKZ,8DAUsC;AATpC,gHAAA,eAAe,OAAA;AAKf,6HAAA,4BAA4B,OAAA;AAC5B,+HAAA,8BAA8B,OAAA;AAC9B,iIAAA,gCAAgC,OAAA;AAChC,oHAAA,mBAAmB,OAAA;AAGrB,sDAekC;AAdhC,yGAAA,YAAY,OAAA;AAKZ,uIAAA,0CAA0C,OAAA;AAC1C,gIAAA,mCAAmC,OAAA;AAGnC,wIAAA,2CAA2C,OAAA;AAO7C,wEAI2C;AAFzC,yHAAA,mBAAmB,OAAA;AAIrB,0FAaoD;AAZlD,2IAAA,4BAA4B,OAAA;AAc9B,8EAI8C;AAH5C,+HAAA,sBAAsB,OAAA;AAEtB,6IAAA,oCAAoC,OAAA;AAGtC,0GAI4D;AAH1D,yJAAA,kCAAkC,OAAA;AAKpC,8EAK8C;AAJ5C,+HAAA,sBAAsB,OAAA;AAMxB,wEAI2C;AAFzC,0HAAA,oBAAoB,OAAA;AAItB,0DAIoC;AAHlC,4GAAA,aAAa,OAAA;AAKf,wEAG2C;AAFzC,0HAAA,oBAAoB,OAAA;AAItB,sEAG0C;AAFxC,wHAAA,mBAAmB,OAAA;AAIrB,kEAGwC;AAFtC,oHAAA,iBAAiB,OAAA;AAInB,gEAUuC;AATrC,kHAAA,gBAAgB,OAAA;AAEhB,qIAAA,mCAAmC,OAAA;AAEnC,wHAAA,sBAAsB,OAAA;AACtB,kHAAA,gBAAgB,OAAA;AAGhB,kHAAA,gBAAgB,OAAA;AAGlB,gEAIuC;AAHrC,kHAAA,gBAAgB,OAAA;AAEhB,4HAAA,0BAA0B,OAAA;AAG5B,4DAIqC;AAHnC,+GAAA,eAAe,OAAA;AAKjB,oEAIyC;AAFvC,sHAAA,kBAAkB,OAAA;AAIpB,4EAG6C;AAF3C,6HAAA,qBAAqB,OAAA;AAIvB,4EAG6C;AAD3C,6HAAA,qBAAqB,OAAA;AAGvB,gGAGuD;AAFrD,gJAAA,8BAA8B,OAAA;AAIhC,oFAIiD;AAH/C,qIAAA,yBAAyB,OAAA;AAEzB,uJAAA,2CAA2C,OAAA;AAG7C,0JAGoF;AAFlF,uMAAA,wDAAwD,OAAA;AAI1D,kDAMgC;AAL9B,qGAAA,UAAU,OAAA;AAOZ,wEAI2C;AAHzC,0HAAA,oBAAoB,OAAA;AAEpB,oIAAA,8BAA8B,OAAA;AAGhC,gFAK+C;AAH7C,gIAAA,sBAAsB,OAAA;AAKxB,sEAI0C;AAHxC,wHAAA,mBAAmB,OAAA;AAKrB,4DAQqC;AAHnC,8GAAA,cAAc,OAAA;AAKhB,0EAS4C;AAR1C,4HAAA,qBAAqB,OAAA;AAKrB,4IAAA,qCAAqC,OAAA;AAErC,qJAAA,8CAA8C,OAAA;AAGhD,0FAIoD;AAFlD,2IAAA,4BAA4B,OAAA;AAI9B,sEAQ0C;AAPxC,wHAAA,mBAAmB,OAAA;AAEnB,iIAAA,4BAA4B,OAAA;AAE5B,wHAAA,mBAAmB,OAAA;AAKrB,kEAQwC;AAPtC,oHAAA,iBAAiB,OAAA;AACjB,wIAAA,qCAAqC,OAAA;AAKrC,wHAAA,qBAAqB,OAAA;AAGvB,8CAO8B;AAN5B,iGAAA,QAAQ,OAAA;AAER,+GAAA,sBAAsB,OAAA;AACtB,0GAAA,iBAAiB,OAAA;AAKnB,kFAMgD;AAL9C,mIAAA,wBAAwB,OAAA;AAExB,8IAAA,mCAAmC,OAAA;AACnC,wJAAA,6CAA6C,OAAA;AAC7C,4IAAA,iCAAiC,OAAA;AAGnC,kDAcgC;AAZ9B,kHAAA,uBAAuB,OAAA;AACvB,8GAAA,mBAAmB,OAAA;AACnB,qGAAA,UAAU,OAAA;AAGV,uHAAA,4BAA4B,OAAA;AAS9B,sGAI0D;AAHxD,sJAAA,iCAAiC,OAAA;AAKnC,kBAAkB;AAElB,oEAAkD;AAClD,yEAAuD;AAEvD,kBAAkB;AAElB,8DAA4C;AAE5C,6DAA2C;AAC3C,wEAAsD;AACtD,8EAA4D;AAC5D,4EAA0D;AAC1D,iEAA+C","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\n// L1 Constructors\n\nexport {\n  CfnAccessListApiKey,\n  CfnAccessListApiKeyProps,\n} from \"./l1-resources/access-list-api-key\";\n\nexport {\n  CfnAlertConfiguration,\n  CfnAlertConfigurationProps,\n  IntegerThresholdView,\n  IntegerThresholdViewOperator,\n  Matcher,\n  MatcherFieldName,\n  MatcherOperator,\n  MetricThresholdView,\n  MetricThresholdViewMode,\n  MetricThresholdViewOperator,\n  NotificationView,\n  NotificationViewDatadogRegion,\n  NotificationViewTypeName,\n  NotificationViewOpsGenieRegion,\n  NotificationViewRoles,\n  NotificationViewSeverity,\n} from \"./l1-resources/alert-configuration\";\n\nexport {\n  CfnApiKey,\n  CfnApiKeyProps,\n  ProjectAssignment,\n} from \"./l1-resources/api-key\";\n\nexport { CfnAuditing, CfnAuditingProps } from \"./l1-resources/auditing\";\n\nexport {\n  CfnCloudBackUpRestoreJobs,\n  CfnCloudBackUpRestoreJobsProps,\n  CfnCloudBackUpRestoreJobsPropsLinks,\n  CfnCloudBackUpRestoreJobsPropsDeliveryType,\n  CfnCloudBackUpRestoreJobsPropsInstanceType,\n  SynchronousCreationOptions,\n} from \"./l1-resources/cloud-backup-restore-jobs\";\n\nexport {\n  ApiAtlasDiskBackupCopySettingView,\n  ApiDeleteCopiedBackupsView,\n  ApiPolicyItemView,\n  ApiPolicyView,\n  CfnCloudBackupSchedule,\n  CfnCloudBackupScheduleProps,\n  Export,\n  Link,\n} from \"./l1-resources/cloud-backup-schedule\";\n\nexport {\n  ApiAtlasDiskBackupShardedClusterSnapshotMemberView,\n  ApiAtlasDiskBackupShardedClusterSnapshotMemberViewCloudProvider,\n  ApiAtlasDiskBackupShardedClusterSnapshotView,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewFrequencyType,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewSnapshotType,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewStatus,\n  ApiAtlasDiskBackupShardedClusterSnapshotViewType,\n  CfnCloudBackupSnapshot,\n  CfnCloudBackupSnapshotProps,\n  CfnCloudBackupSnapshotPropsFrequencyType,\n  CfnCloudBackupSnapshotPropsSnapshotType,\n  CfnCloudBackupSnapshotPropsInstanceType,\n} from \"./l1-resources/cloud-backup-snapshot\";\n\nexport {\n  CfnCloudBackupSnapshotExportBucket,\n  CfnCloudBackupSnapshotExportBucketProps,\n} from \"./l1-resources/cloud-backup-snapshot-export-bucket\";\n\nexport {\n  CfnClusterOutageSimulation,\n  CfnClusterOutageSimulationProps,\n  Filter,\n  FilterCloudProvider,\n} from \"./l1-resources/cluster-outage-simulation\";\n\nexport {\n  CfnClusterProps,\n  ProcessArgs,\n  CfnClusterPropsBiConnector,\n  CfnClusterPropsLabels,\n  ConnectionStrings,\n  AdvancedReplicationSpec,\n  AdvancedAutoScaling,\n  Specs,\n  DiskGb,\n  Compute,\n  AdvancedRegionConfig,\n  CfnCluster,\n  CfnClusterPropsEncryptionAtRestProvider,\n  AdvancedRegionConfigProviderName,\n  Tag,\n} from \"./l1-resources/cluster\";\n\nexport {\n  Action,\n  CfnCustomDbRole,\n  CfnCustomDbRoleProps,\n  InheritedRole,\n  Resource,\n} from \"./l1-resources/custom-db-role\";\n\nexport {\n  CfnCustomDnsConfigurationClusterAws,\n  CfnCustomDnsConfigurationClusterAwsProps,\n} from \"./l1-resources/custom-dns-configuration-cluster-aws\";\n\nexport {\n  CfnDataLakePipeline,\n  CfnDataLakePipelineProps,\n  Sink,\n  SinkType,\n  Source,\n  SourceType,\n  Transformations,\n  PartitionFields,\n} from \"./l1-resources/data-lake-pipeline\";\n\nexport {\n  CfnDatabaseUser,\n  CfnDatabaseUserProps,\n  LabelDefinition,\n  RoleDefinition,\n  ScopeDefinition,\n  CfnDatabaseUserPropsX509Type,\n  CfnDatabaseUserPropsAwsiamType,\n  CfnDatabaseUserPropsLdapAuthType,\n  ScopeDefinitionType,\n} from \"./l1-resources/database-user\";\n\nexport {\n  CfnDataLakes,\n  CfnDataLakesProps,\n  DataLakeAwsCloudProviderConfigView,\n  DataLakeCloudProviderConfigView,\n  DataLakeDataProcessRegionView,\n  DataLakeDataProcessRegionViewCloudProvider,\n  DataLakeDataProcessRegionViewRegion,\n  DataLakeDatabaseCollectionView,\n  DataLakeDatabaseDataSourceView,\n  DataLakeDatabaseDataSourceViewDefaultFormat,\n  DataLakeDatabaseView,\n  DataLakeStorageView,\n  DataLakeViewView,\n  StoreDetail,\n} from \"./l1-resources/datalakes\";\n\nexport {\n  AwsKmsConfig,\n  CfnEncryptionAtRest,\n  CfnEncryptionAtRestProps,\n} from \"./l1-resources/encryption-at-rest\";\n\nexport {\n  CfnFederatedDatabaseInstance,\n  CfnFederatedDatabaseInstanceProps,\n  CloudProviderConfig,\n  DataProcessRegion,\n  Storage,\n  Database,\n  Store,\n  Collection,\n  DataSource,\n  ReadPreference,\n  TagSet,\n  View,\n} from \"./l1-resources/federated-database-instance\";\n\nexport {\n  CfnFederatedQueryLimit,\n  CfnFederatedQueryLimitProps,\n  CfnFederatedQueryLimitPropsLimitName,\n} from \"./l1-resources/federated-query-limit\";\n\nexport {\n  CfnFederatedSettingsOrgRoleMapping,\n  CfnFederatedSettingsOrgRoleMappingProps,\n  RoleAssignment,\n} from \"./l1-resources/federated-settings-org-role-mapping\";\n\nexport {\n  CfnGlobalClusterConfig,\n  CfnGlobalClusterConfigProps,\n  ManagedNamespace,\n  ZoneMapping,\n} from \"./l1-resources/global-cluster-config\";\n\nexport {\n  ApiAtlasNdsUserToDnMappingView,\n  CfnLdapConfiguration,\n  CfnLdapConfigurationProps,\n} from \"./l1-resources/ldap-configuration\";\n\nexport {\n  CfnLdapVerify,\n  CfnLdapVerifyProps,\n  Validation,\n} from \"./l1-resources/ldap-verify\";\n\nexport {\n  CfnMaintenanceWindow,\n  CfnMaintenanceWindowProps,\n} from \"./l1-resources/maintenance-window\";\n\nexport {\n  CfnNetworkContainer,\n  CfnNetworkContainerProps,\n} from \"./l1-resources/network-container\";\n\nexport {\n  CfnNetworkPeering,\n  CfnNetworkPeeringProps,\n} from \"./l1-resources/network-peering\";\n\nexport {\n  CfnOnlineArchive,\n  CfnOnlineArchiveProps,\n  CfnOnlineArchivePropsCollectionType,\n  CriteriaView,\n  CriteriaViewDateFormat,\n  CriteriaViewType,\n  PartitionFieldView,\n  ScheduleView,\n  ScheduleViewType,\n} from \"./l1-resources/online-archive\";\n\nexport {\n  CfnOrgInvitation,\n  CfnOrgInvitationProps,\n  CfnOrgInvitationPropsRoles,\n} from \"./l1-resources/org-invitation\";\n\nexport {\n  CfnOrganization,\n  CfnOrganizationProps,\n  ApiKey,\n} from \"./l1-resources/organization\";\n\nexport {\n  CfnPrivateEndpointProps,\n  CfnPrivateEndpoint,\n  PrivateEndpoint,\n} from \"./l1-resources/private-endpoint\";\n\nexport {\n  CfnPrivateEndpointAdl,\n  CfnPrivateEndpointAdlProps,\n} from \"./l1-resources/private-endpoint-adl\";\n\nexport {\n  CfnPrivateEndpointAwsProps,\n  CfnPrivateEndpointAws,\n} from \"./l1-resources/private-endpoint-aws\";\n\nexport {\n  CfnPrivateEndPointRegionalMode,\n  CfnPrivateEndPointRegionalModeProps,\n} from \"./l1-resources/private-endpoint-regional-mode\";\n\nexport {\n  CfnPrivateEndpointService,\n  CfnPrivateEndpointServiceProps,\n  CfnPrivateEndpointServicePropsCloudProvider,\n} from \"./l1-resources/private-endpoint-service\";\n\nexport {\n  CfnPrivatelinkEndpointServiceDataFederationOnlineArchive,\n  CfnPrivatelinkEndpointServiceDataFederationOnlineArchiveProps,\n} from \"./l1-resources/privatelink-endpoint-service-data-federation-online-archive\";\n\nexport {\n  CfnProject,\n  CfnProjectProps,\n  ProjectApiKey,\n  ProjectSettings,\n  ProjectTeam,\n} from \"./l1-resources/project\";\n\nexport {\n  CfnProjectInvitation,\n  CfnProjectInvitationProps,\n  CfnProjectInvitationPropsRoles,\n} from \"./l1-resources/project-invitation\";\n\nexport {\n  AccessListDefinition,\n  CfnProjectIpAccessList,\n  CfnProjectIpAccessListProps,\n  ListOptions,\n} from \"./l1-resources/project-ip-access-list\";\n\nexport {\n  CfnSearchDeployment,\n  CfnSearchDeploymentProps,\n  ApiSearchDeploymentSpec,\n} from \"./l1-resources/search-deployment\";\n\nexport {\n  ApiAtlasFtsAnalyzersTokenizer,\n  ApiAtlasFtsAnalyzersViewManual,\n  ApiAtlasFtsMappingsViewManual,\n  ApiAtlasFtsSynonymMappingDefinitionView,\n  CfnSearchIndex,\n  CfnSearchIndexProps,\n  SynonymSource,\n} from \"./l1-resources/search-index\";\n\nexport {\n  CfnServerlessInstance,\n  CfnServerlessInstanceProps,\n  ServerlessInstanceConnectionStrings,\n  ServerlessInstancePrivateEndpoint,\n  ServerlessInstancePrivateEndpointEndpoint,\n  ServerlessInstancePrivateEndpointType,\n  ServerlessInstanceProviderSettings,\n  ServerlessInstanceProviderSettingsProviderName,\n} from \"./l1-resources/serverless-instance\";\n\nexport {\n  CfnServerlessPrivateEndpointProps,\n  CfnServerlessPrivateEndpoint,\n  AwsPrivateEndpointConfig,\n} from \"./l1-resources/serverless-private-endpoint\";\n\nexport {\n  CfnStreamConnection,\n  CfnStreamConnectionProps,\n  CfnStreamConnectionPropsType,\n  DbRoleToExecute,\n  DbRoleToExecuteType,\n  StreamsKafkaAuthentication,\n  StreamsKafkaSecurity,\n} from \"./l1-resources/stream-connection\";\n\nexport {\n  CfnStreamInstance,\n  StreamsDataProcessRegionCloudProvider,\n  CfnStreamInstanceProps,\n  StreamsDataProcessRegion,\n  StreamConfig,\n  StreamsConnection,\n  StreamsConnectionType,\n} from \"./l1-resources/stream-instance\";\n\nexport {\n  CfnTeams,\n  CfnTeamsProps,\n  CfnTeamsPropsRoleNames,\n  AtlasRoleRoleName,\n  AtlasRole,\n  AtlasUser,\n} from \"./l1-resources/teams\";\n\nexport {\n  CfnThirdPartyIntegration,\n  CfnThirdPartyIntegrationProps,\n  CfnThirdPartyIntegrationPropsScheme,\n  CfnThirdPartyIntegrationPropsServiceDiscovery,\n  CfnThirdPartyIntegrationPropsType,\n} from \"./l1-resources/third-party-integration\";\n\nexport {\n  AuthConfig,\n  AuthConfigOperationType,\n  AuthConfigProviders,\n  CfnTrigger,\n  CfnTriggerProps,\n  DatabaseConfig,\n  DatabaseConfigOperationTypes,\n  Event,\n  EventAwseventbridge,\n  EventAwseventbridgeAwsConfig,\n  EventFunction,\n  EventFunctionFuncConfig,\n  ScheduleConfig,\n} from \"./l1-resources/trigger\";\n\nexport {\n  CfnX509AuthenticationDatabaseUser,\n  CfnX509AuthenticationDatabaseUserProps,\n  CustomerX509,\n} from \"./l1-resources/x509-authentication-database-user\";\n\n// L2 Constructors\n\nexport * from \"./l2-resources/encryption-at-rest\";\nexport * from \"./l2-resources/third-party-integration\";\n\n// L3 Constructors\n\nexport * from \"./l3-resources/common/props\";\n\nexport * from \"./l3-resources/atlas-basic\";\nexport * from \"./l3-resources/atlas-serverless-basic\";\nexport * from \"./l3-resources/atlas-basic-private-endpoint\";\nexport * from \"./l3-resources/encryption-at-rest-express\";\nexport * from \"./l3-resources/atlas-bootstrap\";\n"]}

@@ -54,3 +54,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnAccessListApiKey[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAccessListApiKey", version: "3.7.2" };
CfnAccessListApiKey[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAccessListApiKey", version: "3.8.0" };
/**

@@ -57,0 +57,0 @@ * The CloudFormation resource type name for this resource class.

@@ -16,8 +16,2 @@ import * as cdk from "aws-cdk-lib";

/**
* Date and time when MongoDB Cloud created the alert configuration. This parameter expresses its value in the ISO 8601 timestamp format in UTC.
*
* @schema CfnAlertConfigurationProps#Created
*/
readonly created?: string;
/**
* Event type that triggers an alert.

@@ -193,14 +187,2 @@ *

/**
* Flowdock flow name to which MongoDB Cloud sends alert notifications. This name appears after the organization name in the Uniform Resource Locator (URL) path: 'www.flowdock.com/app/<organization-name>/<flow-name>'. The resource requires this parameter when '"notifications.typeName" : "FLOWDOCK"'.
*
* @schema NotificationView#FlowName
*/
readonly flowName?: string;
/**
* Flowdock API token that MongoDB Cloud needs to send alert notifications to Flowdock. The resource requires this parameter when '"notifications.typeName" : "FLOWDOCK"'. If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes the token.
*
* @schema NotificationView#FlowdockApiToken
*/
readonly flowdockApiToken?: string;
/**
* Number of minutes to wait between successive notifications. MongoDB Cloud sends notifications until someone acknowledges the unacknowledged alert.

@@ -569,2 +551,6 @@ *

/**
* Attribute `MongoDB::Atlas::AlertConfiguration.Created`
*/
readonly attrCreated: string;
/**
* Create a new `MongoDB::Atlas::AlertConfiguration`.

@@ -571,0 +557,0 @@ *

@@ -18,3 +18,2 @@ "use strict";

Profile: obj.profile,
Created: obj.created,
EventTypeName: obj.eventTypeName,

@@ -84,4 +83,2 @@ ProjectId: obj.projectId,

EmailEnabled: obj.emailEnabled,
FlowName: obj.flowName,
FlowdockApiToken: obj.flowdockApiToken,
IntervalMin: obj.intervalMin,

@@ -341,2 +338,3 @@ MicrosoftTeamsWebhookUrl: obj.microsoftTeamsWebhookUrl,

this.attrUpdated = cdk.Token.asString(this.getAtt("Updated"));
this.attrCreated = cdk.Token.asString(this.getAtt("Created"));
}

@@ -346,3 +344,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnAlertConfiguration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAlertConfiguration", version: "3.7.2" };
CfnAlertConfiguration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAlertConfiguration", version: "3.8.0" };
/**

@@ -352,2 +350,2 @@ * The CloudFormation resource type name for this resource class.

CfnAlertConfiguration.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::AlertConfiguration";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/alert-configuration/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAyEnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,iCAAiC,CAC/C,GAA2C;IAE3C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QACrD,eAAe,EAAE,0BAA0B,CAAC,GAAG,CAAC,eAAe,CAAC;QAChE,aAAa,EAAE,GAAG,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;QACxE,SAAS,EAAE,2BAA2B,CAAC,GAAG,CAAC,SAAS,CAAC;QACrD,QAAQ,EAAE,GAAG,CAAC,QAAQ;KACvB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAtBD,8EAsBC;AA6BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,cAAc,CAC5B,GAAwB;IAExB,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,KAAK,EAAE,GAAG,CAAC,KAAK;KACjB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,wCAgBC;AA2CD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,0BAA0B,CACxC,GAAoC;IAEpC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;KACjB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,gEAkBC;AAoOD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,uBAAuB,CACrC,GAAiC;IAEjC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;QACtC,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,wBAAwB,EAAE,GAAG,CAAC,wBAAwB;QACtD,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,iBAAiB,EAAE,GAAG,CAAC,iBAAiB;QACxC,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QAC/B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,UAAU,EAAE,GAAG,CAAC,UAAU;KAC3B,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AA1CD,0DA0CC;AA6BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,2BAA2B,CACzC,GAAqC;IAErC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;KACjB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,kEAgBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,gBAqBX;AArBD,WAAY,gBAAgB;IAC1B,mBAAmB;IACnB,iDAA6B,CAAA;IAC7B,eAAe;IACf,yCAAqB,CAAA;IACrB,wBAAwB;IACxB,2DAAuC,CAAA;IACvC,WAAW;IACX,iCAAa,CAAA;IACb,uBAAuB;IACvB,yDAAqC,CAAA;IACrC,iBAAiB;IACjB,6CAAyB,CAAA;IACzB,gBAAgB;IAChB,2CAAuB,CAAA;IACvB,qBAAqB;IACrB,qDAAiC,CAAA;IACjC,oBAAoB;IACpB,mDAA+B,CAAA;IAC/B,qBAAqB;IACrB,qDAAiC,CAAA;AACnC,CAAC,EArBW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAqB3B;AAED;;;;GAIG;AACH,IAAY,eAeX;AAfD,WAAY,eAAe;IACzB,aAAa;IACb,oCAAiB,CAAA;IACjB,eAAe;IACf,wCAAqB,CAAA;IACrB,kBAAkB;IAClB,8CAA2B,CAAA;IAC3B,gBAAgB;IAChB,0CAAuB,CAAA;IACvB,iBAAiB;IACjB,4CAAyB,CAAA;IACzB,mBAAmB;IACnB,gDAA6B,CAAA;IAC7B,YAAY;IACZ,kCAAe,CAAA;AACjB,CAAC,EAfW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAe1B;AAED;;;;GAIG;AACH,IAAY,uBAGX;AAHD,WAAY,uBAAuB;IACjC,cAAc;IACd,8CAAmB,CAAA;AACrB,CAAC,EAHW,uBAAuB,GAAvB,+BAAuB,KAAvB,+BAAuB,QAGlC;AAED;;;;GAIG;AACH,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,mBAAmB;IACnB,4DAA6B,CAAA;IAC7B,gBAAgB;IAChB,sDAAuB,CAAA;AACzB,CAAC,EALW,2BAA2B,GAA3B,mCAA2B,KAA3B,mCAA2B,QAKtC;AAED;;;;GAIG;AACH,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,SAAS;IACT,0CAAS,CAAA;IACT,SAAS;IACT,0CAAS,CAAA;AACX,CAAC,EALW,6BAA6B,GAA7B,qCAA6B,KAA7B,qCAA6B,QAKxC;AAED;;;;GAIG;AACH,IAAY,8BAKX;AALD,WAAY,8BAA8B;IACxC,SAAS;IACT,2CAAS,CAAA;IACT,SAAS;IACT,2CAAS,CAAA;AACX,CAAC,EALW,8BAA8B,GAA9B,sCAA8B,KAA9B,sCAA8B,QAKzC;AAED;;GAEG;AACH,IAAY,qBAuBX;AAvBD,WAAY,qBAAqB;IAC/B,4BAA4B;IAC5B,wEAA+C,CAAA;IAC/C,8BAA8B;IAC9B,4EAAmD,CAAA;IACnD,kCAAkC;IAClC,oFAA2D,CAAA;IAC3D,mCAAmC;IACnC,sFAA6D,CAAA;IAC7D,kBAAkB;IAClB,oDAA2B,CAAA;IAC3B,uBAAuB;IACvB,8DAAqC,CAAA;IACrC,gBAAgB;IAChB,gDAAuB,CAAA;IACvB,iBAAiB;IACjB,kDAAyB,CAAA;IACzB,wBAAwB;IACxB,gEAAuC,CAAA;IACvC,wBAAwB;IACxB,gEAAuC,CAAA;IACvC,oBAAoB;IACpB,wDAA+B,CAAA;AACjC,CAAC,EAvBW,qBAAqB,GAArB,6BAAqB,KAArB,6BAAqB,QAuBhC;AAED;;;;GAIG;AACH,IAAY,wBAOX;AAPD,WAAY,wBAAwB;IAClC,eAAe;IACf,iDAAqB,CAAA;IACrB,YAAY;IACZ,2CAAe,CAAA;IACf,cAAc;IACd,+CAAmB,CAAA;AACrB,CAAC,EAPW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QAOnC;AAED;;;;GAIG;AACH,IAAY,wBA+BX;AA/BD,WAAY,wBAAwB;IAClC,cAAc;IACd,+CAAmB,CAAA;IACnB,YAAY;IACZ,2CAAe,CAAA;IACf,eAAe;IACf,iDAAqB,CAAA;IACrB,YAAY;IACZ,2CAAe,CAAA;IACf,sBAAsB;IACtB,+DAAmC,CAAA;IACnC,gBAAgB;IAChB,mDAAuB,CAAA;IACvB,UAAU;IACV,uCAAW,CAAA;IACX,iBAAiB;IACjB,qDAAyB,CAAA;IACzB,iBAAiB;IACjB,qDAAyB,CAAA;IACzB,YAAY;IACZ,2CAAe,CAAA;IACf,UAAU;IACV,uCAAW,CAAA;IACX,WAAW;IACX,yCAAa,CAAA;IACb,WAAW;IACX,yCAAa,CAAA;IACb,iBAAiB;IACjB,qDAAyB,CAAA;IACzB,cAAc;IACd,+CAAmB,CAAA;AACrB,CAAC,EA/BW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QA+BnC;AAED;;;;GAIG;AACH,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,mBAAmB;IACnB,6DAA6B,CAAA;IAC7B,gBAAgB;IAChB,uDAAuB,CAAA;AACzB,CAAC,EALW,4BAA4B,GAA5B,oCAA4B,KAA5B,oCAA4B,QAKvC;AAED;;;;;GAKG;AACH,MAAa,qBAAsB,SAAQ,GAAG,CAAC,WAAW;IAyBxD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAiC;QAEjC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,qBAAqB,CAAC,sBAAsB;YAClD,UAAU,EAAE,iCAAiC,CAAC,KAAK,CAAE;SACtD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;IAChE,CAAC;;AA/CH,sDAgDC;;;AA/CC;;GAEG;AACoB,4CAAsB,GAC3C,oCAAoC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns and edits the conditions that trigger alerts and how MongoDB Cloud notifies users. This collection remains under revision and may change. Refer to the legacy documentation for this collection in the following link.\n *\n * @schema CfnAlertConfigurationProps\n */\nexport interface CfnAlertConfigurationProps {\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnAlertConfigurationProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Date and time when MongoDB Cloud created the alert configuration. This parameter expresses its value in the ISO 8601 timestamp format in UTC.\n   *\n   * @schema CfnAlertConfigurationProps#Created\n   */\n  readonly created?: string;\n\n  /**\n   * Event type that triggers an alert.\n   *\n   * @schema CfnAlertConfigurationProps#EventTypeName\n   */\n  readonly eventTypeName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnAlertConfigurationProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * List of rules that determine whether MongoDB Cloud checks an object for the alert configuration. You can filter using the matchers array if the **eventTypeName** specifies an event for a host, replica set, or sharded cluster.\n   *\n   * @schema CfnAlertConfigurationProps#Matchers\n   */\n  readonly matchers?: Matcher[];\n\n  /**\n   * Threshold for the metric that, when exceeded, triggers an alert. The resource returns this parameter when '\"eventTypeName\" : \"OUTSIDE_METRIC_THRESHOLD\"'.\n   *\n   * @schema CfnAlertConfigurationProps#MetricThreshold\n   */\n  readonly metricThreshold?: MetricThresholdView;\n\n  /**\n   * List that contains the targets that MongoDB Cloud sends notifications.\n   *\n   * @schema CfnAlertConfigurationProps#Notifications\n   */\n  readonly notifications?: NotificationView[];\n\n  /**\n   * Limit that triggers an alert when exceeded. The resource returns this parameter when **eventTypeName** has not been set to 'OUTSIDE_METRIC_THRESHOLD'.\n   *\n   * @schema CfnAlertConfigurationProps#Threshold\n   */\n  readonly threshold?: IntegerThresholdView;\n\n  /**\n   * Human-readable label that displays the alert type.\n   *\n   * @schema CfnAlertConfigurationProps#TypeName\n   */\n  readonly typeName?: string;\n}\n\n/**\n * Converts an object of type 'CfnAlertConfigurationProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnAlertConfigurationProps(\n  obj: CfnAlertConfigurationProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    Created: obj.created,\n    EventTypeName: obj.eventTypeName,\n    ProjectId: obj.projectId,\n    Matchers: obj.matchers?.map((y) => toJson_Matcher(y)),\n    MetricThreshold: toJson_MetricThresholdView(obj.metricThreshold),\n    Notifications: obj.notifications?.map((y) => toJson_NotificationView(y)),\n    Threshold: toJson_IntegerThresholdView(obj.threshold),\n    TypeName: obj.typeName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Matcher\n */\nexport interface Matcher {\n  /**\n   * Name of the parameter in the target object that MongoDB Cloud checks. The parameter must match all rules for MongoDB Cloud to check for alert configurations.\n   *\n   * @schema Matcher#FieldName\n   */\n  readonly fieldName?: MatcherFieldName;\n\n  /**\n   * Comparison operator to apply when checking the current metric value against **matcher[n].value**.\n   *\n   * @schema Matcher#Operator\n   */\n  readonly operator?: MatcherOperator;\n\n  /**\n   * Value to match or exceed using the specified **matchers.operator**.\n   *\n   * @schema Matcher#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'Matcher' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Matcher(\n  obj: Matcher | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FieldName: obj.fieldName,\n    Operator: obj.operator,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema MetricThresholdView\n */\nexport interface MetricThresholdView {\n  /**\n   * Human-readable label that identifies the metric against which MongoDB Cloud checks the configured **metricThreshold.threshold**.\n   *\n   * @schema MetricThresholdView#MetricName\n   */\n  readonly metricName?: string;\n\n  /**\n   * MongoDB Cloud computes the current metric value as an average.\n   *\n   * @schema MetricThresholdView#Mode\n   */\n  readonly mode?: MetricThresholdViewMode;\n\n  /**\n   * Comparison operator to apply when checking the current metric value.\n   *\n   * @schema MetricThresholdView#Operator\n   */\n  readonly operator?: MetricThresholdViewOperator;\n\n  /**\n   * Value of metric that, when exceeded, triggers an alert.\n   *\n   * @schema MetricThresholdView#Threshold\n   */\n  readonly threshold?: number;\n\n  /**\n   * Element used to express the quantity. This can be an element of time, storage capacity, and the like.\n   *\n   * @schema MetricThresholdView#Units\n   */\n  readonly units?: string;\n}\n\n/**\n * Converts an object of type 'MetricThresholdView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_MetricThresholdView(\n  obj: MetricThresholdView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    MetricName: obj.metricName,\n    Mode: obj.mode,\n    Operator: obj.operator,\n    Threshold: obj.threshold,\n    Units: obj.units,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema NotificationView\n */\nexport interface NotificationView {\n  /**\n   * Slack API token or Bot token that MongoDB Cloud needs to send alert notifications via Slack. The resource requires this parameter when '\"notifications.typeName\" : \"SLACK\"'. If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes the token.\n   *\n   * @schema NotificationView#ApiToken\n   */\n  readonly apiToken?: string;\n\n  /**\n   * Name of the Slack channel to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"SLACK\"'.\n   *\n   * @schema NotificationView#ChannelName\n   */\n  readonly channelName?: string;\n\n  /**\n   * Datadog API Key that MongoDB Cloud needs to send alert notifications to Datadog. You can find this API key in the Datadog dashboard. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n   *\n   * @schema NotificationView#DatadogApiKey\n   */\n  readonly datadogApiKey?: string;\n\n  /**\n   * Datadog region that indicates which API Uniform Resource Locator (URL) to use. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n   *\n   * @schema NotificationView#DatadogRegion\n   */\n  readonly datadogRegion?: NotificationViewDatadogRegion;\n\n  /**\n   * Number of minutes that MongoDB Cloud waits after detecting an alert condition before it sends out the first notification.\n   *\n   * @schema NotificationView#DelayMin\n   */\n  readonly delayMin?: number;\n\n  /**\n   * Email address to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"EMAIL\"'. You don't need to set this value to send emails to individual or groups of MongoDB Cloud users including:\n   *\n   * - specific MongoDB Cloud users ('\"notifications.typeName\" : \"USER\"')\n   * - MongoDB Cloud users with specific project roles ('\"notifications.typeName\" : \"GROUP\"')\n   * - MongoDB Cloud users with specific organization roles ('\"notifications.typeName\" : \"ORG\"')\n   * - MongoDB Cloud teams ('\"notifications.typeName\" : \"TEAM\"')\n   *\n   * To send emails to one MongoDB Cloud user or grouping of users, set the **notifications.emailEnabled** parameter.\n   *\n   * @schema NotificationView#EmailAddress\n   */\n  readonly emailAddress?: string;\n\n  /**\n   * Flag that indicates whether MongoDB Cloud should send email notifications. The resource requires this parameter when one of the following values have been set:\n   *\n   * - '\"notifications.typeName\" : \"ORG\"'\n   * - '\"notifications.typeName\" : \"GROUP\"'\n   * - '\"notifications.typeName\" : \"USER\"'\n   *\n   * @schema NotificationView#EmailEnabled\n   */\n  readonly emailEnabled?: boolean;\n\n  /**\n   * Flowdock flow name to which MongoDB Cloud sends alert notifications. This name appears after the organization name in the Uniform Resource Locator (URL) path: 'www.flowdock.com/app/<organization-name>/<flow-name>'. The resource requires this parameter when '\"notifications.typeName\" : \"FLOWDOCK\"'.\n   *\n   * @schema NotificationView#FlowName\n   */\n  readonly flowName?: string;\n\n  /**\n   * Flowdock API token that MongoDB Cloud needs to send alert notifications to Flowdock. The resource requires this parameter when '\"notifications.typeName\" : \"FLOWDOCK\"'. If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes the token.\n   *\n   * @schema NotificationView#FlowdockApiToken\n   */\n  readonly flowdockApiToken?: string;\n\n  /**\n   * Number of minutes to wait between successive notifications. MongoDB Cloud sends notifications until someone acknowledges the unacknowledged alert.\n   *\n   * PagerDuty, VictorOps, and OpsGenie notifications don't return this element. Configure and manage the notification interval within each of those services.\n   *\n   * @schema NotificationView#IntervalMin\n   */\n  readonly intervalMin?: number;\n\n  /**\n   * Microsoft Teams Webhook Uniform Resource Locator (URL) that MongoDB Cloud needs to send this notification via Microsoft Teams. The resource requires this parameter when '\"notifications.typeName\" : \"MICROSOFT_TEAMS\"'. If the URL later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#MicrosoftTeamsWebhookUrl\n   */\n  readonly microsoftTeamsWebhookUrl?: string;\n\n  /**\n   * Mobile phone number to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"SMS\"'.\n   *\n   * @schema NotificationView#MobileNumber\n   */\n  readonly mobileNumber?: string;\n\n  /**\n   * HipChat API token that MongoDB Cloud needs to send alert notifications to HipChat. The resource requires this parameter when '\"notifications.typeName\" : \"HIP_CHAT\"'\". If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#NotificationToken\n   */\n  readonly notificationToken?: string;\n\n  /**\n   * API Key that MongoDB Cloud needs to send this notification via Opsgenie. The resource requires this parameter when '\"notifications.typeName\" : \"OPS_GENIE\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#OpsGenieApiKey\n   */\n  readonly opsGenieApiKey?: string;\n\n  /**\n   * Opsgenie region that indicates which API Uniform Resource Locator (URL) to use.\n   *\n   * @schema NotificationView#OpsGenieRegion\n   */\n  readonly opsGenieRegion?: NotificationViewOpsGenieRegion;\n\n  /**\n   * Flowdock organization name to which MongoDB Cloud sends alert notifications. This name appears after 'www.flowdock.com/app/' in the Uniform Resource Locator (URL) path. The resource requires this parameter when '\"notifications.typeName\" : \"FLOWDOCK\"'.\n   *\n   * @schema NotificationView#OrgName\n   */\n  readonly orgName?: string;\n\n  /**\n   * List that contains the one or more organization or project roles that receive the configured alert. The resource requires this parameter when '\"notifications.typeName\" : \"GROUP\"' or '\"notifications.typeName\" : \"ORG\"'. If you include this parameter, MongoDB Cloud sends alerts only to users assigned the roles you specify in the array. If you omit this parameter, MongoDB Cloud sends alerts to users assigned any role.\n   *\n   * @schema NotificationView#Roles\n   */\n  readonly roles?: NotificationViewRoles[];\n\n  /**\n   * HipChat API room name to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"HIP_CHAT\"'\".\n   *\n   * @schema NotificationView#RoomName\n   */\n  readonly roomName?: string;\n\n  /**\n   * PagerDuty service key that MongoDB Cloud needs to send notifications via PagerDuty. The resource requires this parameter when '\"notifications.typeName\" : \"PAGER_DUTY\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#ServiceKey\n   */\n  readonly serviceKey?: string;\n\n  /**\n   * Degree of seriousness given to this notification.\n   *\n   * @schema NotificationView#Severity\n   */\n  readonly severity?: NotificationViewSeverity;\n\n  /**\n   * Flag that indicates whether MongoDB Cloud should send text message notifications. The resource requires this parameter when one of the following values have been set:\n   *\n   * - '\"notifications.typeName\" : \"ORG\"'\n   * - '\"notifications.typeName\" : \"GROUP\"'\n   * - '\"notifications.typeName\" : \"USER\"'\n   *\n   * @schema NotificationView#SmsEnabled\n   */\n  readonly smsEnabled?: boolean;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies one MongoDB Cloud team. The resource requires this parameter when '\"notifications.typeName\" : \"TEAM\"'.\n   *\n   * @schema NotificationView#TeamId\n   */\n  readonly teamId?: string;\n\n  /**\n   * Name of the MongoDB Cloud team that receives this notification. The resource requires this parameter when '\"notifications.typeName\" : \"TEAM\"'.\n   *\n   * @schema NotificationView#TeamName\n   */\n  readonly teamName?: string;\n\n  /**\n   * Human-readable label that displays the alert notification type.\n   *\n   * @schema NotificationView#TypeName\n   */\n  readonly typeName?: NotificationViewTypeName;\n\n  /**\n   * MongoDB Cloud username of the person to whom MongoDB Cloud sends notifications. Specify only MongoDB Cloud users who belong to the project that owns the alert configuration. The resource requires this parameter when '\"notifications.typeName\" : \"USER\"'.\n   *\n   * @schema NotificationView#Username\n   */\n  readonly username?: string;\n\n  /**\n   * API key that MongoDB Cloud needs to send alert notifications to Splunk On-Call. The resource requires this parameter when '\"notifications.typeName\" : \"VICTOR_OPS\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#VictorOpsApiKey\n   */\n  readonly victorOpsApiKey?: string;\n\n  /**\n   * Routing key that MongoDB Cloud needs to send alert notifications to Splunk On-Call. The resource requires this parameter when '\"notifications.typeName\" : \"VICTOR_OPS\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#VictorOpsRoutingKey\n   */\n  readonly victorOpsRoutingKey?: string;\n\n  /**\n   * An optional field for your webhook secret.\n   *\n   * @schema NotificationView#WebhookSecret\n   */\n  readonly webhookSecret?: string;\n\n  /**\n   * Your webhook URL.\n   *\n   * @schema NotificationView#WebhookUrl\n   */\n  readonly webhookUrl?: string;\n}\n\n/**\n * Converts an object of type 'NotificationView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_NotificationView(\n  obj: NotificationView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ApiToken: obj.apiToken,\n    ChannelName: obj.channelName,\n    DatadogApiKey: obj.datadogApiKey,\n    DatadogRegion: obj.datadogRegion,\n    DelayMin: obj.delayMin,\n    EmailAddress: obj.emailAddress,\n    EmailEnabled: obj.emailEnabled,\n    FlowName: obj.flowName,\n    FlowdockApiToken: obj.flowdockApiToken,\n    IntervalMin: obj.intervalMin,\n    MicrosoftTeamsWebhookUrl: obj.microsoftTeamsWebhookUrl,\n    MobileNumber: obj.mobileNumber,\n    NotificationToken: obj.notificationToken,\n    OpsGenieApiKey: obj.opsGenieApiKey,\n    OpsGenieRegion: obj.opsGenieRegion,\n    OrgName: obj.orgName,\n    Roles: obj.roles?.map((y) => y),\n    RoomName: obj.roomName,\n    ServiceKey: obj.serviceKey,\n    Severity: obj.severity,\n    SmsEnabled: obj.smsEnabled,\n    TeamId: obj.teamId,\n    TeamName: obj.teamName,\n    TypeName: obj.typeName,\n    Username: obj.username,\n    VictorOpsApiKey: obj.victorOpsApiKey,\n    VictorOpsRoutingKey: obj.victorOpsRoutingKey,\n    WebhookSecret: obj.webhookSecret,\n    WebhookUrl: obj.webhookUrl,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema IntegerThresholdView\n */\nexport interface IntegerThresholdView {\n  /**\n   * Comparison operator to apply when checking the current metric value.\n   *\n   * @schema IntegerThresholdView#Operator\n   */\n  readonly operator?: IntegerThresholdViewOperator;\n\n  /**\n   * Value of metric that, when exceeded, triggers an alert.\n   *\n   * @schema IntegerThresholdView#Threshold\n   */\n  readonly threshold?: number;\n\n  /**\n   * Element used to express the quantity. This can be an element of time, storage capacity, and the like.\n   *\n   * @schema IntegerThresholdView#Units\n   */\n  readonly units?: string;\n}\n\n/**\n * Converts an object of type 'IntegerThresholdView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_IntegerThresholdView(\n  obj: IntegerThresholdView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Operator: obj.operator,\n    Threshold: obj.threshold,\n    Units: obj.units,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Name of the parameter in the target object that MongoDB Cloud checks. The parameter must match all rules for MongoDB Cloud to check for alert configurations.\n *\n * @schema MatcherFieldName\n */\nexport enum MatcherFieldName {\n  /** CLUSTER_NAME */\n  CLUSTER_NAME = \"CLUSTER_NAME\",\n  /** HOSTNAME */\n  HOSTNAME = \"HOSTNAME\",\n  /** HOSTNAME_AND_PORT */\n  HOSTNAME_AND_PORT = \"HOSTNAME_AND_PORT\",\n  /** PORT */\n  PORT = \"PORT\",\n  /** REPLICA_SET_NAME */\n  REPLICA_SET_NAME = \"REPLICA_SET_NAME\",\n  /** SHARD_NAME */\n  SHARD_NAME = \"SHARD_NAME\",\n  /** TYPE_NAME */\n  TYPE_NAME = \"TYPE_NAME\",\n  /** APPLICATION_ID */\n  APPLICATION_ID = \"APPLICATION_ID\",\n  /** INSTANCE_NAME */\n  INSTANCE_NAME = \"INSTANCE_NAME\",\n  /** PROCESSOR_NAME */\n  PROCESSOR_NAME = \"PROCESSOR_NAME\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value against **matcher[n].value**.\n *\n * @schema MatcherOperator\n */\nexport enum MatcherOperator {\n  /** EQUALS */\n  EQUALS = \"EQUALS\",\n  /** CONTAINS */\n  CONTAINS = \"CONTAINS\",\n  /** STARTS_WITH */\n  STARTS_WITH = \"STARTS_WITH\",\n  /** ENDS_WITH */\n  ENDS_WITH = \"ENDS_WITH\",\n  /** NOT_EQUALS */\n  NOT_EQUALS = \"NOT_EQUALS\",\n  /** NOT_CONTAINS */\n  NOT_CONTAINS = \"NOT_CONTAINS\",\n  /** REGEX */\n  REGEX = \"REGEX\",\n}\n\n/**\n * MongoDB Cloud computes the current metric value as an average.\n *\n * @schema MetricThresholdViewMode\n */\nexport enum MetricThresholdViewMode {\n  /** AVERAGE */\n  AVERAGE = \"AVERAGE\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value.\n *\n * @schema MetricThresholdViewOperator\n */\nexport enum MetricThresholdViewOperator {\n  /** GREATER_THAN */\n  GREATER_THAN = \"GREATER_THAN\",\n  /** LESS_THAN */\n  LESS_THAN = \"LESS_THAN\",\n}\n\n/**\n * Datadog region that indicates which API Uniform Resource Locator (URL) to use. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n *\n * @schema NotificationViewDatadogRegion\n */\nexport enum NotificationViewDatadogRegion {\n  /** EU */\n  EU = \"EU\",\n  /** US */\n  US = \"US\",\n}\n\n/**\n * Opsgenie region that indicates which API Uniform Resource Locator (URL) to use.\n *\n * @schema NotificationViewOpsGenieRegion\n */\nexport enum NotificationViewOpsGenieRegion {\n  /** EU */\n  EU = \"EU\",\n  /** US */\n  US = \"US\",\n}\n\n/**\n * @schema NotificationViewRoles\n */\nexport enum NotificationViewRoles {\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_WRITE */\n  GROUP_READ_WRITE = \"GROUP_READ_WRITE\",\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n}\n\n/**\n * Degree of seriousness given to this notification.\n *\n * @schema NotificationViewSeverity\n */\nexport enum NotificationViewSeverity {\n  /** CRITICAL */\n  CRITICAL = \"CRITICAL\",\n  /** ERROR */\n  ERROR = \"ERROR\",\n  /** WARNING */\n  WARNING = \"WARNING\",\n}\n\n/**\n * Human-readable label that displays the alert notification type.\n *\n * @schema NotificationViewTypeName\n */\nexport enum NotificationViewTypeName {\n  /** DATADOG */\n  DATADOG = \"DATADOG\",\n  /** EMAIL */\n  EMAIL = \"EMAIL\",\n  /** FLOWDOCK */\n  FLOWDOCK = \"FLOWDOCK\",\n  /** GROUP */\n  GROUP = \"GROUP\",\n  /** MICROSOFT_TEAMS */\n  MICROSOFT_TEAMS = \"MICROSOFT_TEAMS\",\n  /** OPS_GENIE */\n  OPS_GENIE = \"OPS_GENIE\",\n  /** ORG */\n  ORG = \"ORG\",\n  /** PAGER_DUTY */\n  PAGER_DUTY = \"PAGER_DUTY\",\n  /** PROMETHEUS */\n  PROMETHEUS = \"PROMETHEUS\",\n  /** SLACK */\n  SLACK = \"SLACK\",\n  /** SMS */\n  SMS = \"SMS\",\n  /** TEAM */\n  TEAM = \"TEAM\",\n  /** USER */\n  USER = \"USER\",\n  /** VICTOR_OPS */\n  VICTOR_OPS = \"VICTOR_OPS\",\n  /** WEBHOOK */\n  WEBHOOK = \"WEBHOOK\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value.\n *\n * @schema IntegerThresholdViewOperator\n */\nexport enum IntegerThresholdViewOperator {\n  /** GREATER_THAN */\n  GREATER_THAN = \"GREATER_THAN\",\n  /** LESS_THAN */\n  LESS_THAN = \"LESS_THAN\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::AlertConfiguration`\n *\n * @cloudformationResource MongoDB::Atlas::AlertConfiguration\n * @stability external\n */\nexport class CfnAlertConfiguration extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::AlertConfiguration\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnAlertConfigurationProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Enabled`\n   */\n  public readonly attrEnabled: cdk.IResolvable;\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Updated`\n   */\n  public readonly attrUpdated: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::AlertConfiguration`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnAlertConfigurationProps\n  ) {\n    super(scope, id, {\n      type: CfnAlertConfiguration.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnAlertConfigurationProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEnabled = this.getAtt(\"Enabled\");\n    this.attrUpdated = cdk.Token.asString(this.getAtt(\"Updated\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/alert-configuration/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns and edits the conditions that trigger alerts and how MongoDB Cloud notifies users. This collection remains under revision and may change. Refer to the legacy documentation for this collection in the following link.\n *\n * @schema CfnAlertConfigurationProps\n */\nexport interface CfnAlertConfigurationProps {\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnAlertConfigurationProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Event type that triggers an alert.\n   *\n   * @schema CfnAlertConfigurationProps#EventTypeName\n   */\n  readonly eventTypeName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnAlertConfigurationProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * List of rules that determine whether MongoDB Cloud checks an object for the alert configuration. You can filter using the matchers array if the **eventTypeName** specifies an event for a host, replica set, or sharded cluster.\n   *\n   * @schema CfnAlertConfigurationProps#Matchers\n   */\n  readonly matchers?: Matcher[];\n\n  /**\n   * Threshold for the metric that, when exceeded, triggers an alert. The resource returns this parameter when '\"eventTypeName\" : \"OUTSIDE_METRIC_THRESHOLD\"'.\n   *\n   * @schema CfnAlertConfigurationProps#MetricThreshold\n   */\n  readonly metricThreshold?: MetricThresholdView;\n\n  /**\n   * List that contains the targets that MongoDB Cloud sends notifications.\n   *\n   * @schema CfnAlertConfigurationProps#Notifications\n   */\n  readonly notifications?: NotificationView[];\n\n  /**\n   * Limit that triggers an alert when exceeded. The resource returns this parameter when **eventTypeName** has not been set to 'OUTSIDE_METRIC_THRESHOLD'.\n   *\n   * @schema CfnAlertConfigurationProps#Threshold\n   */\n  readonly threshold?: IntegerThresholdView;\n\n  /**\n   * Human-readable label that displays the alert type.\n   *\n   * @schema CfnAlertConfigurationProps#TypeName\n   */\n  readonly typeName?: string;\n}\n\n/**\n * Converts an object of type 'CfnAlertConfigurationProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnAlertConfigurationProps(\n  obj: CfnAlertConfigurationProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    EventTypeName: obj.eventTypeName,\n    ProjectId: obj.projectId,\n    Matchers: obj.matchers?.map((y) => toJson_Matcher(y)),\n    MetricThreshold: toJson_MetricThresholdView(obj.metricThreshold),\n    Notifications: obj.notifications?.map((y) => toJson_NotificationView(y)),\n    Threshold: toJson_IntegerThresholdView(obj.threshold),\n    TypeName: obj.typeName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Matcher\n */\nexport interface Matcher {\n  /**\n   * Name of the parameter in the target object that MongoDB Cloud checks. The parameter must match all rules for MongoDB Cloud to check for alert configurations.\n   *\n   * @schema Matcher#FieldName\n   */\n  readonly fieldName?: MatcherFieldName;\n\n  /**\n   * Comparison operator to apply when checking the current metric value against **matcher[n].value**.\n   *\n   * @schema Matcher#Operator\n   */\n  readonly operator?: MatcherOperator;\n\n  /**\n   * Value to match or exceed using the specified **matchers.operator**.\n   *\n   * @schema Matcher#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'Matcher' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Matcher(\n  obj: Matcher | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FieldName: obj.fieldName,\n    Operator: obj.operator,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema MetricThresholdView\n */\nexport interface MetricThresholdView {\n  /**\n   * Human-readable label that identifies the metric against which MongoDB Cloud checks the configured **metricThreshold.threshold**.\n   *\n   * @schema MetricThresholdView#MetricName\n   */\n  readonly metricName?: string;\n\n  /**\n   * MongoDB Cloud computes the current metric value as an average.\n   *\n   * @schema MetricThresholdView#Mode\n   */\n  readonly mode?: MetricThresholdViewMode;\n\n  /**\n   * Comparison operator to apply when checking the current metric value.\n   *\n   * @schema MetricThresholdView#Operator\n   */\n  readonly operator?: MetricThresholdViewOperator;\n\n  /**\n   * Value of metric that, when exceeded, triggers an alert.\n   *\n   * @schema MetricThresholdView#Threshold\n   */\n  readonly threshold?: number;\n\n  /**\n   * Element used to express the quantity. This can be an element of time, storage capacity, and the like.\n   *\n   * @schema MetricThresholdView#Units\n   */\n  readonly units?: string;\n}\n\n/**\n * Converts an object of type 'MetricThresholdView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_MetricThresholdView(\n  obj: MetricThresholdView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    MetricName: obj.metricName,\n    Mode: obj.mode,\n    Operator: obj.operator,\n    Threshold: obj.threshold,\n    Units: obj.units,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema NotificationView\n */\nexport interface NotificationView {\n  /**\n   * Slack API token or Bot token that MongoDB Cloud needs to send alert notifications via Slack. The resource requires this parameter when '\"notifications.typeName\" : \"SLACK\"'. If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes the token.\n   *\n   * @schema NotificationView#ApiToken\n   */\n  readonly apiToken?: string;\n\n  /**\n   * Name of the Slack channel to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"SLACK\"'.\n   *\n   * @schema NotificationView#ChannelName\n   */\n  readonly channelName?: string;\n\n  /**\n   * Datadog API Key that MongoDB Cloud needs to send alert notifications to Datadog. You can find this API key in the Datadog dashboard. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n   *\n   * @schema NotificationView#DatadogApiKey\n   */\n  readonly datadogApiKey?: string;\n\n  /**\n   * Datadog region that indicates which API Uniform Resource Locator (URL) to use. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n   *\n   * @schema NotificationView#DatadogRegion\n   */\n  readonly datadogRegion?: NotificationViewDatadogRegion;\n\n  /**\n   * Number of minutes that MongoDB Cloud waits after detecting an alert condition before it sends out the first notification.\n   *\n   * @schema NotificationView#DelayMin\n   */\n  readonly delayMin?: number;\n\n  /**\n   * Email address to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"EMAIL\"'. You don't need to set this value to send emails to individual or groups of MongoDB Cloud users including:\n   *\n   * - specific MongoDB Cloud users ('\"notifications.typeName\" : \"USER\"')\n   * - MongoDB Cloud users with specific project roles ('\"notifications.typeName\" : \"GROUP\"')\n   * - MongoDB Cloud users with specific organization roles ('\"notifications.typeName\" : \"ORG\"')\n   * - MongoDB Cloud teams ('\"notifications.typeName\" : \"TEAM\"')\n   *\n   * To send emails to one MongoDB Cloud user or grouping of users, set the **notifications.emailEnabled** parameter.\n   *\n   * @schema NotificationView#EmailAddress\n   */\n  readonly emailAddress?: string;\n\n  /**\n   * Flag that indicates whether MongoDB Cloud should send email notifications. The resource requires this parameter when one of the following values have been set:\n   *\n   * - '\"notifications.typeName\" : \"ORG\"'\n   * - '\"notifications.typeName\" : \"GROUP\"'\n   * - '\"notifications.typeName\" : \"USER\"'\n   *\n   * @schema NotificationView#EmailEnabled\n   */\n  readonly emailEnabled?: boolean;\n\n  /**\n   * Number of minutes to wait between successive notifications. MongoDB Cloud sends notifications until someone acknowledges the unacknowledged alert.\n   *\n   * PagerDuty, VictorOps, and OpsGenie notifications don't return this element. Configure and manage the notification interval within each of those services.\n   *\n   * @schema NotificationView#IntervalMin\n   */\n  readonly intervalMin?: number;\n\n  /**\n   * Microsoft Teams Webhook Uniform Resource Locator (URL) that MongoDB Cloud needs to send this notification via Microsoft Teams. The resource requires this parameter when '\"notifications.typeName\" : \"MICROSOFT_TEAMS\"'. If the URL later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#MicrosoftTeamsWebhookUrl\n   */\n  readonly microsoftTeamsWebhookUrl?: string;\n\n  /**\n   * Mobile phone number to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"SMS\"'.\n   *\n   * @schema NotificationView#MobileNumber\n   */\n  readonly mobileNumber?: string;\n\n  /**\n   * HipChat API token that MongoDB Cloud needs to send alert notifications to HipChat. The resource requires this parameter when '\"notifications.typeName\" : \"HIP_CHAT\"'\". If the token later becomes invalid, MongoDB Cloud sends an email to the project owners. If the token remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#NotificationToken\n   */\n  readonly notificationToken?: string;\n\n  /**\n   * API Key that MongoDB Cloud needs to send this notification via Opsgenie. The resource requires this parameter when '\"notifications.typeName\" : \"OPS_GENIE\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#OpsGenieApiKey\n   */\n  readonly opsGenieApiKey?: string;\n\n  /**\n   * Opsgenie region that indicates which API Uniform Resource Locator (URL) to use.\n   *\n   * @schema NotificationView#OpsGenieRegion\n   */\n  readonly opsGenieRegion?: NotificationViewOpsGenieRegion;\n\n  /**\n   * Flowdock organization name to which MongoDB Cloud sends alert notifications. This name appears after 'www.flowdock.com/app/' in the Uniform Resource Locator (URL) path. The resource requires this parameter when '\"notifications.typeName\" : \"FLOWDOCK\"'.\n   *\n   * @schema NotificationView#OrgName\n   */\n  readonly orgName?: string;\n\n  /**\n   * List that contains the one or more organization or project roles that receive the configured alert. The resource requires this parameter when '\"notifications.typeName\" : \"GROUP\"' or '\"notifications.typeName\" : \"ORG\"'. If you include this parameter, MongoDB Cloud sends alerts only to users assigned the roles you specify in the array. If you omit this parameter, MongoDB Cloud sends alerts to users assigned any role.\n   *\n   * @schema NotificationView#Roles\n   */\n  readonly roles?: NotificationViewRoles[];\n\n  /**\n   * HipChat API room name to which MongoDB Cloud sends alert notifications. The resource requires this parameter when '\"notifications.typeName\" : \"HIP_CHAT\"'\".\n   *\n   * @schema NotificationView#RoomName\n   */\n  readonly roomName?: string;\n\n  /**\n   * PagerDuty service key that MongoDB Cloud needs to send notifications via PagerDuty. The resource requires this parameter when '\"notifications.typeName\" : \"PAGER_DUTY\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#ServiceKey\n   */\n  readonly serviceKey?: string;\n\n  /**\n   * Degree of seriousness given to this notification.\n   *\n   * @schema NotificationView#Severity\n   */\n  readonly severity?: NotificationViewSeverity;\n\n  /**\n   * Flag that indicates whether MongoDB Cloud should send text message notifications. The resource requires this parameter when one of the following values have been set:\n   *\n   * - '\"notifications.typeName\" : \"ORG\"'\n   * - '\"notifications.typeName\" : \"GROUP\"'\n   * - '\"notifications.typeName\" : \"USER\"'\n   *\n   * @schema NotificationView#SmsEnabled\n   */\n  readonly smsEnabled?: boolean;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies one MongoDB Cloud team. The resource requires this parameter when '\"notifications.typeName\" : \"TEAM\"'.\n   *\n   * @schema NotificationView#TeamId\n   */\n  readonly teamId?: string;\n\n  /**\n   * Name of the MongoDB Cloud team that receives this notification. The resource requires this parameter when '\"notifications.typeName\" : \"TEAM\"'.\n   *\n   * @schema NotificationView#TeamName\n   */\n  readonly teamName?: string;\n\n  /**\n   * Human-readable label that displays the alert notification type.\n   *\n   * @schema NotificationView#TypeName\n   */\n  readonly typeName?: NotificationViewTypeName;\n\n  /**\n   * MongoDB Cloud username of the person to whom MongoDB Cloud sends notifications. Specify only MongoDB Cloud users who belong to the project that owns the alert configuration. The resource requires this parameter when '\"notifications.typeName\" : \"USER\"'.\n   *\n   * @schema NotificationView#Username\n   */\n  readonly username?: string;\n\n  /**\n   * API key that MongoDB Cloud needs to send alert notifications to Splunk On-Call. The resource requires this parameter when '\"notifications.typeName\" : \"VICTOR_OPS\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#VictorOpsApiKey\n   */\n  readonly victorOpsApiKey?: string;\n\n  /**\n   * Routing key that MongoDB Cloud needs to send alert notifications to Splunk On-Call. The resource requires this parameter when '\"notifications.typeName\" : \"VICTOR_OPS\"'. If the key later becomes invalid, MongoDB Cloud sends an email to the project owners. If the key remains invalid, MongoDB Cloud removes it.\n   *\n   * @schema NotificationView#VictorOpsRoutingKey\n   */\n  readonly victorOpsRoutingKey?: string;\n\n  /**\n   * An optional field for your webhook secret.\n   *\n   * @schema NotificationView#WebhookSecret\n   */\n  readonly webhookSecret?: string;\n\n  /**\n   * Your webhook URL.\n   *\n   * @schema NotificationView#WebhookUrl\n   */\n  readonly webhookUrl?: string;\n}\n\n/**\n * Converts an object of type 'NotificationView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_NotificationView(\n  obj: NotificationView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ApiToken: obj.apiToken,\n    ChannelName: obj.channelName,\n    DatadogApiKey: obj.datadogApiKey,\n    DatadogRegion: obj.datadogRegion,\n    DelayMin: obj.delayMin,\n    EmailAddress: obj.emailAddress,\n    EmailEnabled: obj.emailEnabled,\n    IntervalMin: obj.intervalMin,\n    MicrosoftTeamsWebhookUrl: obj.microsoftTeamsWebhookUrl,\n    MobileNumber: obj.mobileNumber,\n    NotificationToken: obj.notificationToken,\n    OpsGenieApiKey: obj.opsGenieApiKey,\n    OpsGenieRegion: obj.opsGenieRegion,\n    OrgName: obj.orgName,\n    Roles: obj.roles?.map((y) => y),\n    RoomName: obj.roomName,\n    ServiceKey: obj.serviceKey,\n    Severity: obj.severity,\n    SmsEnabled: obj.smsEnabled,\n    TeamId: obj.teamId,\n    TeamName: obj.teamName,\n    TypeName: obj.typeName,\n    Username: obj.username,\n    VictorOpsApiKey: obj.victorOpsApiKey,\n    VictorOpsRoutingKey: obj.victorOpsRoutingKey,\n    WebhookSecret: obj.webhookSecret,\n    WebhookUrl: obj.webhookUrl,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema IntegerThresholdView\n */\nexport interface IntegerThresholdView {\n  /**\n   * Comparison operator to apply when checking the current metric value.\n   *\n   * @schema IntegerThresholdView#Operator\n   */\n  readonly operator?: IntegerThresholdViewOperator;\n\n  /**\n   * Value of metric that, when exceeded, triggers an alert.\n   *\n   * @schema IntegerThresholdView#Threshold\n   */\n  readonly threshold?: number;\n\n  /**\n   * Element used to express the quantity. This can be an element of time, storage capacity, and the like.\n   *\n   * @schema IntegerThresholdView#Units\n   */\n  readonly units?: string;\n}\n\n/**\n * Converts an object of type 'IntegerThresholdView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_IntegerThresholdView(\n  obj: IntegerThresholdView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Operator: obj.operator,\n    Threshold: obj.threshold,\n    Units: obj.units,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Name of the parameter in the target object that MongoDB Cloud checks. The parameter must match all rules for MongoDB Cloud to check for alert configurations.\n *\n * @schema MatcherFieldName\n */\nexport enum MatcherFieldName {\n  /** CLUSTER_NAME */\n  CLUSTER_NAME = \"CLUSTER_NAME\",\n  /** HOSTNAME */\n  HOSTNAME = \"HOSTNAME\",\n  /** HOSTNAME_AND_PORT */\n  HOSTNAME_AND_PORT = \"HOSTNAME_AND_PORT\",\n  /** PORT */\n  PORT = \"PORT\",\n  /** REPLICA_SET_NAME */\n  REPLICA_SET_NAME = \"REPLICA_SET_NAME\",\n  /** SHARD_NAME */\n  SHARD_NAME = \"SHARD_NAME\",\n  /** TYPE_NAME */\n  TYPE_NAME = \"TYPE_NAME\",\n  /** APPLICATION_ID */\n  APPLICATION_ID = \"APPLICATION_ID\",\n  /** INSTANCE_NAME */\n  INSTANCE_NAME = \"INSTANCE_NAME\",\n  /** PROCESSOR_NAME */\n  PROCESSOR_NAME = \"PROCESSOR_NAME\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value against **matcher[n].value**.\n *\n * @schema MatcherOperator\n */\nexport enum MatcherOperator {\n  /** EQUALS */\n  EQUALS = \"EQUALS\",\n  /** CONTAINS */\n  CONTAINS = \"CONTAINS\",\n  /** STARTS_WITH */\n  STARTS_WITH = \"STARTS_WITH\",\n  /** ENDS_WITH */\n  ENDS_WITH = \"ENDS_WITH\",\n  /** NOT_EQUALS */\n  NOT_EQUALS = \"NOT_EQUALS\",\n  /** NOT_CONTAINS */\n  NOT_CONTAINS = \"NOT_CONTAINS\",\n  /** REGEX */\n  REGEX = \"REGEX\",\n}\n\n/**\n * MongoDB Cloud computes the current metric value as an average.\n *\n * @schema MetricThresholdViewMode\n */\nexport enum MetricThresholdViewMode {\n  /** AVERAGE */\n  AVERAGE = \"AVERAGE\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value.\n *\n * @schema MetricThresholdViewOperator\n */\nexport enum MetricThresholdViewOperator {\n  /** GREATER_THAN */\n  GREATER_THAN = \"GREATER_THAN\",\n  /** LESS_THAN */\n  LESS_THAN = \"LESS_THAN\",\n}\n\n/**\n * Datadog region that indicates which API Uniform Resource Locator (URL) to use. The resource requires this parameter when '\"notifications.typeName\" : \"DATADOG\"'.\n *\n * @schema NotificationViewDatadogRegion\n */\nexport enum NotificationViewDatadogRegion {\n  /** EU */\n  EU = \"EU\",\n  /** US */\n  US = \"US\",\n}\n\n/**\n * Opsgenie region that indicates which API Uniform Resource Locator (URL) to use.\n *\n * @schema NotificationViewOpsGenieRegion\n */\nexport enum NotificationViewOpsGenieRegion {\n  /** EU */\n  EU = \"EU\",\n  /** US */\n  US = \"US\",\n}\n\n/**\n * @schema NotificationViewRoles\n */\nexport enum NotificationViewRoles {\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_WRITE */\n  GROUP_READ_WRITE = \"GROUP_READ_WRITE\",\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n}\n\n/**\n * Degree of seriousness given to this notification.\n *\n * @schema NotificationViewSeverity\n */\nexport enum NotificationViewSeverity {\n  /** CRITICAL */\n  CRITICAL = \"CRITICAL\",\n  /** ERROR */\n  ERROR = \"ERROR\",\n  /** WARNING */\n  WARNING = \"WARNING\",\n}\n\n/**\n * Human-readable label that displays the alert notification type.\n *\n * @schema NotificationViewTypeName\n */\nexport enum NotificationViewTypeName {\n  /** DATADOG */\n  DATADOG = \"DATADOG\",\n  /** EMAIL */\n  EMAIL = \"EMAIL\",\n  /** FLOWDOCK */\n  FLOWDOCK = \"FLOWDOCK\",\n  /** GROUP */\n  GROUP = \"GROUP\",\n  /** MICROSOFT_TEAMS */\n  MICROSOFT_TEAMS = \"MICROSOFT_TEAMS\",\n  /** OPS_GENIE */\n  OPS_GENIE = \"OPS_GENIE\",\n  /** ORG */\n  ORG = \"ORG\",\n  /** PAGER_DUTY */\n  PAGER_DUTY = \"PAGER_DUTY\",\n  /** PROMETHEUS */\n  PROMETHEUS = \"PROMETHEUS\",\n  /** SLACK */\n  SLACK = \"SLACK\",\n  /** SMS */\n  SMS = \"SMS\",\n  /** TEAM */\n  TEAM = \"TEAM\",\n  /** USER */\n  USER = \"USER\",\n  /** VICTOR_OPS */\n  VICTOR_OPS = \"VICTOR_OPS\",\n  /** WEBHOOK */\n  WEBHOOK = \"WEBHOOK\",\n}\n\n/**\n * Comparison operator to apply when checking the current metric value.\n *\n * @schema IntegerThresholdViewOperator\n */\nexport enum IntegerThresholdViewOperator {\n  /** GREATER_THAN */\n  GREATER_THAN = \"GREATER_THAN\",\n  /** LESS_THAN */\n  LESS_THAN = \"LESS_THAN\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::AlertConfiguration`\n *\n * @cloudformationResource MongoDB::Atlas::AlertConfiguration\n * @stability external\n */\nexport class CfnAlertConfiguration extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::AlertConfiguration\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnAlertConfigurationProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Enabled`\n   */\n  public readonly attrEnabled: cdk.IResolvable;\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Updated`\n   */\n  public readonly attrUpdated: string;\n  /**\n   * Attribute `MongoDB::Atlas::AlertConfiguration.Created`\n   */\n  public readonly attrCreated: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::AlertConfiguration`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnAlertConfigurationProps\n  ) {\n    super(scope, id, {\n      type: CfnAlertConfiguration.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnAlertConfigurationProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEnabled = this.getAtt(\"Enabled\");\n    this.attrUpdated = cdk.Token.asString(this.getAtt(\"Updated\"));\n    this.attrCreated = cdk.Token.asString(this.getAtt(\"Created\"));\n  }\n}\n"]}

@@ -16,7 +16,7 @@ import * as cdk from "aws-cdk-lib";

/**
* Name of the AWS Secrets Manager secret that stores the API key Details. The secret name must be unique to the AWS account and region. If you don't specify a name, AWS CloudFormation use APIUserId for the secret name.
* Name of the AWS Secrets Manager secret that stores the API key Details.
*
* @schema CfnApiKeyProps#AwsSecretName
*/
readonly awsSecretName?: string;
readonly awsSecretName: string;
/**

@@ -35,2 +35,8 @@ * Unique 24-hexadecimal digit string that identifies the organization that contains your projects. Use the /orgs endpoint to retrieve all organizations to which the authenticated user has access.

/**
* ARN of the AWS Secrets Manager secret that stores the API key Details
*
* @schema CfnApiKeyProps#AwsSecretArn
*/
readonly awsSecretArn?: string;
/**
* List of roles to grant this API key. If you provide this list, provide a minimum of one role and ensure each role applies to this organization.

@@ -130,6 +136,2 @@ *

/**
* Attribute `MongoDB::Atlas::APIKey.AwsSecretArn`
*/
readonly attrAwsSecretArn: string;
/**
* Create a new `MongoDB::Atlas::APIKey`.

@@ -136,0 +138,0 @@ *

@@ -21,2 +21,3 @@ "use strict";

Profile: obj.profile,
AwsSecretArn: obj.awsSecretArn,
Roles: obj.roles?.map((y) => y),

@@ -87,3 +88,2 @@ ProjectAssignments: obj.projectAssignments?.map((y) => toJson_ProjectAssignment(y)),

this.attrAPIUserId = cdk.Token.asString(this.getAtt("APIUserId"));
this.attrAwsSecretArn = cdk.Token.asString(this.getAtt("AwsSecretArn"));
}

@@ -93,3 +93,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnApiKey[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnApiKey", version: "3.7.2" };
CfnApiKey[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnApiKey", version: "3.8.0" };
/**

@@ -99,2 +99,2 @@ * The CloudFormation resource type name for this resource class.

CfnApiKey.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::APIKey";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/api-key/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Creates one API key for the specified organization. An organization API key grants programmatic access to an organization.\n *\n * @schema CfnApiKeyProps\n */\nexport interface CfnApiKeyProps {\n  /**\n   * Purpose or explanation provided when someone created this organization API key.\n   *\n   * @schema CfnApiKeyProps#Description\n   */\n  readonly description: string;\n\n  /**\n   * Name of the AWS Secrets Manager secret that stores the API key Details. The secret name must be unique to the AWS account and region. If you don't specify a name, AWS CloudFormation use APIUserId for the secret name.\n   *\n   * @schema CfnApiKeyProps#AwsSecretName\n   */\n  readonly awsSecretName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects. Use the /orgs endpoint to retrieve all organizations to which the authenticated user has access.\n   *\n   * @schema CfnApiKeyProps#OrgId\n   */\n  readonly orgId: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnApiKeyProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * List of roles to grant this API key. If you provide this list, provide a minimum of one role and ensure each role applies to this organization.\n   *\n   * @schema CfnApiKeyProps#Roles\n   */\n  readonly roles?: string[];\n\n  /**\n   * @schema CfnApiKeyProps#ProjectAssignments\n   */\n  readonly projectAssignments?: ProjectAssignment[];\n\n  /**\n   * @schema CfnApiKeyProps#ListOptions\n   */\n  readonly listOptions?: ListOptions;\n}\n\n/**\n * Converts an object of type 'CfnApiKeyProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnApiKeyProps(\n  obj: CfnApiKeyProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Description: obj.description,\n    AwsSecretName: obj.awsSecretName,\n    OrgId: obj.orgId,\n    Profile: obj.profile,\n    Roles: obj.roles?.map((y) => y),\n    ProjectAssignments: obj.projectAssignments?.map((y) =>\n      toJson_ProjectAssignment(y)\n    ),\n    ListOptions: toJson_ListOptions(obj.listOptions),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ProjectAssignment\n */\nexport interface ProjectAssignment {\n  /**\n   * List of roles to grant this API key. If you provide this list, provide a minimum of one role and ensure each role applies to this organization.\n   *\n   * @schema ProjectAssignment#Roles\n   */\n  readonly roles?: string[];\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project in an organization.\n   *\n   * @schema ProjectAssignment#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'ProjectAssignment' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ProjectAssignment(\n  obj: ProjectAssignment | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Roles: obj.roles?.map((y) => y),\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ListOptions\n */\nexport interface ListOptions {\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema ListOptions#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema ListOptions#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (totalCount) in the response.\n   *\n   * @schema ListOptions#IncludeCount\n   */\n  readonly includeCount?: boolean;\n}\n\n/**\n * Converts an object of type 'ListOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ListOptions(\n  obj: ListOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PageNum: obj.pageNum,\n    ItemsPerPage: obj.itemsPerPage,\n    IncludeCount: obj.includeCount,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::APIKey`\n *\n * @cloudformationResource MongoDB::Atlas::APIKey\n * @stability external\n */\nexport class CfnApiKey extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::APIKey\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnApiKeyProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.PrivateKey`\n   */\n  public readonly attrPrivateKey: string;\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.PublicKey`\n   */\n  public readonly attrPublicKey: string;\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.APIUserId`\n   */\n  public readonly attrAPIUserId: string;\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.AwsSecretArn`\n   */\n  public readonly attrAwsSecretArn: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::APIKey`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnApiKeyProps) {\n    super(scope, id, {\n      type: CfnApiKey.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnApiKeyProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrPrivateKey = cdk.Token.asString(this.getAtt(\"PrivateKey\"));\n    this.attrPublicKey = cdk.Token.asString(this.getAtt(\"PublicKey\"));\n    this.attrAPIUserId = cdk.Token.asString(this.getAtt(\"APIUserId\"));\n    this.attrAwsSecretArn = cdk.Token.asString(this.getAtt(\"AwsSecretArn\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/api-key/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Creates one API key for the specified organization. An organization API key grants programmatic access to an organization.\n *\n * @schema CfnApiKeyProps\n */\nexport interface CfnApiKeyProps {\n  /**\n   * Purpose or explanation provided when someone created this organization API key.\n   *\n   * @schema CfnApiKeyProps#Description\n   */\n  readonly description: string;\n\n  /**\n   * Name of the AWS Secrets Manager secret that stores the API key Details.\n   *\n   * @schema CfnApiKeyProps#AwsSecretName\n   */\n  readonly awsSecretName: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects. Use the /orgs endpoint to retrieve all organizations to which the authenticated user has access.\n   *\n   * @schema CfnApiKeyProps#OrgId\n   */\n  readonly orgId: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnApiKeyProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * ARN of the AWS Secrets Manager secret that stores the API key Details\n   *\n   * @schema CfnApiKeyProps#AwsSecretArn\n   */\n  readonly awsSecretArn?: string;\n\n  /**\n   * List of roles to grant this API key. If you provide this list, provide a minimum of one role and ensure each role applies to this organization.\n   *\n   * @schema CfnApiKeyProps#Roles\n   */\n  readonly roles?: string[];\n\n  /**\n   * @schema CfnApiKeyProps#ProjectAssignments\n   */\n  readonly projectAssignments?: ProjectAssignment[];\n\n  /**\n   * @schema CfnApiKeyProps#ListOptions\n   */\n  readonly listOptions?: ListOptions;\n}\n\n/**\n * Converts an object of type 'CfnApiKeyProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnApiKeyProps(\n  obj: CfnApiKeyProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Description: obj.description,\n    AwsSecretName: obj.awsSecretName,\n    OrgId: obj.orgId,\n    Profile: obj.profile,\n    AwsSecretArn: obj.awsSecretArn,\n    Roles: obj.roles?.map((y) => y),\n    ProjectAssignments: obj.projectAssignments?.map((y) =>\n      toJson_ProjectAssignment(y)\n    ),\n    ListOptions: toJson_ListOptions(obj.listOptions),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ProjectAssignment\n */\nexport interface ProjectAssignment {\n  /**\n   * List of roles to grant this API key. If you provide this list, provide a minimum of one role and ensure each role applies to this organization.\n   *\n   * @schema ProjectAssignment#Roles\n   */\n  readonly roles?: string[];\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project in an organization.\n   *\n   * @schema ProjectAssignment#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'ProjectAssignment' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ProjectAssignment(\n  obj: ProjectAssignment | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Roles: obj.roles?.map((y) => y),\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ListOptions\n */\nexport interface ListOptions {\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema ListOptions#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema ListOptions#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (totalCount) in the response.\n   *\n   * @schema ListOptions#IncludeCount\n   */\n  readonly includeCount?: boolean;\n}\n\n/**\n * Converts an object of type 'ListOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ListOptions(\n  obj: ListOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PageNum: obj.pageNum,\n    ItemsPerPage: obj.itemsPerPage,\n    IncludeCount: obj.includeCount,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::APIKey`\n *\n * @cloudformationResource MongoDB::Atlas::APIKey\n * @stability external\n */\nexport class CfnApiKey extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::APIKey\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnApiKeyProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.PrivateKey`\n   */\n  public readonly attrPrivateKey: string;\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.PublicKey`\n   */\n  public readonly attrPublicKey: string;\n  /**\n   * Attribute `MongoDB::Atlas::APIKey.APIUserId`\n   */\n  public readonly attrAPIUserId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::APIKey`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnApiKeyProps) {\n    super(scope, id, {\n      type: CfnApiKey.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnApiKeyProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrPrivateKey = cdk.Token.asString(this.getAtt(\"PrivateKey\"));\n    this.attrPublicKey = cdk.Token.asString(this.getAtt(\"PublicKey\"));\n    this.attrAPIUserId = cdk.Token.asString(this.getAtt(\"APIUserId\"));\n  }\n}\n"]}

@@ -52,3 +52,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnAuditing[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAuditing", version: "3.7.2" };
CfnAuditing[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnAuditing", version: "3.8.0" };
/**

@@ -55,0 +55,0 @@ * The CloudFormation resource type name for this resource class.

@@ -34,26 +34,14 @@ import * as cdk from "aws-cdk-lib";

/**
* Indicates whether the restore job was canceled.
* Unique identifier of the source snapshot ID of the restore job.
*
* @schema CfnCloudBackUpRestoreJobsProps#Cancelled
* @schema CfnCloudBackUpRestoreJobsProps#SnapshotId
*/
readonly cancelled?: boolean;
readonly snapshotId: string;
/**
* Indicates whether the restore job failed.
* One or more links to sub-resources and/or related resources.
*
* @schema CfnCloudBackUpRestoreJobsProps#Failed
* @schema CfnCloudBackUpRestoreJobsProps#Links
*/
readonly failed?: boolean;
readonly links?: CfnCloudBackUpRestoreJobsPropsLinks[];
/**
* Indicates whether the restore job expired.
*
* @schema CfnCloudBackUpRestoreJobsProps#Expired
*/
readonly expired?: boolean;
/**
* Unique identifier of the source snapshot ID of the restore job.
*
* @schema CfnCloudBackUpRestoreJobsProps#SnapshotId
*/
readonly snapshotId: string;
/**
* Timestamp in the number of seconds that have elapsed since the UNIX epoch from which to you want to restore this snapshot. This is the first part of an Oplog timestamp.

@@ -136,2 +124,19 @@ *

/**
* @schema CfnCloudBackUpRestoreJobsPropsLinks
*/
export interface CfnCloudBackUpRestoreJobsPropsLinks {
/**
* @schema CfnCloudBackUpRestoreJobsPropsLinks#Rel
*/
readonly rel?: string;
/**
* @schema CfnCloudBackUpRestoreJobsPropsLinks#Href
*/
readonly href?: string;
}
/**
* Converts an object of type 'CfnCloudBackUpRestoreJobsPropsLinks' to JSON representation.
*/
export declare function toJson_CfnCloudBackUpRestoreJobsPropsLinks(obj: CfnCloudBackUpRestoreJobsPropsLinks | undefined): Record<string, any> | undefined;
/**
* Options that needs to be set to control the synchronous creation flow, this options need to be set if EnableSynchronousCreation is se to TRUE

@@ -189,2 +194,14 @@ *

/**
* Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Cancelled`
*/
readonly attrCancelled: cdk.IResolvable;
/**
* Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Failed`
*/
readonly attrFailed: cdk.IResolvable;
/**
* Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Expired`
*/
readonly attrExpired: cdk.IResolvable;
/**
* Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.ExpiresAt`

@@ -191,0 +208,0 @@ */

"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnCloudBackUpRestoreJobs = exports.toJson_SynchronousCreationOptions = exports.CfnCloudBackUpRestoreJobsPropsDeliveryType = exports.CfnCloudBackUpRestoreJobsPropsInstanceType = exports.toJson_CfnCloudBackUpRestoreJobsProps = void 0;
exports.CfnCloudBackUpRestoreJobs = exports.toJson_SynchronousCreationOptions = exports.toJson_CfnCloudBackUpRestoreJobsPropsLinks = exports.CfnCloudBackUpRestoreJobsPropsDeliveryType = exports.CfnCloudBackUpRestoreJobsPropsInstanceType = exports.toJson_CfnCloudBackUpRestoreJobsProps = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");

@@ -21,6 +21,4 @@ // Generated by cdk-import

DeliveryType: obj.deliveryType,
Cancelled: obj.cancelled,
Failed: obj.failed,
Expired: obj.expired,
SnapshotId: obj.snapshotId,
Links: obj.links?.map((y) => toJson_CfnCloudBackUpRestoreJobsPropsLinks(y)),
OpLogTs: obj.opLogTs,

@@ -67,2 +65,18 @@ OpLogInc: obj.opLogInc,

/**
* Converts an object of type 'CfnCloudBackUpRestoreJobsPropsLinks' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CfnCloudBackUpRestoreJobsPropsLinks(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Rel: obj.rel,
Href: obj.href,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
exports.toJson_CfnCloudBackUpRestoreJobsPropsLinks = toJson_CfnCloudBackUpRestoreJobsPropsLinks;
/**
* Converts an object of type 'SynchronousCreationOptions' to JSON representation.

@@ -107,2 +121,5 @@ */

this.attrDeliveryUrl = cdk.Token.asList(this.getAtt("DeliveryUrl"));
this.attrCancelled = this.getAtt("Cancelled");
this.attrFailed = this.getAtt("Failed");
this.attrExpired = this.getAtt("Expired");
this.attrExpiresAt = cdk.Token.asString(this.getAtt("ExpiresAt"));

@@ -115,3 +132,3 @@ this.attrFinishedAt = cdk.Token.asString(this.getAtt("FinishedAt"));

_a = JSII_RTTI_SYMBOL_1;
CfnCloudBackUpRestoreJobs[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackUpRestoreJobs", version: "3.7.2" };
CfnCloudBackUpRestoreJobs[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackUpRestoreJobs", version: "3.8.0" };
/**

@@ -121,2 +138,2 @@ * The CloudFormation resource type name for this resource class.

CfnCloudBackUpRestoreJobs.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::CloudBackUpRestoreJobs";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/cloud-backup-restore-jobs/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, starts, and cancels Cloud Backup restore jobs.\n *\n * @schema CfnCloudBackUpRestoreJobsProps\n */\nexport interface CfnCloudBackUpRestoreJobsProps {\n  /**\n   * The unique identifier of the project for the Atlas cluster.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Type of instance specified on the Instance Name serverless or cluster\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#InstanceType\n   */\n  readonly instanceType: CfnCloudBackUpRestoreJobsPropsInstanceType;\n\n  /**\n   * The instance name of the Serverless/Cluster whose snapshot you want to restore or you want to retrieve restore jobs.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * Type of restore job to create.The value can be any one of download,automated or point_in_time\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#DeliveryType\n   */\n  readonly deliveryType: CfnCloudBackUpRestoreJobsPropsDeliveryType;\n\n  /**\n   * Indicates whether the restore job was canceled.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Cancelled\n   */\n  readonly cancelled?: boolean;\n\n  /**\n   * Indicates whether the restore job failed.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Failed\n   */\n  readonly failed?: boolean;\n\n  /**\n   * Indicates whether the restore job expired.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Expired\n   */\n  readonly expired?: boolean;\n\n  /**\n   * Unique identifier of the source snapshot ID of the restore job.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#SnapshotId\n   */\n  readonly snapshotId: string;\n\n  /**\n   * Timestamp in the number of seconds that have elapsed since the UNIX epoch from which to you want to restore this snapshot. This is the first part of an Oplog timestamp.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#OpLogTs\n   */\n  readonly opLogTs?: string;\n\n  /**\n   * Oplog operation number from which to you want to restore this snapshot. This is the second part of an Oplog timestamp.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#OpLogInc\n   */\n  readonly opLogInc?: string;\n\n  /**\n   * If you performed a Point-in-Time restores at a time specified by a Unix time in seconds since epoch, pointInTimeUTCSeconds indicates the Unix time used.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#PointInTimeUtcSeconds\n   */\n  readonly pointInTimeUtcSeconds?: number;\n\n  /**\n   * Name of the target Atlas project of the restore job. Only visible if deliveryType is automated.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#TargetProjectId\n   */\n  readonly targetProjectId?: string;\n\n  /**\n   * Name of the target Atlas cluster to which the restore job restores the snapshot. Only visible if deliveryType is automated.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#TargetClusterName\n   */\n  readonly targetClusterName?: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * If set to true, the CloudFormation resource will wait until the job is completed, WARNING: if the snapshot has a big load of data, the cloud formation resource might take a long time to finish leading to high costs\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#EnableSynchronousCreation\n   */\n  readonly enableSynchronousCreation?: boolean;\n\n  /**\n   * Options that needs to be set to control the synchronous creation flow, this options need to be set if EnableSynchronousCreation is se to TRUE\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#SynchronousCreationOptions\n   */\n  readonly synchronousCreationOptions?: SynchronousCreationOptions;\n}\n\n/**\n * Converts an object of type 'CfnCloudBackUpRestoreJobsProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnCloudBackUpRestoreJobsProps(\n  obj: CfnCloudBackUpRestoreJobsProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    InstanceType: obj.instanceType,\n    InstanceName: obj.instanceName,\n    DeliveryType: obj.deliveryType,\n    Cancelled: obj.cancelled,\n    Failed: obj.failed,\n    Expired: obj.expired,\n    SnapshotId: obj.snapshotId,\n    OpLogTs: obj.opLogTs,\n    OpLogInc: obj.opLogInc,\n    PointInTimeUtcSeconds: obj.pointInTimeUtcSeconds,\n    TargetProjectId: obj.targetProjectId,\n    TargetClusterName: obj.targetClusterName,\n    Profile: obj.profile,\n    EnableSynchronousCreation: obj.enableSynchronousCreation,\n    SynchronousCreationOptions: toJson_SynchronousCreationOptions(\n      obj.synchronousCreationOptions\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Type of instance specified on the Instance Name serverless or cluster\n *\n * @schema CfnCloudBackUpRestoreJobsPropsInstanceType\n */\nexport enum CfnCloudBackUpRestoreJobsPropsInstanceType {\n  /** serverless */\n  SERVERLESS = \"serverless\",\n  /** cluster */\n  CLUSTER = \"cluster\",\n}\n\n/**\n * Type of restore job to create.The value can be any one of download,automated or point_in_time\n *\n * @schema CfnCloudBackUpRestoreJobsPropsDeliveryType\n */\nexport enum CfnCloudBackUpRestoreJobsPropsDeliveryType {\n  /** download */\n  DOWNLOAD = \"download\",\n  /** automated */\n  AUTOMATED = \"automated\",\n  /** pointInTime */\n  POINT_IN_TIME = \"pointInTime\",\n}\n\n/**\n * Options that needs to be set to control the synchronous creation flow, this options need to be set if EnableSynchronousCreation is se to TRUE\n *\n * @schema SynchronousCreationOptions\n */\nexport interface SynchronousCreationOptions {\n  /**\n   * The amount of time the process will wait until exiting with a success, default (1200 seconds)\n   *\n   * @schema SynchronousCreationOptions#TimeOutInSeconds\n   */\n  readonly timeOutInSeconds?: number;\n\n  /**\n   * Represents the time interval, measured in seconds, for the synchronous process to wait before checking again to verify if the job has been completed. example: if set to 20, it will chek every 20 seconds if the resource is completed, default (30 seconds)\n   *\n   * @schema SynchronousCreationOptions#CallbackDelaySeconds\n   */\n  readonly callbackDelaySeconds?: number;\n\n  /**\n   * if set to true, the process will return success, in the event of a timeOut, default false\n   *\n   * @schema SynchronousCreationOptions#ReturnSuccessIfTimeOut\n   */\n  readonly returnSuccessIfTimeOut?: boolean;\n}\n\n/**\n * Converts an object of type 'SynchronousCreationOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_SynchronousCreationOptions(\n  obj: SynchronousCreationOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    TimeOutInSeconds: obj.timeOutInSeconds,\n    CallbackDelaySeconds: obj.callbackDelaySeconds,\n    ReturnSuccessIfTimeOut: obj.returnSuccessIfTimeOut,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::CloudBackUpRestoreJobs`\n *\n * @cloudformationResource MongoDB::Atlas::CloudBackUpRestoreJobs\n * @stability external\n */\nexport class CfnCloudBackUpRestoreJobs extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::CloudBackUpRestoreJobs\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnCloudBackUpRestoreJobsProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.DeliveryUrl`\n   */\n  public readonly attrDeliveryUrl: string[];\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.ExpiresAt`\n   */\n  public readonly attrExpiresAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.FinishedAt`\n   */\n  public readonly attrFinishedAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Timestamp`\n   */\n  public readonly attrTimestamp: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::CloudBackUpRestoreJobs`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnCloudBackUpRestoreJobsProps\n  ) {\n    super(scope, id, {\n      type: CfnCloudBackUpRestoreJobs.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnCloudBackUpRestoreJobsProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrDeliveryUrl = cdk.Token.asList(this.getAtt(\"DeliveryUrl\"));\n    this.attrExpiresAt = cdk.Token.asString(this.getAtt(\"ExpiresAt\"));\n    this.attrFinishedAt = cdk.Token.asString(this.getAtt(\"FinishedAt\"));\n    this.attrTimestamp = cdk.Token.asString(this.getAtt(\"Timestamp\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/cloud-backup-restore-jobs/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, starts, and cancels Cloud Backup restore jobs.\n *\n * @schema CfnCloudBackUpRestoreJobsProps\n */\nexport interface CfnCloudBackUpRestoreJobsProps {\n  /**\n   * The unique identifier of the project for the Atlas cluster.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Type of instance specified on the Instance Name serverless or cluster\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#InstanceType\n   */\n  readonly instanceType: CfnCloudBackUpRestoreJobsPropsInstanceType;\n\n  /**\n   * The instance name of the Serverless/Cluster whose snapshot you want to restore or you want to retrieve restore jobs.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * Type of restore job to create.The value can be any one of download,automated or point_in_time\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#DeliveryType\n   */\n  readonly deliveryType: CfnCloudBackUpRestoreJobsPropsDeliveryType;\n\n  /**\n   * Unique identifier of the source snapshot ID of the restore job.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#SnapshotId\n   */\n  readonly snapshotId: string;\n\n  /**\n   * One or more links to sub-resources and/or related resources.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Links\n   */\n  readonly links?: CfnCloudBackUpRestoreJobsPropsLinks[];\n\n  /**\n   * Timestamp in the number of seconds that have elapsed since the UNIX epoch from which to you want to restore this snapshot. This is the first part of an Oplog timestamp.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#OpLogTs\n   */\n  readonly opLogTs?: string;\n\n  /**\n   * Oplog operation number from which to you want to restore this snapshot. This is the second part of an Oplog timestamp.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#OpLogInc\n   */\n  readonly opLogInc?: string;\n\n  /**\n   * If you performed a Point-in-Time restores at a time specified by a Unix time in seconds since epoch, pointInTimeUTCSeconds indicates the Unix time used.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#PointInTimeUtcSeconds\n   */\n  readonly pointInTimeUtcSeconds?: number;\n\n  /**\n   * Name of the target Atlas project of the restore job. Only visible if deliveryType is automated.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#TargetProjectId\n   */\n  readonly targetProjectId?: string;\n\n  /**\n   * Name of the target Atlas cluster to which the restore job restores the snapshot. Only visible if deliveryType is automated.\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#TargetClusterName\n   */\n  readonly targetClusterName?: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * If set to true, the CloudFormation resource will wait until the job is completed, WARNING: if the snapshot has a big load of data, the cloud formation resource might take a long time to finish leading to high costs\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#EnableSynchronousCreation\n   */\n  readonly enableSynchronousCreation?: boolean;\n\n  /**\n   * Options that needs to be set to control the synchronous creation flow, this options need to be set if EnableSynchronousCreation is se to TRUE\n   *\n   * @schema CfnCloudBackUpRestoreJobsProps#SynchronousCreationOptions\n   */\n  readonly synchronousCreationOptions?: SynchronousCreationOptions;\n}\n\n/**\n * Converts an object of type 'CfnCloudBackUpRestoreJobsProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnCloudBackUpRestoreJobsProps(\n  obj: CfnCloudBackUpRestoreJobsProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    InstanceType: obj.instanceType,\n    InstanceName: obj.instanceName,\n    DeliveryType: obj.deliveryType,\n    SnapshotId: obj.snapshotId,\n    Links: obj.links?.map((y) => toJson_CfnCloudBackUpRestoreJobsPropsLinks(y)),\n    OpLogTs: obj.opLogTs,\n    OpLogInc: obj.opLogInc,\n    PointInTimeUtcSeconds: obj.pointInTimeUtcSeconds,\n    TargetProjectId: obj.targetProjectId,\n    TargetClusterName: obj.targetClusterName,\n    Profile: obj.profile,\n    EnableSynchronousCreation: obj.enableSynchronousCreation,\n    SynchronousCreationOptions: toJson_SynchronousCreationOptions(\n      obj.synchronousCreationOptions\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Type of instance specified on the Instance Name serverless or cluster\n *\n * @schema CfnCloudBackUpRestoreJobsPropsInstanceType\n */\nexport enum CfnCloudBackUpRestoreJobsPropsInstanceType {\n  /** serverless */\n  SERVERLESS = \"serverless\",\n  /** cluster */\n  CLUSTER = \"cluster\",\n}\n\n/**\n * Type of restore job to create.The value can be any one of download,automated or point_in_time\n *\n * @schema CfnCloudBackUpRestoreJobsPropsDeliveryType\n */\nexport enum CfnCloudBackUpRestoreJobsPropsDeliveryType {\n  /** download */\n  DOWNLOAD = \"download\",\n  /** automated */\n  AUTOMATED = \"automated\",\n  /** pointInTime */\n  POINT_IN_TIME = \"pointInTime\",\n}\n\n/**\n * @schema CfnCloudBackUpRestoreJobsPropsLinks\n */\nexport interface CfnCloudBackUpRestoreJobsPropsLinks {\n  /**\n   * @schema CfnCloudBackUpRestoreJobsPropsLinks#Rel\n   */\n  readonly rel?: string;\n\n  /**\n   * @schema CfnCloudBackUpRestoreJobsPropsLinks#Href\n   */\n  readonly href?: string;\n}\n\n/**\n * Converts an object of type 'CfnCloudBackUpRestoreJobsPropsLinks' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnCloudBackUpRestoreJobsPropsLinks(\n  obj: CfnCloudBackUpRestoreJobsPropsLinks | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Rel: obj.rel,\n    Href: obj.href,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Options that needs to be set to control the synchronous creation flow, this options need to be set if EnableSynchronousCreation is se to TRUE\n *\n * @schema SynchronousCreationOptions\n */\nexport interface SynchronousCreationOptions {\n  /**\n   * The amount of time the process will wait until exiting with a success, default (1200 seconds)\n   *\n   * @schema SynchronousCreationOptions#TimeOutInSeconds\n   */\n  readonly timeOutInSeconds?: number;\n\n  /**\n   * Represents the time interval, measured in seconds, for the synchronous process to wait before checking again to verify if the job has been completed. example: if set to 20, it will chek every 20 seconds if the resource is completed, default (30 seconds)\n   *\n   * @schema SynchronousCreationOptions#CallbackDelaySeconds\n   */\n  readonly callbackDelaySeconds?: number;\n\n  /**\n   * if set to true, the process will return success, in the event of a timeOut, default false\n   *\n   * @schema SynchronousCreationOptions#ReturnSuccessIfTimeOut\n   */\n  readonly returnSuccessIfTimeOut?: boolean;\n}\n\n/**\n * Converts an object of type 'SynchronousCreationOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_SynchronousCreationOptions(\n  obj: SynchronousCreationOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    TimeOutInSeconds: obj.timeOutInSeconds,\n    CallbackDelaySeconds: obj.callbackDelaySeconds,\n    ReturnSuccessIfTimeOut: obj.returnSuccessIfTimeOut,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::CloudBackUpRestoreJobs`\n *\n * @cloudformationResource MongoDB::Atlas::CloudBackUpRestoreJobs\n * @stability external\n */\nexport class CfnCloudBackUpRestoreJobs extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::CloudBackUpRestoreJobs\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnCloudBackUpRestoreJobsProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.DeliveryUrl`\n   */\n  public readonly attrDeliveryUrl: string[];\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Cancelled`\n   */\n  public readonly attrCancelled: cdk.IResolvable;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Failed`\n   */\n  public readonly attrFailed: cdk.IResolvable;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Expired`\n   */\n  public readonly attrExpired: cdk.IResolvable;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.ExpiresAt`\n   */\n  public readonly attrExpiresAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.FinishedAt`\n   */\n  public readonly attrFinishedAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackUpRestoreJobs.Timestamp`\n   */\n  public readonly attrTimestamp: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::CloudBackUpRestoreJobs`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnCloudBackUpRestoreJobsProps\n  ) {\n    super(scope, id, {\n      type: CfnCloudBackUpRestoreJobs.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnCloudBackUpRestoreJobsProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrDeliveryUrl = cdk.Token.asList(this.getAtt(\"DeliveryUrl\"));\n    this.attrCancelled = this.getAtt(\"Cancelled\");\n    this.attrFailed = this.getAtt(\"Failed\");\n    this.attrExpired = this.getAtt(\"Expired\");\n    this.attrExpiresAt = cdk.Token.asString(this.getAtt(\"ExpiresAt\"));\n    this.attrFinishedAt = cdk.Token.asString(this.getAtt(\"FinishedAt\"));\n    this.attrTimestamp = cdk.Token.asString(this.getAtt(\"Timestamp\"));\n  }\n}\n"]}

@@ -10,13 +10,7 @@ import * as cdk from "aws-cdk-lib";

/**
* Unique identifier of the snapshot.
* The unique identifier of the project for the Atlas cluster.
*
* @schema CfnCloudBackupScheduleProps#Id
*/
readonly id?: string;
/**
* Unique 24-hexadecimal digit string that identifies your project.
*
* @schema CfnCloudBackupScheduleProps#ProjectId
*/
readonly projectId: string;
readonly projectId?: string;
/**

@@ -27,4 +21,10 @@ * The name of the Atlas cluster that contains the snapshots you want to retrieve.

*/
readonly clusterName: string;
readonly clusterName?: string;
/**
* Unique identifier of the snapshot.
*
* @schema CfnCloudBackupScheduleProps#Id
*/
readonly id?: string;
/**
* Flag that indicates whether automatic export of cloud backup snapshots to the AWS bucket is enabled.

@@ -34,3 +34,3 @@ *

*/
readonly autoExportEnabled?: boolean;
readonly autoExportEnabled: boolean;
/**

@@ -118,3 +118,3 @@ * Specify true to use organization and project names instead of organization and project UUIDs in the path for the metadata files that Atlas uploads to your S3 bucket after it finishes exporting the snapshots.

/**
* Frequency associated with the export policy. Value can be daily, weekly, or monthly.
* Frequency associated with the export policy. Value can be daily, weekly, monthly or yearly.
*

@@ -200,2 +200,4 @@ * @schema Export#FrequencyType

/**
* Unique 24-hexadecimal digit string that identifies this backup policy. The policy id can be retrieved by running: atlas backups schedule describe "${clusterName}" --projectId "${projectId}" | jq -r '.policies[0].id'
*
* @schema ApiPolicyView#ID

@@ -245,3 +247,3 @@ */

/**
* Frequency associated with the backup policy item. One of the following values: hourly, daily, weekly or monthly.
* Frequency associated with the backup policy item. One of the following values: hourly, daily, weekly, monthly or yearly.
*

@@ -264,3 +266,3 @@ * @schema ApiPolicyItemView#FrequencyType

/**
* Metric of duration of the backup policy item: days, weeks, or months.
* Metric of duration of the backup policy item: days, weeks, months or years.
*

@@ -267,0 +269,0 @@ * @schema ApiPolicyItemView#RetentionUnit

@@ -17,5 +17,5 @@ "use strict";

const result = {
Id: obj.id,
ProjectId: obj.projectId,
ClusterName: obj.clusterName,
Id: obj.id,
AutoExportEnabled: obj.autoExportEnabled,

@@ -168,3 +168,3 @@ UseOrgAndGroupNamesInExportPrefix: obj.useOrgAndGroupNamesInExportPrefix,

_a = JSII_RTTI_SYMBOL_1;
CfnCloudBackupSchedule[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSchedule", version: "3.7.2" };
CfnCloudBackupSchedule[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSchedule", version: "3.8.0" };
/**

@@ -174,2 +174,2 @@ * The CloudFormation resource type name for this resource class.

CfnCloudBackupSchedule.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::CloudBackupSchedule";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/cloud-backup-schedule/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * An example resource schema demonstrating some basic constructs and validation rules.\n *\n * @schema CfnCloudBackupScheduleProps\n */\nexport interface CfnCloudBackupScheduleProps {\n  /**\n   * Unique identifier of the snapshot.\n   *\n   * @schema CfnCloudBackupScheduleProps#Id\n   */\n  readonly id?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnCloudBackupScheduleProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * The name of the Atlas cluster that contains the snapshots you want to retrieve.\n   *\n   * @schema CfnCloudBackupScheduleProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * Flag that indicates whether automatic export of cloud backup snapshots to the AWS bucket is enabled.\n   *\n   * @schema CfnCloudBackupScheduleProps#AutoExportEnabled\n   */\n  readonly autoExportEnabled?: boolean;\n\n  /**\n   * Specify true to use organization and project names instead of organization and project UUIDs in the path for the metadata files that Atlas uploads to your S3 bucket after it finishes exporting the snapshots.\n   *\n   * @schema CfnCloudBackupScheduleProps#UseOrgAndGroupNamesInExportPrefix\n   */\n  readonly useOrgAndGroupNamesInExportPrefix?: boolean;\n\n  /**\n   * Policy for automatically exporting cloud backup snapshots.\n   *\n   * @schema CfnCloudBackupScheduleProps#Export\n   */\n  readonly export?: Export;\n\n  /**\n   * List that contains a document for each copy setting item in the desired backup policy.\n   *\n   * @schema CfnCloudBackupScheduleProps#CopySettings\n   */\n  readonly copySettings?: ApiAtlasDiskBackupCopySettingView[];\n\n  /**\n   * List that contains a document for each deleted copy setting whose backup copies you want to delete.\n   *\n   * @schema CfnCloudBackupScheduleProps#DeleteCopiedBackups\n   */\n  readonly deleteCopiedBackups?: ApiDeleteCopiedBackupsView[];\n\n  /**\n   * Rules set for this backup schedule.\n   *\n   * @schema CfnCloudBackupScheduleProps#Policies\n   */\n  readonly policies?: ApiPolicyView[];\n\n  /**\n   * UTC Hour of day between 0 and 23 representing which hour of the day that Atlas takes a snapshot\n   *\n   * @schema CfnCloudBackupScheduleProps#ReferenceHourOfDay\n   */\n  readonly referenceHourOfDay?: number;\n\n  /**\n   * UTC Minute of day between 0 and 59 representing which minute of the referenceHourOfDay that Atlas takes the snapshot.\n   *\n   * @schema CfnCloudBackupScheduleProps#ReferenceMinuteOfHour\n   */\n  readonly referenceMinuteOfHour?: number;\n\n  /**\n   * Number of days back in time you can restore to with Continuous Cloud Backup accuracy. Must be a positive, non-zero integer.\n   *\n   * @schema CfnCloudBackupScheduleProps#RestoreWindowDays\n   */\n  readonly restoreWindowDays?: number;\n\n  /**\n   * Flag indicating if updates to retention in the backup policy were applied to snapshots that Atlas took earlier.\n   *\n   * @schema CfnCloudBackupScheduleProps#UpdateSnapshots\n   */\n  readonly updateSnapshots?: boolean;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnCloudBackupScheduleProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * List of one or more Uniform Resource Locators (URLs) that point to API sub-resources, related API resources, or both. RFC 5988 outlines these relationships.\n   *\n   * @schema CfnCloudBackupScheduleProps#Links\n   */\n  readonly links?: Link[];\n}\n\n/**\n * Converts an object of type 'CfnCloudBackupScheduleProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnCloudBackupScheduleProps(\n  obj: CfnCloudBackupScheduleProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Id: obj.id,\n    ProjectId: obj.projectId,\n    ClusterName: obj.clusterName,\n    AutoExportEnabled: obj.autoExportEnabled,\n    UseOrgAndGroupNamesInExportPrefix: obj.useOrgAndGroupNamesInExportPrefix,\n    Export: toJson_Export(obj.export),\n    CopySettings: obj.copySettings?.map((y) =>\n      toJson_ApiAtlasDiskBackupCopySettingView(y)\n    ),\n    DeleteCopiedBackups: obj.deleteCopiedBackups?.map((y) =>\n      toJson_ApiDeleteCopiedBackupsView(y)\n    ),\n    Policies: obj.policies?.map((y) => toJson_ApiPolicyView(y)),\n    ReferenceHourOfDay: obj.referenceHourOfDay,\n    ReferenceMinuteOfHour: obj.referenceMinuteOfHour,\n    RestoreWindowDays: obj.restoreWindowDays,\n    UpdateSnapshots: obj.updateSnapshots,\n    Profile: obj.profile,\n    Links: obj.links?.map((y) => toJson_Link(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Export\n */\nexport interface Export {\n  /**\n   * Unique identifier of the AWS bucket to export the cloud backup snapshot to\n   *\n   * @schema Export#ExportBucketId\n   */\n  readonly exportBucketId?: string;\n\n  /**\n   * Frequency associated with the export policy. Value can be daily, weekly, or monthly.\n   *\n   * @schema Export#FrequencyType\n   */\n  readonly frequencyType?: string;\n}\n\n/**\n * Converts an object of type 'Export' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Export(\n  obj: Export | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ExportBucketId: obj.exportBucketId,\n    FrequencyType: obj.frequencyType,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasDiskBackupCopySettingView\n */\nexport interface ApiAtlasDiskBackupCopySettingView {\n  /**\n   * A label that identifies the cloud provider that stores the snapshot copy.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Target region to copy snapshots belonging to replicationSpecId to.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#RegionName\n   */\n  readonly regionName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the replication object for a zone in a cluster.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#ReplicationSpecId\n   */\n  readonly replicationSpecId?: string;\n\n  /**\n   * Flag that indicates whether to copy the oplogs to the target region.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#ShouldCopyOplogs\n   */\n  readonly shouldCopyOplogs?: boolean;\n\n  /**\n   * List that describes which types of snapshots to copy.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#Frequencies\n   */\n  readonly frequencies?: string[];\n}\n\n/**\n * Converts an object of type 'ApiAtlasDiskBackupCopySettingView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasDiskBackupCopySettingView(\n  obj: ApiAtlasDiskBackupCopySettingView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    RegionName: obj.regionName,\n    ReplicationSpecId: obj.replicationSpecId,\n    ShouldCopyOplogs: obj.shouldCopyOplogs,\n    Frequencies: obj.frequencies?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiDeleteCopiedBackupsView\n */\nexport interface ApiDeleteCopiedBackupsView {\n  /**\n   * A label that identifies the cloud provider for the deleted copy setting whose backup copies you want to delete\n   *\n   * @schema ApiDeleteCopiedBackupsView#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Target region for the deleted copy setting whose backup copies you want to delete.\n   *\n   * @schema ApiDeleteCopiedBackupsView#RegionName\n   */\n  readonly regionName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the replication object for a zone in a cluster.\n   *\n   * @schema ApiDeleteCopiedBackupsView#ReplicationSpecId\n   */\n  readonly replicationSpecId?: string;\n}\n\n/**\n * Converts an object of type 'ApiDeleteCopiedBackupsView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiDeleteCopiedBackupsView(\n  obj: ApiDeleteCopiedBackupsView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    RegionName: obj.regionName,\n    ReplicationSpecId: obj.replicationSpecId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiPolicyView\n */\nexport interface ApiPolicyView {\n  /**\n   * @schema ApiPolicyView#ID\n   */\n  readonly id?: string;\n\n  /**\n   * @schema ApiPolicyView#PolicyItems\n   */\n  readonly policyItems?: ApiPolicyItemView[];\n}\n\n/**\n * Converts an object of type 'ApiPolicyView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiPolicyView(\n  obj: ApiPolicyView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ID: obj.id,\n    PolicyItems: obj.policyItems?.map((y) => toJson_ApiPolicyItemView(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Link\n */\nexport interface Link {\n  /**\n   * Uniform Resource Locator (URL) that points another API resource to which this response has some relationship. This URL often begins with `https://mms.mongodb.com`.\n   *\n   * @schema Link#Href\n   */\n  readonly href?: string;\n\n  /**\n   * Uniform Resource Locator (URL) that defines the semantic relationship between this resource and another API resource. This URL often begins with `https://mms.mongodb.com`.\n   *\n   * @schema Link#Rel\n   */\n  readonly rel?: string;\n}\n\n/**\n * Converts an object of type 'Link' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Link(\n  obj: Link | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Href: obj.href,\n    Rel: obj.rel,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiPolicyItemView\n */\nexport interface ApiPolicyItemView {\n  /**\n   * Unique identifier of the backup policy item.\n   *\n   * @schema ApiPolicyItemView#ID\n   */\n  readonly id?: string;\n\n  /**\n   * Frequency associated with the backup policy item. One of the following values: hourly, daily, weekly or monthly.\n   *\n   * @schema ApiPolicyItemView#FrequencyType\n   */\n  readonly frequencyType?: string;\n\n  /**\n   * Desired frequency of the new backup policy item specified by frequencyType.\n   *\n   * @schema ApiPolicyItemView#FrequencyInterval\n   */\n  readonly frequencyInterval?: number;\n\n  /**\n   * Duration for which the backup is kept. Associated with retentionUnit.\n   *\n   * @schema ApiPolicyItemView#RetentionValue\n   */\n  readonly retentionValue?: number;\n\n  /**\n   * Metric of duration of the backup policy item: days, weeks, or months.\n   *\n   * @schema ApiPolicyItemView#RetentionUnit\n   */\n  readonly retentionUnit?: string;\n}\n\n/**\n * Converts an object of type 'ApiPolicyItemView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiPolicyItemView(\n  obj: ApiPolicyItemView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ID: obj.id,\n    FrequencyType: obj.frequencyType,\n    FrequencyInterval: obj.frequencyInterval,\n    RetentionValue: obj.retentionValue,\n    RetentionUnit: obj.retentionUnit,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::CloudBackupSchedule`\n *\n * @cloudformationResource MongoDB::Atlas::CloudBackupSchedule\n * @stability external\n */\nexport class CfnCloudBackupSchedule extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::CloudBackupSchedule\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnCloudBackupScheduleProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackupSchedule.ClusterId`\n   */\n  public readonly attrClusterId: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackupSchedule.NextSnapshot`\n   */\n  public readonly attrNextSnapshot: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::CloudBackupSchedule`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnCloudBackupScheduleProps\n  ) {\n    super(scope, id, {\n      type: CfnCloudBackupSchedule.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnCloudBackupScheduleProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrClusterId = cdk.Token.asString(this.getAtt(\"ClusterId\"));\n    this.attrNextSnapshot = cdk.Token.asString(this.getAtt(\"NextSnapshot\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/cloud-backup-schedule/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * An example resource schema demonstrating some basic constructs and validation rules.\n *\n * @schema CfnCloudBackupScheduleProps\n */\nexport interface CfnCloudBackupScheduleProps {\n  /**\n   * The unique identifier of the project for the Atlas cluster.\n   *\n   * @schema CfnCloudBackupScheduleProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * The name of the Atlas cluster that contains the snapshots you want to retrieve.\n   *\n   * @schema CfnCloudBackupScheduleProps#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * Unique identifier of the snapshot.\n   *\n   * @schema CfnCloudBackupScheduleProps#Id\n   */\n  readonly id?: string;\n\n  /**\n   * Flag that indicates whether automatic export of cloud backup snapshots to the AWS bucket is enabled.\n   *\n   * @schema CfnCloudBackupScheduleProps#AutoExportEnabled\n   */\n  readonly autoExportEnabled: boolean;\n\n  /**\n   * Specify true to use organization and project names instead of organization and project UUIDs in the path for the metadata files that Atlas uploads to your S3 bucket after it finishes exporting the snapshots.\n   *\n   * @schema CfnCloudBackupScheduleProps#UseOrgAndGroupNamesInExportPrefix\n   */\n  readonly useOrgAndGroupNamesInExportPrefix?: boolean;\n\n  /**\n   * Policy for automatically exporting cloud backup snapshots.\n   *\n   * @schema CfnCloudBackupScheduleProps#Export\n   */\n  readonly export?: Export;\n\n  /**\n   * List that contains a document for each copy setting item in the desired backup policy.\n   *\n   * @schema CfnCloudBackupScheduleProps#CopySettings\n   */\n  readonly copySettings?: ApiAtlasDiskBackupCopySettingView[];\n\n  /**\n   * List that contains a document for each deleted copy setting whose backup copies you want to delete.\n   *\n   * @schema CfnCloudBackupScheduleProps#DeleteCopiedBackups\n   */\n  readonly deleteCopiedBackups?: ApiDeleteCopiedBackupsView[];\n\n  /**\n   * Rules set for this backup schedule.\n   *\n   * @schema CfnCloudBackupScheduleProps#Policies\n   */\n  readonly policies?: ApiPolicyView[];\n\n  /**\n   * UTC Hour of day between 0 and 23 representing which hour of the day that Atlas takes a snapshot\n   *\n   * @schema CfnCloudBackupScheduleProps#ReferenceHourOfDay\n   */\n  readonly referenceHourOfDay?: number;\n\n  /**\n   * UTC Minute of day between 0 and 59 representing which minute of the referenceHourOfDay that Atlas takes the snapshot.\n   *\n   * @schema CfnCloudBackupScheduleProps#ReferenceMinuteOfHour\n   */\n  readonly referenceMinuteOfHour?: number;\n\n  /**\n   * Number of days back in time you can restore to with Continuous Cloud Backup accuracy. Must be a positive, non-zero integer.\n   *\n   * @schema CfnCloudBackupScheduleProps#RestoreWindowDays\n   */\n  readonly restoreWindowDays?: number;\n\n  /**\n   * Flag indicating if updates to retention in the backup policy were applied to snapshots that Atlas took earlier.\n   *\n   * @schema CfnCloudBackupScheduleProps#UpdateSnapshots\n   */\n  readonly updateSnapshots?: boolean;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnCloudBackupScheduleProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * List of one or more Uniform Resource Locators (URLs) that point to API sub-resources, related API resources, or both. RFC 5988 outlines these relationships.\n   *\n   * @schema CfnCloudBackupScheduleProps#Links\n   */\n  readonly links?: Link[];\n}\n\n/**\n * Converts an object of type 'CfnCloudBackupScheduleProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnCloudBackupScheduleProps(\n  obj: CfnCloudBackupScheduleProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    ClusterName: obj.clusterName,\n    Id: obj.id,\n    AutoExportEnabled: obj.autoExportEnabled,\n    UseOrgAndGroupNamesInExportPrefix: obj.useOrgAndGroupNamesInExportPrefix,\n    Export: toJson_Export(obj.export),\n    CopySettings: obj.copySettings?.map((y) =>\n      toJson_ApiAtlasDiskBackupCopySettingView(y)\n    ),\n    DeleteCopiedBackups: obj.deleteCopiedBackups?.map((y) =>\n      toJson_ApiDeleteCopiedBackupsView(y)\n    ),\n    Policies: obj.policies?.map((y) => toJson_ApiPolicyView(y)),\n    ReferenceHourOfDay: obj.referenceHourOfDay,\n    ReferenceMinuteOfHour: obj.referenceMinuteOfHour,\n    RestoreWindowDays: obj.restoreWindowDays,\n    UpdateSnapshots: obj.updateSnapshots,\n    Profile: obj.profile,\n    Links: obj.links?.map((y) => toJson_Link(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Export\n */\nexport interface Export {\n  /**\n   * Unique identifier of the AWS bucket to export the cloud backup snapshot to\n   *\n   * @schema Export#ExportBucketId\n   */\n  readonly exportBucketId?: string;\n\n  /**\n   * Frequency associated with the export policy. Value can be daily, weekly, monthly or yearly.\n   *\n   * @schema Export#FrequencyType\n   */\n  readonly frequencyType?: string;\n}\n\n/**\n * Converts an object of type 'Export' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Export(\n  obj: Export | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ExportBucketId: obj.exportBucketId,\n    FrequencyType: obj.frequencyType,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasDiskBackupCopySettingView\n */\nexport interface ApiAtlasDiskBackupCopySettingView {\n  /**\n   * A label that identifies the cloud provider that stores the snapshot copy.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Target region to copy snapshots belonging to replicationSpecId to.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#RegionName\n   */\n  readonly regionName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the replication object for a zone in a cluster.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#ReplicationSpecId\n   */\n  readonly replicationSpecId?: string;\n\n  /**\n   * Flag that indicates whether to copy the oplogs to the target region.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#ShouldCopyOplogs\n   */\n  readonly shouldCopyOplogs?: boolean;\n\n  /**\n   * List that describes which types of snapshots to copy.\n   *\n   * @schema ApiAtlasDiskBackupCopySettingView#Frequencies\n   */\n  readonly frequencies?: string[];\n}\n\n/**\n * Converts an object of type 'ApiAtlasDiskBackupCopySettingView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasDiskBackupCopySettingView(\n  obj: ApiAtlasDiskBackupCopySettingView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    RegionName: obj.regionName,\n    ReplicationSpecId: obj.replicationSpecId,\n    ShouldCopyOplogs: obj.shouldCopyOplogs,\n    Frequencies: obj.frequencies?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiDeleteCopiedBackupsView\n */\nexport interface ApiDeleteCopiedBackupsView {\n  /**\n   * A label that identifies the cloud provider for the deleted copy setting whose backup copies you want to delete\n   *\n   * @schema ApiDeleteCopiedBackupsView#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Target region for the deleted copy setting whose backup copies you want to delete.\n   *\n   * @schema ApiDeleteCopiedBackupsView#RegionName\n   */\n  readonly regionName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the replication object for a zone in a cluster.\n   *\n   * @schema ApiDeleteCopiedBackupsView#ReplicationSpecId\n   */\n  readonly replicationSpecId?: string;\n}\n\n/**\n * Converts an object of type 'ApiDeleteCopiedBackupsView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiDeleteCopiedBackupsView(\n  obj: ApiDeleteCopiedBackupsView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    RegionName: obj.regionName,\n    ReplicationSpecId: obj.replicationSpecId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiPolicyView\n */\nexport interface ApiPolicyView {\n  /**\n   * Unique 24-hexadecimal digit string that identifies this backup policy. The policy id can be retrieved by running: atlas backups schedule describe \"${clusterName}\" --projectId \"${projectId}\" | jq -r '.policies[0].id'\n   *\n   * @schema ApiPolicyView#ID\n   */\n  readonly id?: string;\n\n  /**\n   * @schema ApiPolicyView#PolicyItems\n   */\n  readonly policyItems?: ApiPolicyItemView[];\n}\n\n/**\n * Converts an object of type 'ApiPolicyView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiPolicyView(\n  obj: ApiPolicyView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ID: obj.id,\n    PolicyItems: obj.policyItems?.map((y) => toJson_ApiPolicyItemView(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Link\n */\nexport interface Link {\n  /**\n   * Uniform Resource Locator (URL) that points another API resource to which this response has some relationship. This URL often begins with `https://mms.mongodb.com`.\n   *\n   * @schema Link#Href\n   */\n  readonly href?: string;\n\n  /**\n   * Uniform Resource Locator (URL) that defines the semantic relationship between this resource and another API resource. This URL often begins with `https://mms.mongodb.com`.\n   *\n   * @schema Link#Rel\n   */\n  readonly rel?: string;\n}\n\n/**\n * Converts an object of type 'Link' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Link(\n  obj: Link | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Href: obj.href,\n    Rel: obj.rel,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiPolicyItemView\n */\nexport interface ApiPolicyItemView {\n  /**\n   * Unique identifier of the backup policy item.\n   *\n   * @schema ApiPolicyItemView#ID\n   */\n  readonly id?: string;\n\n  /**\n   * Frequency associated with the backup policy item. One of the following values: hourly, daily, weekly, monthly or yearly.\n   *\n   * @schema ApiPolicyItemView#FrequencyType\n   */\n  readonly frequencyType?: string;\n\n  /**\n   * Desired frequency of the new backup policy item specified by frequencyType.\n   *\n   * @schema ApiPolicyItemView#FrequencyInterval\n   */\n  readonly frequencyInterval?: number;\n\n  /**\n   * Duration for which the backup is kept. Associated with retentionUnit.\n   *\n   * @schema ApiPolicyItemView#RetentionValue\n   */\n  readonly retentionValue?: number;\n\n  /**\n   * Metric of duration of the backup policy item: days, weeks, months or years.\n   *\n   * @schema ApiPolicyItemView#RetentionUnit\n   */\n  readonly retentionUnit?: string;\n}\n\n/**\n * Converts an object of type 'ApiPolicyItemView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiPolicyItemView(\n  obj: ApiPolicyItemView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ID: obj.id,\n    FrequencyType: obj.frequencyType,\n    FrequencyInterval: obj.frequencyInterval,\n    RetentionValue: obj.retentionValue,\n    RetentionUnit: obj.retentionUnit,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::CloudBackupSchedule`\n *\n * @cloudformationResource MongoDB::Atlas::CloudBackupSchedule\n * @stability external\n */\nexport class CfnCloudBackupSchedule extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::CloudBackupSchedule\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnCloudBackupScheduleProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackupSchedule.ClusterId`\n   */\n  public readonly attrClusterId: string;\n  /**\n   * Attribute `MongoDB::Atlas::CloudBackupSchedule.NextSnapshot`\n   */\n  public readonly attrNextSnapshot: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::CloudBackupSchedule`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnCloudBackupScheduleProps\n  ) {\n    super(scope, id, {\n      type: CfnCloudBackupSchedule.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnCloudBackupScheduleProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrClusterId = cdk.Token.asString(this.getAtt(\"ClusterId\"));\n    this.attrNextSnapshot = cdk.Token.asString(this.getAtt(\"NextSnapshot\"));\n  }\n}\n"]}

@@ -52,3 +52,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnCloudBackupSnapshotExportBucket[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSnapshotExportBucket", version: "3.7.2" };
CfnCloudBackupSnapshotExportBucket[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSnapshotExportBucket", version: "3.8.0" };
/**

@@ -55,0 +55,0 @@ * The CloudFormation resource type name for this resource class.

@@ -230,3 +230,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnCloudBackupSnapshot[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSnapshot", version: "3.7.2" };
CfnCloudBackupSnapshot[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCloudBackupSnapshot", version: "3.8.0" };
/**

@@ -233,0 +233,0 @@ * The CloudFormation resource type name for this resource class.

@@ -83,3 +83,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnClusterOutageSimulation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnClusterOutageSimulation", version: "3.7.2" };
CfnClusterOutageSimulation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnClusterOutageSimulation", version: "3.8.0" };
/**

@@ -86,0 +86,0 @@ * The CloudFormation resource type name for this resource class.

@@ -101,3 +101,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnCustomDbRole[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCustomDbRole", version: "3.7.2" };
CfnCustomDbRole[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCustomDbRole", version: "3.8.0" };
/**

@@ -104,0 +104,0 @@ * The CloudFormation resource type name for this resource class.

@@ -50,3 +50,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnCustomDnsConfigurationClusterAws[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCustomDnsConfigurationClusterAws", version: "3.7.2" };
CfnCustomDnsConfigurationClusterAws[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnCustomDnsConfigurationClusterAws", version: "3.8.0" };
/**

@@ -53,0 +53,0 @@ * The CloudFormation resource type name for this resource class.

@@ -149,3 +149,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnDataLakePipeline[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDataLakePipeline", version: "3.7.2" };
CfnDataLakePipeline[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDataLakePipeline", version: "3.8.0" };
/**

@@ -152,0 +152,0 @@ * The CloudFormation resource type name for this resource class.

@@ -87,3 +87,3 @@ import * as cdk from "aws-cdk-lib";

/**
* Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role.
* Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role. Default value is `NONE`.
*

@@ -90,0 +90,0 @@ * @schema CfnDatabaseUserPropsAwsiamType

@@ -36,3 +36,3 @@ "use strict";

/**
* Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role.
* Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role. Default value is `NONE`.
*

@@ -164,3 +164,3 @@ * @schema CfnDatabaseUserPropsAwsiamType

_a = JSII_RTTI_SYMBOL_1;
CfnDatabaseUser[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDatabaseUser", version: "3.7.2" };
CfnDatabaseUser[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDatabaseUser", version: "3.8.0" };
/**

@@ -170,2 +170,2 @@ * The CloudFormation resource type name for this resource class.

CfnDatabaseUser.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::DatabaseUser";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/database-user/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes database users.\n *\n * @schema CfnDatabaseUserProps\n */\nexport interface CfnDatabaseUserProps {\n  /**\n   * Date and time when MongoDB Cloud deletes the user. This parameter expresses its value in the ISO 8601 timestamp format in UTC and can include the time zone designation. You must specify a future date that falls within one week of making the Application Programming Interface (API) request.\n   *\n   * @schema CfnDatabaseUserProps#DeleteAfterDate\n   */\n  readonly deleteAfterDate?: string;\n\n  /**\n   * Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#AWSIAMType\n   */\n  readonly awsiamType?: CfnDatabaseUserPropsAwsiamType;\n\n  /**\n   * MongoDB database against which the MongoDB database user authenticates. MongoDB database users must provide both a username and authentication database to log into MongoDB.  Default value is `admin`.\n   *\n   * @schema CfnDatabaseUserProps#DatabaseName\n   */\n  readonly databaseName: string;\n\n  /**\n   * List that contains the key-value pairs for tagging and categorizing the MongoDB database user. The labels that you define do not appear in the console.\n   *\n   * @schema CfnDatabaseUserProps#Labels\n   */\n  readonly labels?: LabelDefinition[];\n\n  /**\n   * Method by which the provided username is authenticated. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#LdapAuthType\n   */\n  readonly ldapAuthType?: CfnDatabaseUserPropsLdapAuthType;\n\n  /**\n   * Method that briefs who owns the certificate provided. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#X509Type\n   */\n  readonly x509Type?: CfnDatabaseUserPropsX509Type;\n\n  /**\n   * The user’s password. This field is not included in the entity returned from the server.\n   *\n   * @schema CfnDatabaseUserProps#Password\n   */\n  readonly password?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your Atlas Project.\n   *\n   * @schema CfnDatabaseUserProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * List that provides the pairings of one role with one applicable database.\n   *\n   * @schema CfnDatabaseUserProps#Roles\n   */\n  readonly roles: RoleDefinition[];\n\n  /**\n   * List that contains clusters and MongoDB Atlas Data Lakes that this database user can access. If omitted, MongoDB Cloud grants the database user access to all the clusters and MongoDB Atlas Data Lakes in the project.\n   *\n   * @schema CfnDatabaseUserProps#Scopes\n   */\n  readonly scopes?: ScopeDefinition[];\n\n  /**\n   * Human-readable label that represents the user that authenticates to MongoDB. The format of this label depends on the method of authentication. This will be USER_ARN or ROLE_ARN if AWSIAMType is USER or ROLE. Refer https://www.mongodb.com/docs/atlas/reference/api-resources-spec/#tag/Database-Users/operation/createDatabaseUser for details.\n   *\n   * @schema CfnDatabaseUserProps#Username\n   */\n  readonly username: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided `default` is used\n   *\n   * @schema CfnDatabaseUserProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnDatabaseUserProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnDatabaseUserProps(\n  obj: CfnDatabaseUserProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DeleteAfterDate: obj.deleteAfterDate,\n    AWSIAMType: obj.awsiamType,\n    DatabaseName: obj.databaseName,\n    Labels: obj.labels?.map((y) => toJson_LabelDefinition(y)),\n    LdapAuthType: obj.ldapAuthType,\n    X509Type: obj.x509Type,\n    Password: obj.password,\n    ProjectId: obj.projectId,\n    Roles: obj.roles?.map((y) => toJson_RoleDefinition(y)),\n    Scopes: obj.scopes?.map((y) => toJson_ScopeDefinition(y)),\n    Username: obj.username,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role.\n *\n * @schema CfnDatabaseUserPropsAwsiamType\n */\nexport enum CfnDatabaseUserPropsAwsiamType {\n  /** NONE */\n  NONE = \"NONE\",\n  /** USER */\n  USER = \"USER\",\n  /** ROLE */\n  ROLE = \"ROLE\",\n}\n\n/**\n * @schema labelDefinition\n */\nexport interface LabelDefinition {\n  /**\n   * @schema labelDefinition#Key\n   */\n  readonly key?: string;\n\n  /**\n   * @schema labelDefinition#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'LabelDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_LabelDefinition(\n  obj: LabelDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Key: obj.key,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Method by which the provided username is authenticated. Default value is `NONE`.\n *\n * @schema CfnDatabaseUserPropsLdapAuthType\n */\nexport enum CfnDatabaseUserPropsLdapAuthType {\n  /** NONE */\n  NONE = \"NONE\",\n  /** USER */\n  USER = \"USER\",\n  /** GROUP */\n  GROUP = \"GROUP\",\n}\n\n/**\n * Method that briefs who owns the certificate provided. Default value is `NONE`.\n *\n * @schema CfnDatabaseUserPropsX509Type\n */\nexport enum CfnDatabaseUserPropsX509Type {\n  /** NONE */\n  NONE = \"NONE\",\n  /** MANAGED */\n  MANAGED = \"MANAGED\",\n  /** CUSTOMER */\n  CUSTOMER = \"CUSTOMER\",\n}\n\n/**\n * @schema roleDefinition\n */\nexport interface RoleDefinition {\n  /**\n   * @schema roleDefinition#CollectionName\n   */\n  readonly collectionName?: string;\n\n  /**\n   * @schema roleDefinition#DatabaseName\n   */\n  readonly databaseName?: string;\n\n  /**\n   * @schema roleDefinition#RoleName\n   */\n  readonly roleName?: string;\n}\n\n/**\n * Converts an object of type 'RoleDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_RoleDefinition(\n  obj: RoleDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CollectionName: obj.collectionName,\n    DatabaseName: obj.databaseName,\n    RoleName: obj.roleName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema scopeDefinition\n */\nexport interface ScopeDefinition {\n  /**\n   * @schema scopeDefinition#Name\n   */\n  readonly name?: string;\n\n  /**\n   * @schema scopeDefinition#Type\n   */\n  readonly type?: ScopeDefinitionType;\n}\n\n/**\n * Converts an object of type 'ScopeDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScopeDefinition(\n  obj: ScopeDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScopeDefinitionType\n */\nexport enum ScopeDefinitionType {\n  /** CLUSTER */\n  CLUSTER = \"CLUSTER\",\n  /** DATA_LAKE */\n  DATA_LAKE = \"DATA_LAKE\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::DatabaseUser`\n *\n * @cloudformationResource MongoDB::Atlas::DatabaseUser\n * @stability external\n */\nexport class CfnDatabaseUser extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::DatabaseUser\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnDatabaseUserProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::DatabaseUser.UserCFNIdentifier`\n   */\n  public readonly attrUserCFNIdentifier: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::DatabaseUser`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnDatabaseUserProps\n  ) {\n    super(scope, id, {\n      type: CfnDatabaseUser.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnDatabaseUserProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrUserCFNIdentifier = cdk.Token.asString(\n      this.getAtt(\"UserCFNIdentifier\")\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/database-user/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes database users.\n *\n * @schema CfnDatabaseUserProps\n */\nexport interface CfnDatabaseUserProps {\n  /**\n   * Date and time when MongoDB Cloud deletes the user. This parameter expresses its value in the ISO 8601 timestamp format in UTC and can include the time zone designation. You must specify a future date that falls within one week of making the Application Programming Interface (API) request.\n   *\n   * @schema CfnDatabaseUserProps#DeleteAfterDate\n   */\n  readonly deleteAfterDate?: string;\n\n  /**\n   * Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#AWSIAMType\n   */\n  readonly awsiamType?: CfnDatabaseUserPropsAwsiamType;\n\n  /**\n   * MongoDB database against which the MongoDB database user authenticates. MongoDB database users must provide both a username and authentication database to log into MongoDB.  Default value is `admin`.\n   *\n   * @schema CfnDatabaseUserProps#DatabaseName\n   */\n  readonly databaseName: string;\n\n  /**\n   * List that contains the key-value pairs for tagging and categorizing the MongoDB database user. The labels that you define do not appear in the console.\n   *\n   * @schema CfnDatabaseUserProps#Labels\n   */\n  readonly labels?: LabelDefinition[];\n\n  /**\n   * Method by which the provided username is authenticated. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#LdapAuthType\n   */\n  readonly ldapAuthType?: CfnDatabaseUserPropsLdapAuthType;\n\n  /**\n   * Method that briefs who owns the certificate provided. Default value is `NONE`.\n   *\n   * @schema CfnDatabaseUserProps#X509Type\n   */\n  readonly x509Type?: CfnDatabaseUserPropsX509Type;\n\n  /**\n   * The user’s password. This field is not included in the entity returned from the server.\n   *\n   * @schema CfnDatabaseUserProps#Password\n   */\n  readonly password?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your Atlas Project.\n   *\n   * @schema CfnDatabaseUserProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * List that provides the pairings of one role with one applicable database.\n   *\n   * @schema CfnDatabaseUserProps#Roles\n   */\n  readonly roles: RoleDefinition[];\n\n  /**\n   * List that contains clusters and MongoDB Atlas Data Lakes that this database user can access. If omitted, MongoDB Cloud grants the database user access to all the clusters and MongoDB Atlas Data Lakes in the project.\n   *\n   * @schema CfnDatabaseUserProps#Scopes\n   */\n  readonly scopes?: ScopeDefinition[];\n\n  /**\n   * Human-readable label that represents the user that authenticates to MongoDB. The format of this label depends on the method of authentication. This will be USER_ARN or ROLE_ARN if AWSIAMType is USER or ROLE. Refer https://www.mongodb.com/docs/atlas/reference/api-resources-spec/#tag/Database-Users/operation/createDatabaseUser for details.\n   *\n   * @schema CfnDatabaseUserProps#Username\n   */\n  readonly username: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided `default` is used\n   *\n   * @schema CfnDatabaseUserProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnDatabaseUserProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnDatabaseUserProps(\n  obj: CfnDatabaseUserProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DeleteAfterDate: obj.deleteAfterDate,\n    AWSIAMType: obj.awsiamType,\n    DatabaseName: obj.databaseName,\n    Labels: obj.labels?.map((y) => toJson_LabelDefinition(y)),\n    LdapAuthType: obj.ldapAuthType,\n    X509Type: obj.x509Type,\n    Password: obj.password,\n    ProjectId: obj.projectId,\n    Roles: obj.roles?.map((y) => toJson_RoleDefinition(y)),\n    Scopes: obj.scopes?.map((y) => toJson_ScopeDefinition(y)),\n    Username: obj.username,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that indicates whether the new database user authenticates with the Amazon Web Services (AWS) Identity and Access Management (IAM) credentials associated with the user or the user's role. Default value is `NONE`.\n *\n * @schema CfnDatabaseUserPropsAwsiamType\n */\nexport enum CfnDatabaseUserPropsAwsiamType {\n  /** NONE */\n  NONE = \"NONE\",\n  /** USER */\n  USER = \"USER\",\n  /** ROLE */\n  ROLE = \"ROLE\",\n}\n\n/**\n * @schema labelDefinition\n */\nexport interface LabelDefinition {\n  /**\n   * @schema labelDefinition#Key\n   */\n  readonly key?: string;\n\n  /**\n   * @schema labelDefinition#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'LabelDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_LabelDefinition(\n  obj: LabelDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Key: obj.key,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Method by which the provided username is authenticated. Default value is `NONE`.\n *\n * @schema CfnDatabaseUserPropsLdapAuthType\n */\nexport enum CfnDatabaseUserPropsLdapAuthType {\n  /** NONE */\n  NONE = \"NONE\",\n  /** USER */\n  USER = \"USER\",\n  /** GROUP */\n  GROUP = \"GROUP\",\n}\n\n/**\n * Method that briefs who owns the certificate provided. Default value is `NONE`.\n *\n * @schema CfnDatabaseUserPropsX509Type\n */\nexport enum CfnDatabaseUserPropsX509Type {\n  /** NONE */\n  NONE = \"NONE\",\n  /** MANAGED */\n  MANAGED = \"MANAGED\",\n  /** CUSTOMER */\n  CUSTOMER = \"CUSTOMER\",\n}\n\n/**\n * @schema roleDefinition\n */\nexport interface RoleDefinition {\n  /**\n   * @schema roleDefinition#CollectionName\n   */\n  readonly collectionName?: string;\n\n  /**\n   * @schema roleDefinition#DatabaseName\n   */\n  readonly databaseName?: string;\n\n  /**\n   * @schema roleDefinition#RoleName\n   */\n  readonly roleName?: string;\n}\n\n/**\n * Converts an object of type 'RoleDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_RoleDefinition(\n  obj: RoleDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CollectionName: obj.collectionName,\n    DatabaseName: obj.databaseName,\n    RoleName: obj.roleName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema scopeDefinition\n */\nexport interface ScopeDefinition {\n  /**\n   * @schema scopeDefinition#Name\n   */\n  readonly name?: string;\n\n  /**\n   * @schema scopeDefinition#Type\n   */\n  readonly type?: ScopeDefinitionType;\n}\n\n/**\n * Converts an object of type 'ScopeDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScopeDefinition(\n  obj: ScopeDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScopeDefinitionType\n */\nexport enum ScopeDefinitionType {\n  /** CLUSTER */\n  CLUSTER = \"CLUSTER\",\n  /** DATA_LAKE */\n  DATA_LAKE = \"DATA_LAKE\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::DatabaseUser`\n *\n * @cloudformationResource MongoDB::Atlas::DatabaseUser\n * @stability external\n */\nexport class CfnDatabaseUser extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::DatabaseUser\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnDatabaseUserProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::DatabaseUser.UserCFNIdentifier`\n   */\n  public readonly attrUserCFNIdentifier: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::DatabaseUser`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnDatabaseUserProps\n  ) {\n    super(scope, id, {\n      type: CfnDatabaseUser.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnDatabaseUserProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrUserCFNIdentifier = cdk.Token.asString(\n      this.getAtt(\"UserCFNIdentifier\")\n    );\n  }\n}\n"]}

@@ -288,3 +288,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnDataLakes[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDataLakes", version: "3.7.2" };
CfnDataLakes[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDataLakes", version: "3.8.0" };
/**

@@ -291,0 +291,0 @@ * The CloudFormation resource type name for this resource class.

@@ -10,5 +10,5 @@ import * as cdk from "aws-cdk-lib";

/**
* @schema CfnEncryptionAtRestProps#AwsKms
* @schema CfnEncryptionAtRestProps#AwsKmsConfig
*/
readonly awsKms: AwsKmsConfiguration;
readonly awsKmsConfig: AwsKmsConfig;
/**

@@ -34,9 +34,9 @@ * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).

*
* @schema AwsKms
* @schema AwsKmsConfig
*/
export interface AwsKmsConfiguration {
export interface AwsKmsConfig {
/**
* ID of an AWS IAM role authorized to manage an AWS customer master key.
*
* @schema AwsKms#RoleID
* @schema AwsKmsConfig#RoleID
*/

@@ -47,3 +47,3 @@ readonly roleId?: string;

*
* @schema AwsKms#CustomerMasterKeyID
* @schema AwsKmsConfig#CustomerMasterKeyID
*/

@@ -54,3 +54,3 @@ readonly customerMasterKeyId?: string;

*
* @schema AwsKms#Enabled
* @schema AwsKmsConfig#Enabled
*/

@@ -61,3 +61,3 @@ readonly enabled?: boolean;

*
* @schema AwsKms#Region
* @schema AwsKmsConfig#Region
*/

@@ -67,5 +67,5 @@ readonly region?: string;

/**
* Converts an object of type 'AwsKms' to JSON representation.
* Converts an object of type 'AwsKmsConfig' to JSON representation.
*/
export declare function toJson_AwsKms(obj: AwsKmsConfiguration | undefined): Record<string, any> | undefined;
export declare function toJson_AwsKmsConfig(obj: AwsKmsConfig | undefined): Record<string, any> | undefined;
/**

@@ -72,0 +72,0 @@ * A CloudFormation `MongoDB::Atlas::EncryptionAtRest`

"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnEncryptionAtRest = exports.toJson_AwsKms = exports.toJson_CfnEncryptionAtRestProps = void 0;
exports.CfnEncryptionAtRest = exports.toJson_AwsKmsConfig = exports.toJson_CfnEncryptionAtRestProps = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");

@@ -17,3 +17,3 @@ // Generated by cdk-import

const result = {
AwsKms: toJson_AwsKms(obj.awsKms),
AwsKmsConfig: toJson_AwsKmsConfig(obj.awsKmsConfig),
Profile: obj.profile,

@@ -27,6 +27,6 @@ ProjectId: obj.projectId,

/**
* Converts an object of type 'AwsKms' to JSON representation.
* Converts an object of type 'AwsKmsConfig' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_AwsKms(obj) {
function toJson_AwsKmsConfig(obj) {
if (obj === undefined) {

@@ -44,3 +44,3 @@ return undefined;

}
exports.toJson_AwsKms = toJson_AwsKms;
exports.toJson_AwsKmsConfig = toJson_AwsKmsConfig;
/* eslint-enable max-len, quote-props */

@@ -72,3 +72,3 @@ /**

_a = JSII_RTTI_SYMBOL_1;
CfnEncryptionAtRest[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnEncryptionAtRest", version: "3.7.2" };
CfnEncryptionAtRest[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnEncryptionAtRest", version: "3.8.0" };
/**

@@ -78,2 +78,2 @@ * The CloudFormation resource type name for this resource class.

CfnEncryptionAtRest.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::EncryptionAtRest";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/encryption-at-rest/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA6BnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,+BAA+B,CAC7C,GAAyC;IAEzC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC;QACjC,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,0EAgBC;AAsCD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,aAAa,CAC3B,GAAoC;IAEpC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,MAAM,EAAE,GAAG,CAAC,MAAM;KACnB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAjBD,sCAiBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,mBAAoB,SAAQ,GAAG,CAAC,WAAW;IAiBtD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA+B;QAE/B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,mBAAmB,CAAC,sBAAsB;YAChD,UAAU,EAAE,+BAA+B,CAAC,KAAK,CAAE;SACpD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;;AArCH,kDAsCC;;;AArCC;;GAEG;AACoB,0CAAsB,GAC3C,kCAAkC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns and edits the Encryption at Rest using Customer Key Management configuration.\n *\n * @schema CfnEncryptionAtRestProps\n */\nexport interface CfnEncryptionAtRestProps {\n  /**\n   * @schema CfnEncryptionAtRestProps#AwsKms\n   */\n  readonly awsKms: AwsKmsConfiguration;\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnEncryptionAtRestProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique identifier of the Atlas project to which the user belongs.\n   *\n   * @schema CfnEncryptionAtRestProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnEncryptionAtRestProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnEncryptionAtRestProps(\n  obj: CfnEncryptionAtRestProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AwsKms: toJson_AwsKms(obj.awsKms),\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Specifies AWS KMS configuration details and whether Encryption at Rest is enabled for an Atlas project.\n *\n * @schema AwsKms\n */\nexport interface AwsKmsConfiguration {\n  /**\n   * ID of an AWS IAM role authorized to manage an AWS customer master key.\n   *\n   * @schema AwsKms#RoleID\n   */\n  readonly roleId?: string;\n\n  /**\n   * The AWS customer master key used to encrypt and decrypt the MongoDB master keys.\n   *\n   * @schema AwsKms#CustomerMasterKeyID\n   */\n  readonly customerMasterKeyId?: string;\n\n  /**\n   * Specifies whether Encryption at Rest is enabled for an Atlas project. To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.\n   *\n   * @schema AwsKms#Enabled\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * The AWS region in which the AWS customer master key exists.\n   *\n   * @schema AwsKms#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'AwsKms' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AwsKms(\n  obj: AwsKmsConfiguration | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    RoleID: obj.roleId,\n    CustomerMasterKeyID: obj.customerMasterKeyId,\n    Enabled: obj.enabled,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::EncryptionAtRest`\n *\n * @cloudformationResource MongoDB::Atlas::EncryptionAtRest\n * @stability external\n */\nexport class CfnEncryptionAtRest extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::EncryptionAtRest\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnEncryptionAtRestProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::EncryptionAtRest.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::EncryptionAtRest`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnEncryptionAtRestProps\n  ) {\n    super(scope, id, {\n      type: CfnEncryptionAtRest.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnEncryptionAtRestProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/encryption-at-rest/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA6BnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,+BAA+B,CAC7C,GAAyC;IAEzC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,YAAY,EAAE,mBAAmB,CAAC,GAAG,CAAC,YAAY,CAAC;QACnD,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,0EAgBC;AAsCD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,mBAAmB,CACjC,GAA6B;IAE7B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,MAAM,EAAE,GAAG,CAAC,MAAM;KACnB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAjBD,kDAiBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,mBAAoB,SAAQ,GAAG,CAAC,WAAW;IAiBtD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA+B;QAE/B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,mBAAmB,CAAC,sBAAsB;YAChD,UAAU,EAAE,+BAA+B,CAAC,KAAK,CAAE;SACpD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;;AArCH,kDAsCC;;;AArCC;;GAEG;AACoB,0CAAsB,GAC3C,kCAAkC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns and edits the Encryption at Rest using Customer Key Management configuration.\n *\n * @schema CfnEncryptionAtRestProps\n */\nexport interface CfnEncryptionAtRestProps {\n  /**\n   * @schema CfnEncryptionAtRestProps#AwsKmsConfig\n   */\n  readonly awsKmsConfig: AwsKmsConfig;\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnEncryptionAtRestProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique identifier of the Atlas project to which the user belongs.\n   *\n   * @schema CfnEncryptionAtRestProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnEncryptionAtRestProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnEncryptionAtRestProps(\n  obj: CfnEncryptionAtRestProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AwsKmsConfig: toJson_AwsKmsConfig(obj.awsKmsConfig),\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Specifies AWS KMS configuration details and whether Encryption at Rest is enabled for an Atlas project.\n *\n * @schema AwsKmsConfig\n */\nexport interface AwsKmsConfig {\n  /**\n   * ID of an AWS IAM role authorized to manage an AWS customer master key.\n   *\n   * @schema AwsKmsConfig#RoleID\n   */\n  readonly roleId?: string;\n\n  /**\n   * The AWS customer master key used to encrypt and decrypt the MongoDB master keys.\n   *\n   * @schema AwsKmsConfig#CustomerMasterKeyID\n   */\n  readonly customerMasterKeyId?: string;\n\n  /**\n   * Specifies whether Encryption at Rest is enabled for an Atlas project. To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.\n   *\n   * @schema AwsKmsConfig#Enabled\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * The AWS region in which the AWS customer master key exists.\n   *\n   * @schema AwsKmsConfig#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'AwsKmsConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AwsKmsConfig(\n  obj: AwsKmsConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    RoleID: obj.roleId,\n    CustomerMasterKeyID: obj.customerMasterKeyId,\n    Enabled: obj.enabled,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::EncryptionAtRest`\n *\n * @cloudformationResource MongoDB::Atlas::EncryptionAtRest\n * @stability external\n */\nexport class CfnEncryptionAtRest extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::EncryptionAtRest\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnEncryptionAtRestProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::EncryptionAtRest.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::EncryptionAtRest`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnEncryptionAtRestProps\n  ) {\n    super(scope, id, {\n      type: CfnEncryptionAtRest.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnEncryptionAtRestProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}

@@ -19,3 +19,3 @@ "use strict";

projectId: projectId,
awsKms: {
awsKmsConfig: {
roleId: roleID,

@@ -27,2 +27,2 @@ customerMasterKeyId: customerMasterKeyId,

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVmYXVsdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sMS1yZXNvdXJjZXMvZW5jcnlwdGlvbi1hdC1yZXN0L2ludGVnLmRlZmF1bHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxtQ0FBbUM7QUFDbkMsbUNBQThDO0FBRTlDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsMEJBQTBCLEVBQUU7SUFDM0QsR0FBRyxFQUFFO1FBQ0gsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO1FBQ3RDLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtLQUN6QztDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sU0FBUyxHQUNiLEtBQUssQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDO0lBQzlDLE9BQU8sQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUM7QUFDdkMsTUFBTSxtQkFBbUIsR0FDdkIsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsd0JBQXdCLENBQUM7SUFDbEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQztBQUNyQyxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQztBQUUxRSxJQUFJLDJCQUFtQixDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRTtJQUNqRCxTQUFTLEVBQUUsU0FBUztJQUNwQixNQUFNLEVBQUU7UUFDTixNQUFNLEVBQUUsTUFBTTtRQUNkLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4QyxPQUFPLEVBQUUsSUFBSTtRQUNiLE1BQU0sRUFBRSxnQkFBZ0I7S0FDekI7Q0FDRixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjZGsgZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBDZm5FbmNyeXB0aW9uQXRSZXN0IH0gZnJvbSBcIi4vaW5kZXhcIjtcblxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjayhhcHAsIFwiYXRsYXMtRW5jQXRSZXN0LWNkay10ZXN0XCIsIHtcbiAgZW52OiB7XG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT04sXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbiAgfSxcbn0pO1xuXG5jb25zdCBwcm9qZWN0SWQgPVxuICBzdGFjay5ub2RlLnRyeUdldENvbnRleHQoXCJNT05HT0RCX1BST0pFQ1RfSURcIikgfHxcbiAgcHJvY2Vzcy5lbnYuTU9OR09EQl9BVExBU19QUk9KRUNUX0lEO1xuY29uc3QgY3VzdG9tZXJNYXN0ZXJLZXlJZCA9XG4gIHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dChcIkNVU1RPTUVSX01BU1RFUl9LRVlfSURcIikgfHxcbiAgcHJvY2Vzcy5lbnYuQ1VTVE9NRVJfTUFTVEVSX0tFWV9JRDtcbmNvbnN0IHJvbGVJRCA9IHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dChcIlJPTEVfSURcIikgfHwgcHJvY2Vzcy5lbnYuUk9MRV9JRDtcblxubmV3IENmbkVuY3J5cHRpb25BdFJlc3Qoc3RhY2ssIFwiZW5jcnlwdGlvbkF0UmVzdFwiLCB7XG4gIHByb2plY3RJZDogcHJvamVjdElkLFxuICBhd3NLbXM6IHtcbiAgICByb2xlSWQ6IHJvbGVJRCxcbiAgICBjdXN0b21lck1hc3RlcktleUlkOiBjdXN0b21lck1hc3RlcktleUlkLFxuICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgcmVnaW9uOiBcIkFQX05PUlRIRUFTVF8yXCIsXG4gIH0sXG59KTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVmYXVsdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sMS1yZXNvdXJjZXMvZW5jcnlwdGlvbi1hdC1yZXN0L2ludGVnLmRlZmF1bHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxtQ0FBbUM7QUFDbkMsbUNBQThDO0FBRTlDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsMEJBQTBCLEVBQUU7SUFDM0QsR0FBRyxFQUFFO1FBQ0gsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO1FBQ3RDLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtLQUN6QztDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sU0FBUyxHQUNiLEtBQUssQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDO0lBQzlDLE9BQU8sQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUM7QUFDdkMsTUFBTSxtQkFBbUIsR0FDdkIsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsd0JBQXdCLENBQUM7SUFDbEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQztBQUNyQyxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQztBQUUxRSxJQUFJLDJCQUFtQixDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRTtJQUNqRCxTQUFTLEVBQUUsU0FBUztJQUNwQixZQUFZLEVBQUU7UUFDWixNQUFNLEVBQUUsTUFBTTtRQUNkLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4QyxPQUFPLEVBQUUsSUFBSTtRQUNiLE1BQU0sRUFBRSxnQkFBZ0I7S0FDekI7Q0FDRixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjZGsgZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBDZm5FbmNyeXB0aW9uQXRSZXN0IH0gZnJvbSBcIi4vaW5kZXhcIjtcblxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjayhhcHAsIFwiYXRsYXMtRW5jQXRSZXN0LWNkay10ZXN0XCIsIHtcbiAgZW52OiB7XG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT04sXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbiAgfSxcbn0pO1xuXG5jb25zdCBwcm9qZWN0SWQgPVxuICBzdGFjay5ub2RlLnRyeUdldENvbnRleHQoXCJNT05HT0RCX1BST0pFQ1RfSURcIikgfHxcbiAgcHJvY2Vzcy5lbnYuTU9OR09EQl9BVExBU19QUk9KRUNUX0lEO1xuY29uc3QgY3VzdG9tZXJNYXN0ZXJLZXlJZCA9XG4gIHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dChcIkNVU1RPTUVSX01BU1RFUl9LRVlfSURcIikgfHxcbiAgcHJvY2Vzcy5lbnYuQ1VTVE9NRVJfTUFTVEVSX0tFWV9JRDtcbmNvbnN0IHJvbGVJRCA9IHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dChcIlJPTEVfSURcIikgfHwgcHJvY2Vzcy5lbnYuUk9MRV9JRDtcblxubmV3IENmbkVuY3J5cHRpb25BdFJlc3Qoc3RhY2ssIFwiZW5jcnlwdGlvbkF0UmVzdFwiLCB7XG4gIHByb2plY3RJZDogcHJvamVjdElkLFxuICBhd3NLbXNDb25maWc6IHtcbiAgICByb2xlSWQ6IHJvbGVJRCxcbiAgICBjdXN0b21lck1hc3RlcktleUlkOiBjdXN0b21lck1hc3RlcktleUlkLFxuICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgcmVnaW9uOiBcIkFQX05PUlRIRUFTVF8yXCIsXG4gIH0sXG59KTtcbiJdfQ==

@@ -407,14 +407,2 @@ import * as cdk from "aws-cdk-lib";

/**
* Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.ExternalId`
*/
readonly attrExternalId: string;
/**
* Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.IamAssumedRoleARN`
*/
readonly attrIamAssumedRoleARNN: string;
/**
* Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.IamUserARN`
*/
readonly attrIamUserARN: string;
/**
* Create a new `MongoDB::Atlas::FederatedDatabaseInstance`.

@@ -421,0 +409,0 @@ *

@@ -230,5 +230,2 @@ "use strict";

this.attrState = cdk.Token.asString(this.getAtt("State"));
this.attrExternalId = cdk.Token.asString(this.getAtt("CloudProviderConfig.ExternalId"));
this.attrIamUserARN = cdk.Token.asString(this.getAtt("CloudProviderConfig.IamUserARN"));
this.attrIamAssumedRoleARNN = cdk.Token.asString(this.getAtt("CloudProviderConfig.IamAssumedRoleARN"));
}

@@ -238,3 +235,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnFederatedDatabaseInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedDatabaseInstance", version: "3.7.2" };
CfnFederatedDatabaseInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedDatabaseInstance", version: "3.8.0" };
/**

@@ -244,2 +241,2 @@ * The CloudFormation resource type name for this resource class.

CfnFederatedDatabaseInstance.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::FederatedDatabaseInstance";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-database-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Federated Database Instances.\n *\n * @schema CfnFederatedDatabaseInstanceProps\n */\nexport interface CfnFederatedDatabaseInstanceProps {\n  /**\n   * Cloud provider linked to this data lake.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#CloudProviderConfig\n   */\n  readonly cloudProviderConfig?: CloudProviderConfig;\n\n  /**\n   * Information about the cloud provider region to which the data lake routes client connections. MongoDB Cloud supports AWS only.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#DataProcessRegion\n   */\n  readonly dataProcessRegion?: DataProcessRegion;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the data federation.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#TenantName\n   */\n  readonly tenantName: string;\n\n  /**\n   * Flag that indicates whether this request should check if the requesting IAM role can read from the S3 bucket. AWS checks if the role can list the objects in the bucket before writing to it. Some IAM roles only need write permissions. This flag allows you to skip that check.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#SkipRoleValidation\n   */\n  readonly skipRoleValidation?: boolean;\n\n  /**\n   * Configuration information for each data store and its mapping to MongoDB Cloud databases.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#Storage\n   */\n  readonly storage?: Storage;\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnFederatedDatabaseInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedDatabaseInstanceProps(\n  obj: CfnFederatedDatabaseInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProviderConfig: toJson_CloudProviderConfig(obj.cloudProviderConfig),\n    DataProcessRegion: toJson_DataProcessRegion(obj.dataProcessRegion),\n    ProjectId: obj.projectId,\n    TenantName: obj.tenantName,\n    SkipRoleValidation: obj.skipRoleValidation,\n    Storage: toJson_Storage(obj.storage),\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Cloud provider linked to this data lake..\n *\n * @schema CloudProviderConfig\n */\nexport interface CloudProviderConfig {\n  /**\n   * Unique identifier of the role that the data lake can use to access the data stores.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#ExternalId\n   */\n  readonly externalId?: string;\n\n  /**\n   * Amazon Resource Name (ARN) of the Identity and Access Management (IAM) role that the data lake assumes when accessing data stores.\n   *\n   * @schema CloudProviderConfig#IamAssumedRoleARN\n   */\n  readonly iamAssumedRoleArn?: string;\n\n  /**\n   * Amazon Resource Name (ARN) of the user that the data lake assumes when accessing data stores.\n   *\n   * @schema CloudProviderConfig#IamUserARN\n   */\n  readonly iamUserArn?: string;\n\n  /**\n   * Unique identifier of the role that the data lake can use to access the data stores.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#RoleId\n   */\n  readonly roleId?: string;\n\n  /**\n   * Name of the S3 data bucket that the provided role ID is authorized to access.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#TestS3Bucket\n   */\n  readonly testS3Bucket?: string;\n}\n\n/**\n * Converts an object of type 'CloudProviderConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CloudProviderConfig(\n  obj: CloudProviderConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ExternalId: obj.externalId,\n    IamAssumedRoleARN: obj.iamAssumedRoleArn,\n    IamUserARN: obj.iamUserArn,\n    RoleId: obj.roleId,\n    TestS3Bucket: obj.testS3Bucket,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Information about the cloud provider region to which the data lake routes client connections. MongoDB Cloud supports AWS only.\n *\n * @schema DataProcessRegion\n */\nexport interface DataProcessRegion {\n  /**\n   * Name of the cloud service that hosts the data lake's data stores.\n   *\n   * @schema DataProcessRegion#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Name of the region to which the data lake routes client connections.\n   *\n   * @schema DataProcessRegion#Region\n   */\n  readonly region: string;\n}\n\n/**\n * Converts an object of type 'DataProcessRegion' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DataProcessRegion(\n  obj: DataProcessRegion | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Configuration information for each data store and its mapping to MongoDB Cloud databases.\n *\n * @schema Storage\n */\nexport interface Storage {\n  /**\n   * Array that contains the queryable databases and collections for this data lake.\n   *\n   * @schema Storage#Databases\n   */\n  readonly databases?: Database[];\n\n  /**\n   * Array that contains the data stores for the data lake.\n   *\n   * @schema Storage#Stores\n   */\n  readonly stores?: Store[];\n}\n\n/**\n * Converts an object of type 'Storage' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Storage(\n  obj: Storage | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Databases: obj.databases?.map((y) => toJson_Database(y)),\n    Stores: obj.stores?.map((y) => toJson_Store(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Database\n */\nexport interface Database {\n  /**\n   * Array of collections and data sources that map to a stores data store.\n   *\n   * @schema Database#Collections\n   */\n  readonly collections?: Collection[];\n\n  /**\n   * Maximum number of wildcard collections in the database. This only applies to S3 data sources.\n   *\n   * @schema Database#MaxWildcardCollections\n   */\n  readonly maxWildcardCollections?: string;\n\n  /**\n   * Human-readable label that identifies the database to which the data lake maps data.\n   *\n   * @schema Database#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Array of aggregation pipelines that apply to the collection. This only applies to S3 data sources.\n   *\n   * @schema Database#Views\n   */\n  readonly views?: View[];\n}\n\n/**\n * Converts an object of type 'Database' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Database(\n  obj: Database | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collections: obj.collections?.map((y) => toJson_Collection(y)),\n    MaxWildcardCollections: obj.maxWildcardCollections,\n    Name: obj.name,\n    Views: obj.views?.map((y) => toJson_View(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Array that contains the data stores for the data lake.\n *\n * @schema Store\n */\nexport interface Store {\n  /**\n   * Human-readable label that identifies the data store. The databases.[n].collections.[n].dataSources.[n].storeName field references this values as part of the mapping configuration. To use MongoDB Cloud as a data store, the data lake requires a serverless instance or an M10 or higher cluster.\n   *\n   * @schema Store#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Allowed values atlas, http, online_archive, s3 and DataLakeAzureBlobStore.\n   *\n   * @schema Store#Provider\n   */\n  readonly provider?: string;\n\n  /**\n   * Human-readable label of the MongoDB Cloud cluster on which the store is based.\n   *\n   * @schema Store#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project.Regex ^([a-f0-9]{24})$ .\n   *\n   * @schema Store#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * MongoDB Cloud cluster read preference, which describes how to route read requests to the cluster.\n   *\n   * @schema Store#ReadPreference\n   */\n  readonly readPreference?: ReadPreference;\n}\n\n/**\n * Converts an object of type 'Store' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Store(\n  obj: Store | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Provider: obj.provider,\n    ClusterName: obj.clusterName,\n    ProjectId: obj.projectId,\n    ReadPreference: toJson_ReadPreference(obj.readPreference),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Array of collections and data sources that map to a stores data store.\n *\n * @schema Collection\n */\nexport interface Collection {\n  /**\n   * Array that contains the data stores that map to a collection for this data lake.\n   *\n   * @schema Collection#DataSources\n   */\n  readonly dataSources?: DataSource[];\n\n  /**\n   * @schema Collection#Name\n   */\n  readonly name?: string;\n}\n\n/**\n * Converts an object of type 'Collection' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Collection(\n  obj: Collection | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DataSources: obj.dataSources?.map((y) => toJson_DataSource(y)),\n    Name: obj.name,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema View\n */\nexport interface View {\n  /**\n   * Human-readable label that identifies the view, which corresponds to an aggregation pipeline on a collection.\n   *\n   * @schema View#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Aggregation pipeline stages to apply to the source collection.\n   *\n   * @schema View#Pipeline\n   */\n  readonly pipeline?: string;\n\n  /**\n   * Human-readable label that identifies the source collection for the view.\n   *\n   * @schema View#Source\n   */\n  readonly source?: string;\n}\n\n/**\n * Converts an object of type 'View' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_View(\n  obj: View | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Pipeline: obj.pipeline,\n    Source: obj.source,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ReadPreference\n */\nexport interface ReadPreference {\n  /**\n   * \"primary\" \"primaryPreferred\" \"secondary\" \"secondaryPreferred\" \"nearest\"\n   * Read preference mode that specifies to which replica set member to route the read requests.\n   *\n   * @schema ReadPreference#Mode\n   */\n  readonly mode?: string;\n\n  /**\n   * Maximum replication lag, or staleness, for reads from secondaries.\n   *\n   * @schema ReadPreference#MaxStalenessSeconds\n   */\n  readonly maxStalenessSeconds?: string;\n\n  /**\n   * List that contains tag sets or tag specification documents. If specified, Atlas Data Lake routes read requests to replica set member or members that are associated with the specified tags.\n   *\n   * @schema ReadPreference#TagSets\n   */\n  readonly tagSets?: TagSet[][];\n}\n\n/**\n * Converts an object of type 'ReadPreference' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ReadPreference(\n  obj: ReadPreference | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Mode: obj.mode,\n    MaxStalenessSeconds: obj.maxStalenessSeconds,\n    TagSets: obj.tagSets?.map((y) => y?.map((x) => toJson_TagSet(x))),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DataSource\n */\nexport interface DataSource {\n  /**\n   * Flag that validates the scheme in the specified URLs. If true, allows insecure HTTP scheme, doesn't verify the server's certificate chain and hostname, and accepts any certificate with any hostname presented by the server. If false, allows secure HTTPS scheme only.\n   *\n   * @schema DataSource#AllowInsecure\n   */\n  readonly allowInsecure?: boolean;\n\n  /**\n   * Human-readable label that identifies the collection in the database. For creating a wildcard (*) collection, you must omit this parameter.\n   *\n   * @schema DataSource#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * Regex pattern to use for creating the wildcard (*) collection. To learn more about the regex syntax, see Go programming language.( https://pkg.go.dev/regexp ).\n   *\n   * @schema DataSource#CollectionRegex\n   */\n  readonly collectionRegex?: string;\n\n  /**\n   * Human-readable label that identifies the database, which contains the collection in the cluster. You must omit this parameter to generate wildcard (*) collections for dynamically generated databases.\n   *\n   * @schema DataSource#Database\n   */\n  readonly database?: string;\n\n  /**\n   * Regex pattern to use for creating the wildcard (*) collection. To learn more about the regex syntax, see Go programming language.( https://pkg.go.dev/regexp ).\n   *\n   * @schema DataSource#DatabaseRegex\n   */\n  readonly databaseRegex?: string;\n\n  /**\n   * File format that MongoDB Cloud uses if it encounters a file without a file extension while searching storeName.Enum: \".avro\" \".avro.bz2\" \".avro.gz\" \".bson\" \".bson.bz2\" \".bson.gz\" \".bsonx\" \".csv\" \".csv.bz2\" \".csv.gz\" \".json\" \".json.bz2\" \".json.gz\" \".orc\" \".parquet\" \".tsv\" \".tsv.bz2\" \".tsv.gz\"\n   *\n   * @schema DataSource#DefaultFormat\n   */\n  readonly defaultFormat?: string;\n\n  /**\n   * File path that controls how MongoDB Cloud searches for and parses files in the storeName before mapping them to a collection.Specify / to capture all files and folders from the prefix path.\n   *\n   * @schema DataSource#Path\n   */\n  readonly path?: string;\n\n  /**\n   * Name for the field that includes the provenance of the documents in the results. MongoDB Cloud returns different fields in the results for each supported provider.\n   *\n   * @schema DataSource#ProvenanceFieldName\n   */\n  readonly provenanceFieldName?: string;\n\n  /**\n   * Human-readable label that identifies the data store that MongoDB Cloud maps to the collection.\n   *\n   * @schema DataSource#StoreName\n   */\n  readonly storeName?: string;\n\n  /**\n   * URLs of the publicly accessible data files. You can't specify URLs that require authentication. Atlas Data Lake creates a partition for each URL. If empty or omitted, Data Lake uses the URLs from the store specified in the dataSources.storeName parameter.\n   *\n   * @schema DataSource#Urls\n   */\n  readonly urls?: string[];\n}\n\n/**\n * Converts an object of type 'DataSource' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DataSource(\n  obj: DataSource | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AllowInsecure: obj.allowInsecure,\n    Collection: obj.collection,\n    CollectionRegex: obj.collectionRegex,\n    Database: obj.database,\n    DatabaseRegex: obj.databaseRegex,\n    DefaultFormat: obj.defaultFormat,\n    Path: obj.path,\n    ProvenanceFieldName: obj.provenanceFieldName,\n    StoreName: obj.storeName,\n    Urls: obj.urls?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema TagSet\n */\nexport interface TagSet {\n  /**\n   * Human-readable label of the tag.\n   *\n   * @schema TagSet#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Human-readable label of the tag.\n   *\n   * @schema TagSet#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'TagSet' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_TagSet(\n  obj: TagSet | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedDatabaseInstance`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedDatabaseInstance\n * @stability external\n */\nexport class CfnFederatedDatabaseInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedDatabaseInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedDatabaseInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.HostNames`\n   */\n  public readonly attrHostNames: string[];\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.State`\n   */\n  public readonly attrState: string;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.ExternalId`\n   */\n  public readonly attrExternalId: string;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.IamAssumedRoleARN`\n   */\n  public readonly attrIamAssumedRoleARNN: string;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.CloudProviderConfig.IamUserARN`\n   */\n  public readonly attrIamUserARN: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedDatabaseInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedDatabaseInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedDatabaseInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedDatabaseInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrHostNames = cdk.Token.asList(this.getAtt(\"HostNames\"));\n    this.attrState = cdk.Token.asString(this.getAtt(\"State\"));\n    this.attrExternalId = cdk.Token.asString(\n      this.getAtt(\"CloudProviderConfig.ExternalId\")\n    );\n    this.attrIamUserARN = cdk.Token.asString(\n      this.getAtt(\"CloudProviderConfig.IamUserARN\")\n    );\n    this.attrIamAssumedRoleARNN = cdk.Token.asString(\n      this.getAtt(\"CloudProviderConfig.IamAssumedRoleARN\")\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-database-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Federated Database Instances.\n *\n * @schema CfnFederatedDatabaseInstanceProps\n */\nexport interface CfnFederatedDatabaseInstanceProps {\n  /**\n   * Cloud provider linked to this data lake.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#CloudProviderConfig\n   */\n  readonly cloudProviderConfig?: CloudProviderConfig;\n\n  /**\n   * Information about the cloud provider region to which the data lake routes client connections. MongoDB Cloud supports AWS only.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#DataProcessRegion\n   */\n  readonly dataProcessRegion?: DataProcessRegion;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the data federation.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#TenantName\n   */\n  readonly tenantName: string;\n\n  /**\n   * Flag that indicates whether this request should check if the requesting IAM role can read from the S3 bucket. AWS checks if the role can list the objects in the bucket before writing to it. Some IAM roles only need write permissions. This flag allows you to skip that check.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#SkipRoleValidation\n   */\n  readonly skipRoleValidation?: boolean;\n\n  /**\n   * Configuration information for each data store and its mapping to MongoDB Cloud databases.\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#Storage\n   */\n  readonly storage?: Storage;\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnFederatedDatabaseInstanceProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnFederatedDatabaseInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedDatabaseInstanceProps(\n  obj: CfnFederatedDatabaseInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProviderConfig: toJson_CloudProviderConfig(obj.cloudProviderConfig),\n    DataProcessRegion: toJson_DataProcessRegion(obj.dataProcessRegion),\n    ProjectId: obj.projectId,\n    TenantName: obj.tenantName,\n    SkipRoleValidation: obj.skipRoleValidation,\n    Storage: toJson_Storage(obj.storage),\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Cloud provider linked to this data lake..\n *\n * @schema CloudProviderConfig\n */\nexport interface CloudProviderConfig {\n  /**\n   * Unique identifier of the role that the data lake can use to access the data stores.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#ExternalId\n   */\n  readonly externalId?: string;\n\n  /**\n   * Amazon Resource Name (ARN) of the Identity and Access Management (IAM) role that the data lake assumes when accessing data stores.\n   *\n   * @schema CloudProviderConfig#IamAssumedRoleARN\n   */\n  readonly iamAssumedRoleArn?: string;\n\n  /**\n   * Amazon Resource Name (ARN) of the user that the data lake assumes when accessing data stores.\n   *\n   * @schema CloudProviderConfig#IamUserARN\n   */\n  readonly iamUserArn?: string;\n\n  /**\n   * Unique identifier of the role that the data lake can use to access the data stores.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#RoleId\n   */\n  readonly roleId?: string;\n\n  /**\n   * Name of the S3 data bucket that the provided role ID is authorized to access.Required if specifying cloudProviderConfig.\n   *\n   * @schema CloudProviderConfig#TestS3Bucket\n   */\n  readonly testS3Bucket?: string;\n}\n\n/**\n * Converts an object of type 'CloudProviderConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CloudProviderConfig(\n  obj: CloudProviderConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ExternalId: obj.externalId,\n    IamAssumedRoleARN: obj.iamAssumedRoleArn,\n    IamUserARN: obj.iamUserArn,\n    RoleId: obj.roleId,\n    TestS3Bucket: obj.testS3Bucket,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Information about the cloud provider region to which the data lake routes client connections. MongoDB Cloud supports AWS only.\n *\n * @schema DataProcessRegion\n */\nexport interface DataProcessRegion {\n  /**\n   * Name of the cloud service that hosts the data lake's data stores.\n   *\n   * @schema DataProcessRegion#CloudProvider\n   */\n  readonly cloudProvider?: string;\n\n  /**\n   * Name of the region to which the data lake routes client connections.\n   *\n   * @schema DataProcessRegion#Region\n   */\n  readonly region: string;\n}\n\n/**\n * Converts an object of type 'DataProcessRegion' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DataProcessRegion(\n  obj: DataProcessRegion | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Configuration information for each data store and its mapping to MongoDB Cloud databases.\n *\n * @schema Storage\n */\nexport interface Storage {\n  /**\n   * Array that contains the queryable databases and collections for this data lake.\n   *\n   * @schema Storage#Databases\n   */\n  readonly databases?: Database[];\n\n  /**\n   * Array that contains the data stores for the data lake.\n   *\n   * @schema Storage#Stores\n   */\n  readonly stores?: Store[];\n}\n\n/**\n * Converts an object of type 'Storage' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Storage(\n  obj: Storage | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Databases: obj.databases?.map((y) => toJson_Database(y)),\n    Stores: obj.stores?.map((y) => toJson_Store(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Database\n */\nexport interface Database {\n  /**\n   * Array of collections and data sources that map to a stores data store.\n   *\n   * @schema Database#Collections\n   */\n  readonly collections?: Collection[];\n\n  /**\n   * Maximum number of wildcard collections in the database. This only applies to S3 data sources.\n   *\n   * @schema Database#MaxWildcardCollections\n   */\n  readonly maxWildcardCollections?: string;\n\n  /**\n   * Human-readable label that identifies the database to which the data lake maps data.\n   *\n   * @schema Database#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Array of aggregation pipelines that apply to the collection. This only applies to S3 data sources.\n   *\n   * @schema Database#Views\n   */\n  readonly views?: View[];\n}\n\n/**\n * Converts an object of type 'Database' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Database(\n  obj: Database | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collections: obj.collections?.map((y) => toJson_Collection(y)),\n    MaxWildcardCollections: obj.maxWildcardCollections,\n    Name: obj.name,\n    Views: obj.views?.map((y) => toJson_View(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Array that contains the data stores for the data lake.\n *\n * @schema Store\n */\nexport interface Store {\n  /**\n   * Human-readable label that identifies the data store. The databases.[n].collections.[n].dataSources.[n].storeName field references this values as part of the mapping configuration. To use MongoDB Cloud as a data store, the data lake requires a serverless instance or an M10 or higher cluster.\n   *\n   * @schema Store#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Allowed values atlas, http, online_archive, s3 and DataLakeAzureBlobStore.\n   *\n   * @schema Store#Provider\n   */\n  readonly provider?: string;\n\n  /**\n   * Human-readable label of the MongoDB Cloud cluster on which the store is based.\n   *\n   * @schema Store#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project.Regex ^([a-f0-9]{24})$ .\n   *\n   * @schema Store#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * MongoDB Cloud cluster read preference, which describes how to route read requests to the cluster.\n   *\n   * @schema Store#ReadPreference\n   */\n  readonly readPreference?: ReadPreference;\n}\n\n/**\n * Converts an object of type 'Store' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Store(\n  obj: Store | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Provider: obj.provider,\n    ClusterName: obj.clusterName,\n    ProjectId: obj.projectId,\n    ReadPreference: toJson_ReadPreference(obj.readPreference),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Array of collections and data sources that map to a stores data store.\n *\n * @schema Collection\n */\nexport interface Collection {\n  /**\n   * Array that contains the data stores that map to a collection for this data lake.\n   *\n   * @schema Collection#DataSources\n   */\n  readonly dataSources?: DataSource[];\n\n  /**\n   * @schema Collection#Name\n   */\n  readonly name?: string;\n}\n\n/**\n * Converts an object of type 'Collection' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Collection(\n  obj: Collection | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DataSources: obj.dataSources?.map((y) => toJson_DataSource(y)),\n    Name: obj.name,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema View\n */\nexport interface View {\n  /**\n   * Human-readable label that identifies the view, which corresponds to an aggregation pipeline on a collection.\n   *\n   * @schema View#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Aggregation pipeline stages to apply to the source collection.\n   *\n   * @schema View#Pipeline\n   */\n  readonly pipeline?: string;\n\n  /**\n   * Human-readable label that identifies the source collection for the view.\n   *\n   * @schema View#Source\n   */\n  readonly source?: string;\n}\n\n/**\n * Converts an object of type 'View' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_View(\n  obj: View | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Pipeline: obj.pipeline,\n    Source: obj.source,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ReadPreference\n */\nexport interface ReadPreference {\n  /**\n   * \"primary\" \"primaryPreferred\" \"secondary\" \"secondaryPreferred\" \"nearest\"\n   * Read preference mode that specifies to which replica set member to route the read requests.\n   *\n   * @schema ReadPreference#Mode\n   */\n  readonly mode?: string;\n\n  /**\n   * Maximum replication lag, or staleness, for reads from secondaries.\n   *\n   * @schema ReadPreference#MaxStalenessSeconds\n   */\n  readonly maxStalenessSeconds?: string;\n\n  /**\n   * List that contains tag sets or tag specification documents. If specified, Atlas Data Lake routes read requests to replica set member or members that are associated with the specified tags.\n   *\n   * @schema ReadPreference#TagSets\n   */\n  readonly tagSets?: TagSet[][];\n}\n\n/**\n * Converts an object of type 'ReadPreference' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ReadPreference(\n  obj: ReadPreference | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Mode: obj.mode,\n    MaxStalenessSeconds: obj.maxStalenessSeconds,\n    TagSets: obj.tagSets?.map((y) => y?.map((x) => toJson_TagSet(x))),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DataSource\n */\nexport interface DataSource {\n  /**\n   * Flag that validates the scheme in the specified URLs. If true, allows insecure HTTP scheme, doesn't verify the server's certificate chain and hostname, and accepts any certificate with any hostname presented by the server. If false, allows secure HTTPS scheme only.\n   *\n   * @schema DataSource#AllowInsecure\n   */\n  readonly allowInsecure?: boolean;\n\n  /**\n   * Human-readable label that identifies the collection in the database. For creating a wildcard (*) collection, you must omit this parameter.\n   *\n   * @schema DataSource#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * Regex pattern to use for creating the wildcard (*) collection. To learn more about the regex syntax, see Go programming language.( https://pkg.go.dev/regexp ).\n   *\n   * @schema DataSource#CollectionRegex\n   */\n  readonly collectionRegex?: string;\n\n  /**\n   * Human-readable label that identifies the database, which contains the collection in the cluster. You must omit this parameter to generate wildcard (*) collections for dynamically generated databases.\n   *\n   * @schema DataSource#Database\n   */\n  readonly database?: string;\n\n  /**\n   * Regex pattern to use for creating the wildcard (*) collection. To learn more about the regex syntax, see Go programming language.( https://pkg.go.dev/regexp ).\n   *\n   * @schema DataSource#DatabaseRegex\n   */\n  readonly databaseRegex?: string;\n\n  /**\n   * File format that MongoDB Cloud uses if it encounters a file without a file extension while searching storeName.Enum: \".avro\" \".avro.bz2\" \".avro.gz\" \".bson\" \".bson.bz2\" \".bson.gz\" \".bsonx\" \".csv\" \".csv.bz2\" \".csv.gz\" \".json\" \".json.bz2\" \".json.gz\" \".orc\" \".parquet\" \".tsv\" \".tsv.bz2\" \".tsv.gz\"\n   *\n   * @schema DataSource#DefaultFormat\n   */\n  readonly defaultFormat?: string;\n\n  /**\n   * File path that controls how MongoDB Cloud searches for and parses files in the storeName before mapping them to a collection.Specify / to capture all files and folders from the prefix path.\n   *\n   * @schema DataSource#Path\n   */\n  readonly path?: string;\n\n  /**\n   * Name for the field that includes the provenance of the documents in the results. MongoDB Cloud returns different fields in the results for each supported provider.\n   *\n   * @schema DataSource#ProvenanceFieldName\n   */\n  readonly provenanceFieldName?: string;\n\n  /**\n   * Human-readable label that identifies the data store that MongoDB Cloud maps to the collection.\n   *\n   * @schema DataSource#StoreName\n   */\n  readonly storeName?: string;\n\n  /**\n   * URLs of the publicly accessible data files. You can't specify URLs that require authentication. Atlas Data Lake creates a partition for each URL. If empty or omitted, Data Lake uses the URLs from the store specified in the dataSources.storeName parameter.\n   *\n   * @schema DataSource#Urls\n   */\n  readonly urls?: string[];\n}\n\n/**\n * Converts an object of type 'DataSource' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DataSource(\n  obj: DataSource | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AllowInsecure: obj.allowInsecure,\n    Collection: obj.collection,\n    CollectionRegex: obj.collectionRegex,\n    Database: obj.database,\n    DatabaseRegex: obj.databaseRegex,\n    DefaultFormat: obj.defaultFormat,\n    Path: obj.path,\n    ProvenanceFieldName: obj.provenanceFieldName,\n    StoreName: obj.storeName,\n    Urls: obj.urls?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema TagSet\n */\nexport interface TagSet {\n  /**\n   * Human-readable label of the tag.\n   *\n   * @schema TagSet#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Human-readable label of the tag.\n   *\n   * @schema TagSet#Value\n   */\n  readonly value?: string;\n}\n\n/**\n * Converts an object of type 'TagSet' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_TagSet(\n  obj: TagSet | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Value: obj.value,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedDatabaseInstance`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedDatabaseInstance\n * @stability external\n */\nexport class CfnFederatedDatabaseInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedDatabaseInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedDatabaseInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.HostNames`\n   */\n  public readonly attrHostNames: string[];\n  /**\n   * Attribute `MongoDB::Atlas::FederatedDatabaseInstance.State`\n   */\n  public readonly attrState: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedDatabaseInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedDatabaseInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedDatabaseInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedDatabaseInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrHostNames = cdk.Token.asList(this.getAtt(\"HostNames\"));\n    this.attrState = cdk.Token.asString(this.getAtt(\"State\"));\n  }\n}\n"]}

@@ -85,6 +85,2 @@ import * as cdk from "aws-cdk-lib";

/**
* Attribute `MongoDB::Atlas::FederatedQueryLimit.DefaultLimit`
*/
readonly attrDefaultLimit: string;
/**
* Attribute `MongoDB::Atlas::FederatedQueryLimit.LastModifiedDate`

@@ -98,2 +94,6 @@ */

/**
* Attribute `MongoDB::Atlas::FederatedQueryLimit.DefaultLimit`
*/
readonly attrDefaultLimit: string;
/**
* Create a new `MongoDB::Atlas::FederatedQueryLimit`.

@@ -100,0 +100,0 @@ *

@@ -66,3 +66,2 @@ "use strict";

this.attrCurrentUsage = cdk.Token.asString(this.getAtt("CurrentUsage"));
this.attrDefaultLimit = cdk.Token.asString(this.getAtt("DefaultLimit"));
this.attrLastModifiedDate = cdk.Token.asString(this.getAtt("LastModifiedDate"));

@@ -75,3 +74,3 @@ this.attrMaximumLimit = cdk.Token.asString(this.getAtt("MaximumLimit"));

_a = JSII_RTTI_SYMBOL_1;
CfnFederatedQueryLimit[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedQueryLimit", version: "3.7.2" };
CfnFederatedQueryLimit[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedQueryLimit", version: "3.8.0" };
/**

@@ -81,2 +80,2 @@ * The CloudFormation resource type name for this resource class.

CfnFederatedQueryLimit.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::FederatedQueryLimit";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-query-limit/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAoDnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,kCAAkC,CAChD,GAA4C;IAE5C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,OAAO,EAAE,GAAG,CAAC,OAAO;KACrB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAnBD,gFAmBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,oCASX;AATD,WAAY,oCAAoC;IAC9C,2BAA2B;IAC3B,sFAA8C,CAAA;IAC9C,2BAA2B;IAC3B,sFAA8C,CAAA;IAC9C,4BAA4B;IAC5B,wFAAgD,CAAA;IAChD,6BAA6B;IAC7B,0FAAkD,CAAA;AACpD,CAAC,EATW,oCAAoC,GAApC,4CAAoC,KAApC,4CAAoC,QAS/C;AAED;;;;;GAKG;AACH,MAAa,sBAAuB,SAAQ,GAAG,CAAC,WAAW;IA6BzD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAkC;QAElC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,sBAAsB,CAAC,sBAAsB;YACnD,UAAU,EAAE,kCAAkC,CAAC,KAAK,CAAE;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAC5C,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAChC,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;IAC1E,CAAC;;AAvDH,wDAwDC;;;AAvDC;;GAEG;AACoB,6CAAsB,GAC3C,qCAAqC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Query limit for one federated database instance.\n *\n * @schema CfnFederatedQueryLimitProps\n */\nexport interface CfnFederatedQueryLimitProps {\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnFederatedQueryLimitProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the data federated database instance to which the query limit applies.\n   *\n   * @schema CfnFederatedQueryLimitProps#TenantName\n   */\n  readonly tenantName: string;\n\n  /**\n   * Human-readable label that identifies this data federation instance limit.\n   *\n   * @schema CfnFederatedQueryLimitProps#LimitName\n   */\n  readonly limitName: CfnFederatedQueryLimitPropsLimitName;\n\n  /**\n   * Only used for Data Federation limits. Action to take when the usage limit is exceeded. If limit span is set to QUERY, this is ignored because MongoDB Cloud stops the query when it exceeds the usage limit. \"enum\" : [ \"BLOCK\", \"BLOCK_AND_KILL\" ]\n   *\n   * @schema CfnFederatedQueryLimitProps#OverrunPolicy\n   */\n  readonly overrunPolicy?: string;\n\n  /**\n   * Amount to set the limit to.\n   *\n   * @schema CfnFederatedQueryLimitProps#Value\n   */\n  readonly value: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnFederatedQueryLimitProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnFederatedQueryLimitProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedQueryLimitProps(\n  obj: CfnFederatedQueryLimitProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    TenantName: obj.tenantName,\n    LimitName: obj.limitName,\n    OverrunPolicy: obj.overrunPolicy,\n    Value: obj.value,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies this data federation instance limit.\n *\n * @schema CfnFederatedQueryLimitPropsLimitName\n */\nexport enum CfnFederatedQueryLimitPropsLimitName {\n  /** bytesProcessed.query */\n  BYTES_PROCESSED_QUERY = \"bytesProcessed.query\",\n  /** bytesProcessed.daily */\n  BYTES_PROCESSED_DAILY = \"bytesProcessed.daily\",\n  /** bytesProcessed.weekly */\n  BYTES_PROCESSED_WEEKLY = \"bytesProcessed.weekly\",\n  /** bytesProcessed.monthly */\n  BYTES_PROCESSED_MONTHLY = \"bytesProcessed.monthly\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedQueryLimit`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedQueryLimit\n * @stability external\n */\nexport class CfnFederatedQueryLimit extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedQueryLimit\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedQueryLimitProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.CurrentUsage`\n   */\n  public readonly attrCurrentUsage: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.DefaultLimit`\n   */\n  public readonly attrDefaultLimit: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.LastModifiedDate`\n   */\n  public readonly attrLastModifiedDate: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.MaximumLimit`\n   */\n  public readonly attrMaximumLimit: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedQueryLimit`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedQueryLimitProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedQueryLimit.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedQueryLimitProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrCurrentUsage = cdk.Token.asString(this.getAtt(\"CurrentUsage\"));\n    this.attrDefaultLimit = cdk.Token.asString(this.getAtt(\"DefaultLimit\"));\n    this.attrLastModifiedDate = cdk.Token.asString(\n      this.getAtt(\"LastModifiedDate\")\n    );\n    this.attrMaximumLimit = cdk.Token.asString(this.getAtt(\"MaximumLimit\"));\n    this.attrDefaultLimit = cdk.Token.asString(this.getAtt(\"DefaultLimit\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-query-limit/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAoDnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,kCAAkC,CAChD,GAA4C;IAE5C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,OAAO,EAAE,GAAG,CAAC,OAAO;KACrB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAnBD,gFAmBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,oCASX;AATD,WAAY,oCAAoC;IAC9C,2BAA2B;IAC3B,sFAA8C,CAAA;IAC9C,2BAA2B;IAC3B,sFAA8C,CAAA;IAC9C,4BAA4B;IAC5B,wFAAgD,CAAA;IAChD,6BAA6B;IAC7B,0FAAkD,CAAA;AACpD,CAAC,EATW,oCAAoC,GAApC,4CAAoC,KAApC,4CAAoC,QAS/C;AAED;;;;;GAKG;AACH,MAAa,sBAAuB,SAAQ,GAAG,CAAC,WAAW;IA6BzD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAkC;QAElC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,sBAAsB,CAAC,sBAAsB;YACnD,UAAU,EAAE,kCAAkC,CAAC,KAAK,CAAE;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAC5C,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAChC,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;IAC1E,CAAC;;AAtDH,wDAuDC;;;AAtDC;;GAEG;AACoB,6CAAsB,GAC3C,qCAAqC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Query limit for one federated database instance.\n *\n * @schema CfnFederatedQueryLimitProps\n */\nexport interface CfnFederatedQueryLimitProps {\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnFederatedQueryLimitProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the data federated database instance to which the query limit applies.\n   *\n   * @schema CfnFederatedQueryLimitProps#TenantName\n   */\n  readonly tenantName: string;\n\n  /**\n   * Human-readable label that identifies this data federation instance limit.\n   *\n   * @schema CfnFederatedQueryLimitProps#LimitName\n   */\n  readonly limitName: CfnFederatedQueryLimitPropsLimitName;\n\n  /**\n   * Only used for Data Federation limits. Action to take when the usage limit is exceeded. If limit span is set to QUERY, this is ignored because MongoDB Cloud stops the query when it exceeds the usage limit. \"enum\" : [ \"BLOCK\", \"BLOCK_AND_KILL\" ]\n   *\n   * @schema CfnFederatedQueryLimitProps#OverrunPolicy\n   */\n  readonly overrunPolicy?: string;\n\n  /**\n   * Amount to set the limit to.\n   *\n   * @schema CfnFederatedQueryLimitProps#Value\n   */\n  readonly value: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnFederatedQueryLimitProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnFederatedQueryLimitProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedQueryLimitProps(\n  obj: CfnFederatedQueryLimitProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    TenantName: obj.tenantName,\n    LimitName: obj.limitName,\n    OverrunPolicy: obj.overrunPolicy,\n    Value: obj.value,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies this data federation instance limit.\n *\n * @schema CfnFederatedQueryLimitPropsLimitName\n */\nexport enum CfnFederatedQueryLimitPropsLimitName {\n  /** bytesProcessed.query */\n  BYTES_PROCESSED_QUERY = \"bytesProcessed.query\",\n  /** bytesProcessed.daily */\n  BYTES_PROCESSED_DAILY = \"bytesProcessed.daily\",\n  /** bytesProcessed.weekly */\n  BYTES_PROCESSED_WEEKLY = \"bytesProcessed.weekly\",\n  /** bytesProcessed.monthly */\n  BYTES_PROCESSED_MONTHLY = \"bytesProcessed.monthly\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedQueryLimit`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedQueryLimit\n * @stability external\n */\nexport class CfnFederatedQueryLimit extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedQueryLimit\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedQueryLimitProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.CurrentUsage`\n   */\n  public readonly attrCurrentUsage: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.LastModifiedDate`\n   */\n  public readonly attrLastModifiedDate: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.MaximumLimit`\n   */\n  public readonly attrMaximumLimit: string;\n  /**\n   * Attribute `MongoDB::Atlas::FederatedQueryLimit.DefaultLimit`\n   */\n  public readonly attrDefaultLimit: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedQueryLimit`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedQueryLimitProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedQueryLimit.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedQueryLimitProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrCurrentUsage = cdk.Token.asString(this.getAtt(\"CurrentUsage\"));\n    this.attrLastModifiedDate = cdk.Token.asString(\n      this.getAtt(\"LastModifiedDate\")\n    );\n    this.attrMaximumLimit = cdk.Token.asString(this.getAtt(\"MaximumLimit\"));\n    this.attrDefaultLimit = cdk.Token.asString(this.getAtt(\"DefaultLimit\"));\n  }\n}\n"]}

@@ -38,3 +38,3 @@ import * as cdk from "aws-cdk-lib";

*/
readonly roleAssignments: RoleAssignment[];
readonly roleAssignments?: RoleAssignment[];
}

@@ -41,0 +41,0 @@ /**

@@ -70,3 +70,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnFederatedSettingsOrgRoleMapping[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedSettingsOrgRoleMapping", version: "3.7.2" };
CfnFederatedSettingsOrgRoleMapping[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnFederatedSettingsOrgRoleMapping", version: "3.8.0" };
/**

@@ -76,2 +76,2 @@ * The CloudFormation resource type name for this resource class.

CfnFederatedSettingsOrgRoleMapping.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::FederatedSettingsOrgRoleMapping";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-settings-org-role-mapping/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA6CnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,8CAA8C,CAC5D,GAAwD;IAExD,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,iBAAiB,EAAE,GAAG,CAAC,iBAAiB;QACxC,oBAAoB,EAAE,GAAG,CAAC,oBAAoB;QAC9C,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,eAAe,EAAE,GAAG,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;KAC3E,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,wGAkBC;AA+BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,qBAAqB,CACnC,GAA+B;IAE/B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,IAAI,EAAE,GAAG,CAAC,IAAI;KACf,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,sDAgBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,kCAAmC,SAAQ,GAAG,CAAC,WAAW;IAiBrE;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA8C;QAE9C,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,kCAAkC,CAAC,sBAAsB;YAC/D,UAAU,EAAE,8CAA8C,CAAC,KAAK,CAAE;SACnE,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;;AArCH,gFAsCC;;;AArCC;;GAEG;AACoB,yDAAsB,GAC3C,iDAAiD,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes federation-related features such as role mappings and connected organization configurations.\n *\n * @schema CfnFederatedSettingsOrgRoleMappingProps\n */\nexport interface CfnFederatedSettingsOrgRoleMappingProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique human-readable label that identifies the identity provider group to whichthis role mapping applies.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#ExternalGroupName\n   */\n  readonly externalGroupName: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your federation.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#FederationSettingsId\n   */\n  readonly federationSettingsId: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#OrgId\n   */\n  readonly orgId: string;\n\n  /**\n   * Atlas roles and the unique identifiers of the groups and organizations associated with each role.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#RoleAssignments\n   */\n  readonly roleAssignments: RoleAssignment[];\n}\n\n/**\n * Converts an object of type 'CfnFederatedSettingsOrgRoleMappingProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedSettingsOrgRoleMappingProps(\n  obj: CfnFederatedSettingsOrgRoleMappingProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ExternalGroupName: obj.externalGroupName,\n    FederationSettingsId: obj.federationSettingsId,\n    OrgId: obj.orgId,\n    RoleAssignments: obj.roleAssignments?.map((y) => toJson_RoleAssignment(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema RoleAssignment\n */\nexport interface RoleAssignment {\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to a unique 24-hexadecimal string that identifies the custom zone.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema RoleAssignment#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to a unique 24-hexadecimal string that identifies the custom zone.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema RoleAssignment#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * @schema RoleAssignment#Role\n   */\n  readonly role?: string;\n}\n\n/**\n * Converts an object of type 'RoleAssignment' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_RoleAssignment(\n  obj: RoleAssignment | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    OrgId: obj.orgId,\n    Role: obj.role,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedSettingsOrgRoleMapping`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedSettingsOrgRoleMapping\n * @stability external\n */\nexport class CfnFederatedSettingsOrgRoleMapping extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedSettingsOrgRoleMapping\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedSettingsOrgRoleMappingProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedSettingsOrgRoleMapping.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedSettingsOrgRoleMapping`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedSettingsOrgRoleMappingProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedSettingsOrgRoleMapping.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedSettingsOrgRoleMappingProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/federated-settings-org-role-mapping/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA6CnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,8CAA8C,CAC5D,GAAwD;IAExD,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,iBAAiB,EAAE,GAAG,CAAC,iBAAiB;QACxC,oBAAoB,EAAE,GAAG,CAAC,oBAAoB;QAC9C,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,eAAe,EAAE,GAAG,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;KAC3E,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,wGAkBC;AA+BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,qBAAqB,CACnC,GAA+B;IAE/B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,IAAI,EAAE,GAAG,CAAC,IAAI;KACf,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,sDAgBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,kCAAmC,SAAQ,GAAG,CAAC,WAAW;IAiBrE;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA8C;QAE9C,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,kCAAkC,CAAC,sBAAsB;YAC/D,UAAU,EAAE,8CAA8C,CAAC,KAAK,CAAE;SACnE,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;;AArCH,gFAsCC;;;AArCC;;GAEG;AACoB,yDAAsB,GAC3C,iDAAiD,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes federation-related features such as role mappings and connected organization configurations.\n *\n * @schema CfnFederatedSettingsOrgRoleMappingProps\n */\nexport interface CfnFederatedSettingsOrgRoleMappingProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique human-readable label that identifies the identity provider group to whichthis role mapping applies.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#ExternalGroupName\n   */\n  readonly externalGroupName: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your federation.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#FederationSettingsId\n   */\n  readonly federationSettingsId: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#OrgId\n   */\n  readonly orgId: string;\n\n  /**\n   * Atlas roles and the unique identifiers of the groups and organizations associated with each role.\n   *\n   * @schema CfnFederatedSettingsOrgRoleMappingProps#RoleAssignments\n   */\n  readonly roleAssignments?: RoleAssignment[];\n}\n\n/**\n * Converts an object of type 'CfnFederatedSettingsOrgRoleMappingProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnFederatedSettingsOrgRoleMappingProps(\n  obj: CfnFederatedSettingsOrgRoleMappingProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ExternalGroupName: obj.externalGroupName,\n    FederationSettingsId: obj.federationSettingsId,\n    OrgId: obj.orgId,\n    RoleAssignments: obj.roleAssignments?.map((y) => toJson_RoleAssignment(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema RoleAssignment\n */\nexport interface RoleAssignment {\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to a unique 24-hexadecimal string that identifies the custom zone.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema RoleAssignment#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to a unique 24-hexadecimal string that identifies the custom zone.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema RoleAssignment#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * @schema RoleAssignment#Role\n   */\n  readonly role?: string;\n}\n\n/**\n * Converts an object of type 'RoleAssignment' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_RoleAssignment(\n  obj: RoleAssignment | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    OrgId: obj.orgId,\n    Role: obj.role,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::FederatedSettingsOrgRoleMapping`\n *\n * @cloudformationResource MongoDB::Atlas::FederatedSettingsOrgRoleMapping\n * @stability external\n */\nexport class CfnFederatedSettingsOrgRoleMapping extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::FederatedSettingsOrgRoleMapping\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnFederatedSettingsOrgRoleMappingProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::FederatedSettingsOrgRoleMapping.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::FederatedSettingsOrgRoleMapping`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnFederatedSettingsOrgRoleMappingProps\n  ) {\n    super(scope, id, {\n      type: CfnFederatedSettingsOrgRoleMapping.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnFederatedSettingsOrgRoleMappingProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}

@@ -20,3 +20,3 @@ import * as cdk from "aws-cdk-lib";

*/
readonly projectId: string;
readonly projectId?: string;
/**

@@ -27,3 +27,3 @@ * The name of the Atlas cluster that contains the snapshots you want to retrieve.

*/
readonly clusterName: string;
readonly clusterName?: string;
/**

@@ -38,8 +38,2 @@ * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.

/**
* Flag that indicates whether all custom zone mapping to be deleted during delete.
*
* @schema CfnGlobalClusterConfigProps#RemoveAllZoneMapping
*/
readonly removeAllZoneMapping?: boolean;
/**
* List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.

@@ -133,2 +127,6 @@ *

/**
* Attribute `MongoDB::Atlas::GlobalClusterConfig.RemoveAllZoneMapping`
*/
readonly attrRemoveAllZoneMapping: cdk.IResolvable;
/**
* Create a new `MongoDB::Atlas::GlobalClusterConfig`.

@@ -135,0 +133,0 @@ *

@@ -21,3 +21,2 @@ "use strict";

ManagedNamespaces: obj.managedNamespaces?.map((y) => toJson_ManagedNamespace(y)),
RemoveAllZoneMapping: obj.removeAllZoneMapping,
CustomZoneMappings: obj.customZoneMappings?.map((y) => toJson_ZoneMapping(y)),

@@ -85,2 +84,3 @@ };

this.props = props;
this.attrRemoveAllZoneMapping = this.getAtt("RemoveAllZoneMapping");
}

@@ -90,3 +90,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnGlobalClusterConfig[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnGlobalClusterConfig", version: "3.7.2" };
CfnGlobalClusterConfig[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnGlobalClusterConfig", version: "3.8.0" };
/**

@@ -96,2 +96,2 @@ * The CloudFormation resource type name for this resource class.

CfnGlobalClusterConfig.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::GlobalClusterConfig";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/global-cluster-config/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, and removes Global Cluster managed namespaces and custom zone mappings. This resource can only be used with Atlas-managed clusters, see doc for `GlobalClusterSelfManagedSharding` attribute in `Mongodb::Atlas::Cluster` resource for more info.\n *\n * @schema CfnGlobalClusterConfigProps\n */\nexport interface CfnGlobalClusterConfigProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnGlobalClusterConfigProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * The unique identifier of the project for the Atlas cluster.\n   *\n   * @schema CfnGlobalClusterConfigProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * The name of the Atlas cluster that contains the snapshots you want to retrieve.\n   *\n   * @schema CfnGlobalClusterConfigProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema CfnGlobalClusterConfigProps#ManagedNamespaces\n   */\n  readonly managedNamespaces?: ManagedNamespace[];\n\n  /**\n   * Flag that indicates whether all custom zone mapping to be deleted during delete.\n   *\n   * @schema CfnGlobalClusterConfigProps#RemoveAllZoneMapping\n   */\n  readonly removeAllZoneMapping?: boolean;\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema CfnGlobalClusterConfigProps#CustomZoneMappings\n   */\n  readonly customZoneMappings?: ZoneMapping[];\n}\n\n/**\n * Converts an object of type 'CfnGlobalClusterConfigProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnGlobalClusterConfigProps(\n  obj: CfnGlobalClusterConfigProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n    ClusterName: obj.clusterName,\n    ManagedNamespaces: obj.managedNamespaces?.map((y) =>\n      toJson_ManagedNamespace(y)\n    ),\n    RemoveAllZoneMapping: obj.removeAllZoneMapping,\n    CustomZoneMappings: obj.customZoneMappings?.map((y) =>\n      toJson_ZoneMapping(y)\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema managedNamespace\n */\nexport interface ManagedNamespace {\n  /**\n   * Human-readable label of the collection to manage for this Global Cluster.\n   *\n   * @schema managedNamespace#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * Database parameter used to divide the *collection* into shards. Global clusters require a compound shard key. This compound shard key combines the location parameter and the user-selected custom key.\n   *\n   * @schema managedNamespace#CustomShardKey\n   */\n  readonly customShardKey?: string;\n\n  /**\n   * Human-readable label of the database to manage for this Global Cluster.\n   *\n   * @schema managedNamespace#Db\n   */\n  readonly db?: string;\n\n  /**\n   * Flag that indicates whether someone hashed the custom shard key for the specified collection. If you set this value to `false`, MongoDB Cloud uses ranged sharding.\n   *\n   * @schema managedNamespace#IsCustomShardKeyHashed\n   */\n  readonly isCustomShardKeyHashed?: boolean;\n\n  /**\n   * Flag that indicates whether someone [hashed](https://www.mongodb.com/docs/manual/reference/method/sh.shardCollection/#hashed-shard-keys) the custom shard key. If this parameter returns `false`, this cluster uses [ranged sharding](https://www.mongodb.com/docs/manual/core/ranged-sharding/).\n   *\n   * @schema managedNamespace#IsShardKeyUnique\n   */\n  readonly isShardKeyUnique?: boolean;\n}\n\n/**\n * Converts an object of type 'ManagedNamespace' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ManagedNamespace(\n  obj: ManagedNamespace | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collection: obj.collection,\n    CustomShardKey: obj.customShardKey,\n    Db: obj.db,\n    IsCustomShardKeyHashed: obj.isCustomShardKeyHashed,\n    IsShardKeyUnique: obj.isShardKeyUnique,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema zoneMapping\n */\nexport interface ZoneMapping {\n  /**\n   * Code that represents a location that maps to a zone in your global cluster. MongoDB Cloud represents this location with a ISO 3166-2 location and subdivision codes when possible.\n   *\n   * @schema zoneMapping#Location\n   */\n  readonly location?: string;\n\n  /**\n   * Human-readable label that identifies the zone in your global cluster. This zone maps to a location code.\n   *\n   * @schema zoneMapping#Zone\n   */\n  readonly zone?: string;\n}\n\n/**\n * Converts an object of type 'ZoneMapping' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ZoneMapping(\n  obj: ZoneMapping | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Location: obj.location,\n    Zone: obj.zone,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::GlobalClusterConfig`\n *\n * @cloudformationResource MongoDB::Atlas::GlobalClusterConfig\n * @stability external\n */\nexport class CfnGlobalClusterConfig extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::GlobalClusterConfig\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnGlobalClusterConfigProps;\n\n  /**\n   * Create a new `MongoDB::Atlas::GlobalClusterConfig`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnGlobalClusterConfigProps\n  ) {\n    super(scope, id, {\n      type: CfnGlobalClusterConfig.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnGlobalClusterConfigProps(props)!,\n    });\n\n    this.props = props;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/global-cluster-config/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, and removes Global Cluster managed namespaces and custom zone mappings. This resource can only be used with Atlas-managed clusters, see doc for `GlobalClusterSelfManagedSharding` attribute in `Mongodb::Atlas::Cluster` resource for more info.\n *\n * @schema CfnGlobalClusterConfigProps\n */\nexport interface CfnGlobalClusterConfigProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnGlobalClusterConfigProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * The unique identifier of the project for the Atlas cluster.\n   *\n   * @schema CfnGlobalClusterConfigProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * The name of the Atlas cluster that contains the snapshots you want to retrieve.\n   *\n   * @schema CfnGlobalClusterConfigProps#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema CfnGlobalClusterConfigProps#ManagedNamespaces\n   */\n  readonly managedNamespaces?: ManagedNamespace[];\n\n  /**\n   * List that contains comma-separated key value pairs to map zones to geographic regions. These pairs map an ISO 3166-1a2 location code, with an ISO 3166-2 subdivision code when possible, to the human-readable label for the desired custom zone. MongoDB Cloud maps the ISO 3166-1a2 code to the nearest geographical zone by default. Include this parameter to override the default mappings.\n   *\n   * This parameter returns an empty object if no custom zones exist.\n   *\n   * @schema CfnGlobalClusterConfigProps#CustomZoneMappings\n   */\n  readonly customZoneMappings?: ZoneMapping[];\n}\n\n/**\n * Converts an object of type 'CfnGlobalClusterConfigProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnGlobalClusterConfigProps(\n  obj: CfnGlobalClusterConfigProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n    ClusterName: obj.clusterName,\n    ManagedNamespaces: obj.managedNamespaces?.map((y) =>\n      toJson_ManagedNamespace(y)\n    ),\n    CustomZoneMappings: obj.customZoneMappings?.map((y) =>\n      toJson_ZoneMapping(y)\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema managedNamespace\n */\nexport interface ManagedNamespace {\n  /**\n   * Human-readable label of the collection to manage for this Global Cluster.\n   *\n   * @schema managedNamespace#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * Database parameter used to divide the *collection* into shards. Global clusters require a compound shard key. This compound shard key combines the location parameter and the user-selected custom key.\n   *\n   * @schema managedNamespace#CustomShardKey\n   */\n  readonly customShardKey?: string;\n\n  /**\n   * Human-readable label of the database to manage for this Global Cluster.\n   *\n   * @schema managedNamespace#Db\n   */\n  readonly db?: string;\n\n  /**\n   * Flag that indicates whether someone hashed the custom shard key for the specified collection. If you set this value to `false`, MongoDB Cloud uses ranged sharding.\n   *\n   * @schema managedNamespace#IsCustomShardKeyHashed\n   */\n  readonly isCustomShardKeyHashed?: boolean;\n\n  /**\n   * Flag that indicates whether someone [hashed](https://www.mongodb.com/docs/manual/reference/method/sh.shardCollection/#hashed-shard-keys) the custom shard key. If this parameter returns `false`, this cluster uses [ranged sharding](https://www.mongodb.com/docs/manual/core/ranged-sharding/).\n   *\n   * @schema managedNamespace#IsShardKeyUnique\n   */\n  readonly isShardKeyUnique?: boolean;\n}\n\n/**\n * Converts an object of type 'ManagedNamespace' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ManagedNamespace(\n  obj: ManagedNamespace | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collection: obj.collection,\n    CustomShardKey: obj.customShardKey,\n    Db: obj.db,\n    IsCustomShardKeyHashed: obj.isCustomShardKeyHashed,\n    IsShardKeyUnique: obj.isShardKeyUnique,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema zoneMapping\n */\nexport interface ZoneMapping {\n  /**\n   * Code that represents a location that maps to a zone in your global cluster. MongoDB Cloud represents this location with a ISO 3166-2 location and subdivision codes when possible.\n   *\n   * @schema zoneMapping#Location\n   */\n  readonly location?: string;\n\n  /**\n   * Human-readable label that identifies the zone in your global cluster. This zone maps to a location code.\n   *\n   * @schema zoneMapping#Zone\n   */\n  readonly zone?: string;\n}\n\n/**\n * Converts an object of type 'ZoneMapping' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ZoneMapping(\n  obj: ZoneMapping | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Location: obj.location,\n    Zone: obj.zone,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::GlobalClusterConfig`\n *\n * @cloudformationResource MongoDB::Atlas::GlobalClusterConfig\n * @stability external\n */\nexport class CfnGlobalClusterConfig extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::GlobalClusterConfig\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnGlobalClusterConfigProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::GlobalClusterConfig.RemoveAllZoneMapping`\n   */\n  public readonly attrRemoveAllZoneMapping: cdk.IResolvable;\n\n  /**\n   * Create a new `MongoDB::Atlas::GlobalClusterConfig`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnGlobalClusterConfigProps\n  ) {\n    super(scope, id, {\n      type: CfnGlobalClusterConfig.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnGlobalClusterConfigProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrRemoveAllZoneMapping = this.getAtt(\"RemoveAllZoneMapping\");\n  }\n}\n"]}

@@ -76,3 +76,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnLdapConfiguration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnLdapConfiguration", version: "3.7.2" };
CfnLdapConfiguration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnLdapConfiguration", version: "3.8.0" };
/**

@@ -79,0 +79,0 @@ * The CloudFormation resource type name for this resource class.

@@ -74,3 +74,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnLdapVerify[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnLdapVerify", version: "3.7.2" };
CfnLdapVerify[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnLdapVerify", version: "3.8.0" };
/**

@@ -77,0 +77,0 @@ * The CloudFormation resource type name for this resource class.

@@ -53,3 +53,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnMaintenanceWindow[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnMaintenanceWindow", version: "3.7.2" };
CfnMaintenanceWindow[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnMaintenanceWindow", version: "3.8.0" };
/**

@@ -56,0 +56,0 @@ * The CloudFormation resource type name for this resource class.

@@ -54,3 +54,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnNetworkContainer[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnNetworkContainer", version: "3.7.2" };
CfnNetworkContainer[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnNetworkContainer", version: "3.8.0" };
/**

@@ -57,0 +57,0 @@ * The CloudFormation resource type name for this resource class.

@@ -58,3 +58,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnNetworkPeering[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnNetworkPeering", version: "3.7.2" };
CfnNetworkPeering[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnNetworkPeering", version: "3.8.0" };
/**

@@ -61,0 +61,0 @@ * The CloudFormation resource type name for this resource class.

@@ -110,5 +110,3 @@ import * as cdk from "aws-cdk-lib";

/**
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query.
* **DATE** selects documents to archive based on a date.
* **CUSTOM** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **CUSTOM** when `"collectionType": "TIMESERIES"`.
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query. **DATE** selects documents to archive based on a date. (if DATE is selected, the PartitionFields.FieldName must be completed with the Criteria.DateField value)**CUSTOM** selects documents to archive based on a custom JSON query (When selecting this option, the Query property must be inputted). MongoDB Cloud doesn't support **CUSTOM** when `collectionType: TIMESERIES`.
*

@@ -158,8 +156,2 @@ * @schema CriteriaView#Type

/**
* Data type of the parameter that that MongoDB Cloud uses to partition data. Partition parameters of type [UUID](http://bsonspec.org/spec.html) must be of binary subtype 4. MongoDB Cloud skips partition parameters of type UUID with subtype 3.
*
* @schema PartitionFieldView#FieldType
*/
readonly fieldType?: PartitionFieldViewFieldType;
/**
* Sequence in which MongoDB Cloud slices the collection data to create partitions. The resource expresses this sequence starting with zero. The value of the **criteria.dateField** parameter defaults as the first item in the partition sequence.

@@ -225,5 +217,3 @@ *

/**
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query.
* **DATE** selects documents to archive based on a date.
* **CUSTOM** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **CUSTOM** when `"collectionType": "TIMESERIES"`.
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query. **DATE** selects documents to archive based on a date. (if DATE is selected, the PartitionFields.FieldName must be completed with the Criteria.DateField value)**CUSTOM** selects documents to archive based on a custom JSON query (When selecting this option, the Query property must be inputted). MongoDB Cloud doesn't support **CUSTOM** when `collectionType: TIMESERIES`.
*

@@ -254,21 +244,2 @@ * @schema CriteriaViewType

/**
* Data type of the parameter that that MongoDB Cloud uses to partition data. Partition parameters of type [UUID](http://bsonspec.org/spec.html) must be of binary subtype 4. MongoDB Cloud skips partition parameters of type UUID with subtype 3.
*
* @schema PartitionFieldViewFieldType
*/
export declare enum PartitionFieldViewFieldType {
/** date */
DATE = "date",
/** int */
INT = "int",
/** long */
LONG = "long",
/** objectId */
OBJECT_ID = "objectId",
/** string */
STRING = "string",
/** uuid */
UUID = "uuid"
}
/**
* @schema ScheduleViewType

@@ -275,0 +246,0 @@ */

"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnOnlineArchive = exports.ScheduleViewType = exports.PartitionFieldViewFieldType = exports.CriteriaViewDateFormat = exports.CriteriaViewType = exports.toJson_ScheduleView = exports.toJson_PartitionFieldView = exports.toJson_CriteriaView = exports.CfnOnlineArchivePropsCollectionType = exports.toJson_CfnOnlineArchiveProps = void 0;
exports.CfnOnlineArchive = exports.ScheduleViewType = exports.CriteriaViewDateFormat = exports.CriteriaViewType = exports.toJson_ScheduleView = exports.toJson_PartitionFieldView = exports.toJson_CriteriaView = exports.CfnOnlineArchivePropsCollectionType = exports.toJson_CfnOnlineArchiveProps = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");

@@ -78,3 +78,2 @@ // Generated by cdk-import

FieldName: obj.fieldName,
FieldType: obj.fieldType,
Order: obj.order,

@@ -109,5 +108,3 @@ };

/**
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query.
* **DATE** selects documents to archive based on a date.
* **CUSTOM** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **CUSTOM** when `"collectionType": "TIMESERIES"`.
* Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query. **DATE** selects documents to archive based on a date. (if DATE is selected, the PartitionFields.FieldName must be completed with the Criteria.DateField value)**CUSTOM** selects documents to archive based on a custom JSON query (When selecting this option, the Query property must be inputted). MongoDB Cloud doesn't support **CUSTOM** when `collectionType: TIMESERIES`.
*

@@ -140,22 +137,2 @@ * @schema CriteriaViewType

/**
* Data type of the parameter that that MongoDB Cloud uses to partition data. Partition parameters of type [UUID](http://bsonspec.org/spec.html) must be of binary subtype 4. MongoDB Cloud skips partition parameters of type UUID with subtype 3.
*
* @schema PartitionFieldViewFieldType
*/
var PartitionFieldViewFieldType;
(function (PartitionFieldViewFieldType) {
/** date */
PartitionFieldViewFieldType["DATE"] = "date";
/** int */
PartitionFieldViewFieldType["INT"] = "int";
/** long */
PartitionFieldViewFieldType["LONG"] = "long";
/** objectId */
PartitionFieldViewFieldType["OBJECT_ID"] = "objectId";
/** string */
PartitionFieldViewFieldType["STRING"] = "string";
/** uuid */
PartitionFieldViewFieldType["UUID"] = "uuid";
})(PartitionFieldViewFieldType = exports.PartitionFieldViewFieldType || (exports.PartitionFieldViewFieldType = {}));
/**
* @schema ScheduleViewType

@@ -201,3 +178,3 @@ */

_a = JSII_RTTI_SYMBOL_1;
CfnOnlineArchive[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOnlineArchive", version: "3.7.2" };
CfnOnlineArchive[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOnlineArchive", version: "3.8.0" };
/**

@@ -207,2 +184,2 @@ * The CloudFormation resource type name for this resource class.

CfnOnlineArchive.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::OnlineArchive";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/online-archive/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, or removes an online archive.\n *\n * @schema CfnOnlineArchiveProps\n */\nexport interface CfnOnlineArchiveProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnOnlineArchiveProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Human-readable label that identifies the cluster that contains the collection from which you want to remove an online archive.\n   *\n   * @schema CfnOnlineArchiveProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * Human-readable label that identifies the collection for which you created the online archive.\n   *\n   * @schema CfnOnlineArchiveProps#CollName\n   */\n  readonly collName?: string;\n\n  /**\n   * Classification of MongoDB database collection that you want to return.\n   *\n   * If you set this parameter to `TIMESERIES`, set `\"criteria.type\" : \"date\"` and `\"criteria.dateFormat\" : \"ISODATE\"`.\n   *\n   * @schema CfnOnlineArchiveProps#CollectionType\n   */\n  readonly collectionType?: CfnOnlineArchivePropsCollectionType;\n\n  /**\n   * Rules by which MongoDB MongoDB Cloud archives data.\n   *\n   * Use the **criteria.type** field to choose how MongoDB Cloud selects data to archive. Choose data using the age of the data or a MongoDB query.\n   * **\"criteria.type\": \"DATE\"** selects documents to archive based on a date.\n   * **\"criteria.type\": \"CUSTOM\"** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **\"criteria.type\": \"CUSTOM\"** when **\"collectionType\": \"TIMESERIES\"**.\n   *\n   * @schema CfnOnlineArchiveProps#Criteria\n   */\n  readonly criteria: CriteriaView;\n\n  /**\n   * Human-readable label of the database that contains the collection that contains the online archive.\n   *\n   * @schema CfnOnlineArchiveProps#DbName\n   */\n  readonly dbName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnOnlineArchiveProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnOnlineArchiveProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnOnlineArchiveProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnOnlineArchiveProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * List that contains document parameters to use to logically divide data within a collection. Partitions provide a coarse level of filtering of the underlying collection data. To divide your data, specify up to two parameters that you frequently query. Any queries that don't use these parameters result in a full collection scan of all archived documents. This takes more time and increase your costs.\n   *\n   * @schema CfnOnlineArchiveProps#PartitionFields\n   */\n  readonly partitionFields?: PartitionFieldView[];\n\n  /**\n   * Regular frequency and duration when archiving process occurs.\n   *\n   * @schema CfnOnlineArchiveProps#Schedule\n   */\n  readonly schedule?: ScheduleView;\n}\n\n/**\n * Converts an object of type 'CfnOnlineArchiveProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnOnlineArchiveProps(\n  obj: CfnOnlineArchiveProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ClusterName: obj.clusterName,\n    CollName: obj.collName,\n    CollectionType: obj.collectionType,\n    Criteria: toJson_CriteriaView(obj.criteria),\n    DbName: obj.dbName,\n    ProjectId: obj.projectId,\n    IncludeCount: obj.includeCount,\n    ItemsPerPage: obj.itemsPerPage,\n    PageNum: obj.pageNum,\n    PartitionFields: obj.partitionFields?.map((y) =>\n      toJson_PartitionFieldView(y)\n    ),\n    Schedule: toJson_ScheduleView(obj.schedule),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Classification of MongoDB database collection that you want to return.\n *\n * If you set this parameter to `TIMESERIES`, set `\"criteria.type\" : \"date\"` and `\"criteria.dateFormat\" : \"ISODATE\"`.\n *\n * @schema CfnOnlineArchivePropsCollectionType\n */\nexport enum CfnOnlineArchivePropsCollectionType {\n  /** STANDARD */\n  STANDARD = \"STANDARD\",\n  /** TIMESERIES */\n  TIMESERIES = \"TIMESERIES\",\n}\n\n/**\n * @schema CriteriaView\n */\nexport interface CriteriaView {\n  /**\n   * Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query.\n   * **DATE** selects documents to archive based on a date.\n   * **CUSTOM** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **CUSTOM** when `\"collectionType\": \"TIMESERIES\"`.\n   *\n   * @schema CriteriaView#Type\n   */\n  readonly type?: CriteriaViewType;\n\n  /**\n   * Indexed database parameter that stores the date that determines when data moves to the online archive. MongoDB Cloud archives the data when the current date exceeds the date in this database parameter plus the number of days specified through the expireAfterDays parameter. Set this parameter when you set \"criteria.type\" : \"DATE\".\n   *\n   * @schema CriteriaView#DateField\n   */\n  readonly dateField?: string;\n\n  /**\n   * Syntax used to write the date after which data moves to the online archive. Date can be expressed as ISO 8601 or Epoch timestamps. The Epoch timestamp can be expressed as nanoseconds, milliseconds, or seconds. Set this parameter when \"criteria.type\" : \"DATE\". You must set \"criteria.type\" : \"DATE\" if \"collectionType\": \"TIMESERIES\".\n   *\n   * @schema CriteriaView#DateFormat\n   */\n  readonly dateFormat?: CriteriaViewDateFormat;\n\n  /**\n   * Number of days after the value in the criteria.dateField when MongoDB Cloud archives data in the specified cluster. Set this parameter when you set \"criteria.type\" : \"DATE\".\n   *\n   * @schema CriteriaView#ExpireAfterDays\n   */\n  readonly expireAfterDays?: number;\n\n  /**\n   * MongoDB find query that selects documents to archive. The specified query follows the syntax of the db.collection.find(query) command. This query can't use the empty document ({}) to return all documents. Set this parameter when \"criteria.type\" : \"CUSTOM\".\n   *\n   * @schema CriteriaView#Query\n   */\n  readonly query?: string;\n}\n\n/**\n * Converts an object of type 'CriteriaView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CriteriaView(\n  obj: CriteriaView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Type: obj.type,\n    DateField: obj.dateField,\n    DateFormat: obj.dateFormat,\n    ExpireAfterDays: obj.expireAfterDays,\n    Query: obj.query,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema PartitionFieldView\n */\nexport interface PartitionFieldView {\n  /**\n   * Human-readable label that identifies the parameter that MongoDB Cloud uses to partition data. To specify a nested parameter, use the dot notation.\n   *\n   * @schema PartitionFieldView#FieldName\n   */\n  readonly fieldName?: string;\n\n  /**\n   * Data type of the parameter that that MongoDB Cloud uses to partition data. Partition parameters of type [UUID](http://bsonspec.org/spec.html) must be of binary subtype 4. MongoDB Cloud skips partition parameters of type UUID with subtype 3.\n   *\n   * @schema PartitionFieldView#FieldType\n   */\n  readonly fieldType?: PartitionFieldViewFieldType;\n\n  /**\n   * Sequence in which MongoDB Cloud slices the collection data to create partitions. The resource expresses this sequence starting with zero. The value of the **criteria.dateField** parameter defaults as the first item in the partition sequence.\n   *\n   * @schema PartitionFieldView#Order\n   */\n  readonly order?: number;\n}\n\n/**\n * Converts an object of type 'PartitionFieldView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_PartitionFieldView(\n  obj: PartitionFieldView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FieldName: obj.fieldName,\n    FieldType: obj.fieldType,\n    Order: obj.order,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScheduleView\n */\nexport interface ScheduleView {\n  /**\n   * @schema ScheduleView#Type\n   */\n  readonly type?: ScheduleViewType;\n\n  /**\n   * Hour of the day when the scheduled window to run one online archive ends.\n   *\n   * @schema ScheduleView#EndHour\n   */\n  readonly endHour?: number;\n\n  /**\n   * Minute of the hour when the scheduled window to run one online archive ends.\n   *\n   * @schema ScheduleView#EndMinute\n   */\n  readonly endMinute?: number;\n\n  /**\n   * Hour of the day when the when the scheduled window to run one online archive starts.\n   *\n   * @schema ScheduleView#StartHour\n   */\n  readonly startHour?: number;\n\n  /**\n   * Minute of the hour when the scheduled window to run one online archive starts.\n   *\n   * @schema ScheduleView#StartMinute\n   */\n  readonly startMinute?: number;\n\n  /**\n   * Day of the month when the scheduled archive starts.\n   *\n   * @schema ScheduleView#DayOfMonth\n   */\n  readonly dayOfMonth?: number;\n\n  /**\n   * Day of the month when the scheduled archive starts.\n   *\n   * @schema ScheduleView#DayOfWeek\n   */\n  readonly dayOfWeek?: number;\n}\n\n/**\n * Converts an object of type 'ScheduleView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScheduleView(\n  obj: ScheduleView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Type: obj.type,\n    EndHour: obj.endHour,\n    EndMinute: obj.endMinute,\n    StartHour: obj.startHour,\n    StartMinute: obj.startMinute,\n    DayOfMonth: obj.dayOfMonth,\n    DayOfWeek: obj.dayOfWeek,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query.\n * **DATE** selects documents to archive based on a date.\n * **CUSTOM** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **CUSTOM** when `\"collectionType\": \"TIMESERIES\"`.\n *\n * @schema CriteriaViewType\n */\nexport enum CriteriaViewType {\n  /** DATE */\n  DATE = \"DATE\",\n  /** CUSTOM */\n  CUSTOM = \"CUSTOM\",\n}\n\n/**\n * Syntax used to write the date after which data moves to the online archive. Date can be expressed as ISO 8601 or Epoch timestamps. The Epoch timestamp can be expressed as nanoseconds, milliseconds, or seconds. Set this parameter when \"criteria.type\" : \"DATE\". You must set \"criteria.type\" : \"DATE\" if \"collectionType\": \"TIMESERIES\".\n *\n * @schema CriteriaViewDateFormat\n */\nexport enum CriteriaViewDateFormat {\n  /** ISODATE */\n  ISODATE = \"ISODATE\",\n  /** EPOCH_SECONDS */\n  EPOCH_SECONDS = \"EPOCH_SECONDS\",\n  /** EPOCH_MILLIS */\n  EPOCH_MILLIS = \"EPOCH_MILLIS\",\n  /** EPOCH_NANOSECONDS */\n  EPOCH_NANOSECONDS = \"EPOCH_NANOSECONDS\",\n}\n\n/**\n * Data type of the parameter that that MongoDB Cloud uses to partition data. Partition parameters of type [UUID](http://bsonspec.org/spec.html) must be of binary subtype 4. MongoDB Cloud skips partition parameters of type UUID with subtype 3.\n *\n * @schema PartitionFieldViewFieldType\n */\nexport enum PartitionFieldViewFieldType {\n  /** date */\n  DATE = \"date\",\n  /** int */\n  INT = \"int\",\n  /** long */\n  LONG = \"long\",\n  /** objectId */\n  OBJECT_ID = \"objectId\",\n  /** string */\n  STRING = \"string\",\n  /** uuid */\n  UUID = \"uuid\",\n}\n\n/**\n * @schema ScheduleViewType\n */\nexport enum ScheduleViewType {\n  /** DAILY */\n  DAILY = \"DAILY\",\n  /** MONTHLY */\n  MONTHLY = \"MONTHLY\",\n  /** DEFAULT */\n  DEFAULT = \"DEFAULT\",\n  /** WEEKLY */\n  WEEKLY = \"WEEKLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::OnlineArchive`\n *\n * @cloudformationResource MongoDB::Atlas::OnlineArchive\n * @stability external\n */\nexport class CfnOnlineArchive extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::OnlineArchive\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnOnlineArchiveProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.State`\n   */\n  public readonly attrState: string;\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.ArchiveId`\n   */\n  public readonly attrArchiveId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::OnlineArchive`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnOnlineArchiveProps\n  ) {\n    super(scope, id, {\n      type: CfnOnlineArchive.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnOnlineArchiveProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrState = cdk.Token.asString(this.getAtt(\"State\"));\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n    this.attrArchiveId = cdk.Token.asString(this.getAtt(\"ArchiveId\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/online-archive/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAoGnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,4BAA4B,CAC1C,GAAsC;IAEtC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,QAAQ,EAAE,mBAAmB,CAAC,GAAG,CAAC,QAAQ,CAAC;QAC3C,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,eAAe,EAAE,GAAG,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC9C,yBAAyB,CAAC,CAAC,CAAC,CAC7B;QACD,QAAQ,EAAE,mBAAmB,CAAC,GAAG,CAAC,QAAQ,CAAC;KAC5C,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AA3BD,oEA2BC;AACD,wCAAwC;AAExC;;;;;;GAMG;AACH,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,eAAe;IACf,4DAAqB,CAAA;IACrB,iBAAiB;IACjB,gEAAyB,CAAA;AAC3B,CAAC,EALW,mCAAmC,GAAnC,2CAAmC,KAAnC,2CAAmC,QAK9C;AA0CD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,mBAAmB,CACjC,GAA6B;IAE7B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,KAAK,EAAE,GAAG,CAAC,KAAK;KACjB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,kDAkBC;AAsBD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,yBAAyB,CACvC,GAAmC;IAEnC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;KACjB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAfD,8DAeC;AAuDD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,mBAAmB,CACjC,GAA6B;IAE7B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AApBD,kDAoBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,WAAW;IACX,iCAAa,CAAA;IACb,aAAa;IACb,qCAAiB,CAAA;AACnB,CAAC,EALW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAK3B;AAED;;;;GAIG;AACH,IAAY,sBASX;AATD,WAAY,sBAAsB;IAChC,cAAc;IACd,6CAAmB,CAAA;IACnB,oBAAoB;IACpB,yDAA+B,CAAA;IAC/B,mBAAmB;IACnB,uDAA6B,CAAA;IAC7B,wBAAwB;IACxB,iEAAuC,CAAA;AACzC,CAAC,EATW,sBAAsB,GAAtB,8BAAsB,KAAtB,8BAAsB,QASjC;AAED;;GAEG;AACH,IAAY,gBASX;AATD,WAAY,gBAAgB;IAC1B,YAAY;IACZ,mCAAe,CAAA;IACf,cAAc;IACd,uCAAmB,CAAA;IACnB,cAAc;IACd,uCAAmB,CAAA;IACnB,aAAa;IACb,qCAAiB,CAAA;AACnB,CAAC,EATW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAS3B;AAED;;;;;GAKG;AACH,MAAa,gBAAiB,SAAQ,GAAG,CAAC,WAAW;IAyBnD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA4B;QAE5B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,gBAAgB,CAAC,sBAAsB;YAC7C,UAAU,EAAE,4BAA4B,CAAC,KAAK,CAAE;SACjD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QAC1D,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;QACpE,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;IACpE,CAAC;;AA/CH,4CAgDC;;;AA/CC;;GAEG;AACoB,uCAAsB,GAC3C,+BAA+B,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, or removes an online archive.\n *\n * @schema CfnOnlineArchiveProps\n */\nexport interface CfnOnlineArchiveProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnOnlineArchiveProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Human-readable label that identifies the cluster that contains the collection from which you want to remove an online archive.\n   *\n   * @schema CfnOnlineArchiveProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * Human-readable label that identifies the collection for which you created the online archive.\n   *\n   * @schema CfnOnlineArchiveProps#CollName\n   */\n  readonly collName?: string;\n\n  /**\n   * Classification of MongoDB database collection that you want to return.\n   *\n   * If you set this parameter to `TIMESERIES`, set `\"criteria.type\" : \"date\"` and `\"criteria.dateFormat\" : \"ISODATE\"`.\n   *\n   * @schema CfnOnlineArchiveProps#CollectionType\n   */\n  readonly collectionType?: CfnOnlineArchivePropsCollectionType;\n\n  /**\n   * Rules by which MongoDB MongoDB Cloud archives data.\n   *\n   * Use the **criteria.type** field to choose how MongoDB Cloud selects data to archive. Choose data using the age of the data or a MongoDB query.\n   * **\"criteria.type\": \"DATE\"** selects documents to archive based on a date.\n   * **\"criteria.type\": \"CUSTOM\"** selects documents to archive based on a custom JSON query. MongoDB Cloud doesn't support **\"criteria.type\": \"CUSTOM\"** when **\"collectionType\": \"TIMESERIES\"**.\n   *\n   * @schema CfnOnlineArchiveProps#Criteria\n   */\n  readonly criteria: CriteriaView;\n\n  /**\n   * Human-readable label of the database that contains the collection that contains the online archive.\n   *\n   * @schema CfnOnlineArchiveProps#DbName\n   */\n  readonly dbName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnOnlineArchiveProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnOnlineArchiveProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnOnlineArchiveProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnOnlineArchiveProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * List that contains document parameters to use to logically divide data within a collection. Partitions provide a coarse level of filtering of the underlying collection data. To divide your data, specify up to two parameters that you frequently query. Any queries that don't use these parameters result in a full collection scan of all archived documents. This takes more time and increase your costs.\n   *\n   * @schema CfnOnlineArchiveProps#PartitionFields\n   */\n  readonly partitionFields?: PartitionFieldView[];\n\n  /**\n   * Regular frequency and duration when archiving process occurs.\n   *\n   * @schema CfnOnlineArchiveProps#Schedule\n   */\n  readonly schedule?: ScheduleView;\n}\n\n/**\n * Converts an object of type 'CfnOnlineArchiveProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnOnlineArchiveProps(\n  obj: CfnOnlineArchiveProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ClusterName: obj.clusterName,\n    CollName: obj.collName,\n    CollectionType: obj.collectionType,\n    Criteria: toJson_CriteriaView(obj.criteria),\n    DbName: obj.dbName,\n    ProjectId: obj.projectId,\n    IncludeCount: obj.includeCount,\n    ItemsPerPage: obj.itemsPerPage,\n    PageNum: obj.pageNum,\n    PartitionFields: obj.partitionFields?.map((y) =>\n      toJson_PartitionFieldView(y)\n    ),\n    Schedule: toJson_ScheduleView(obj.schedule),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Classification of MongoDB database collection that you want to return.\n *\n * If you set this parameter to `TIMESERIES`, set `\"criteria.type\" : \"date\"` and `\"criteria.dateFormat\" : \"ISODATE\"`.\n *\n * @schema CfnOnlineArchivePropsCollectionType\n */\nexport enum CfnOnlineArchivePropsCollectionType {\n  /** STANDARD */\n  STANDARD = \"STANDARD\",\n  /** TIMESERIES */\n  TIMESERIES = \"TIMESERIES\",\n}\n\n/**\n * @schema CriteriaView\n */\nexport interface CriteriaView {\n  /**\n   * Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query. **DATE** selects documents to archive based on a date. (if DATE is selected, the PartitionFields.FieldName must be completed with the Criteria.DateField value)**CUSTOM** selects documents to archive based on a custom JSON query (When selecting this option, the Query property must be inputted). MongoDB Cloud doesn't support **CUSTOM** when `collectionType: TIMESERIES`.\n   *\n   * @schema CriteriaView#Type\n   */\n  readonly type?: CriteriaViewType;\n\n  /**\n   * Indexed database parameter that stores the date that determines when data moves to the online archive. MongoDB Cloud archives the data when the current date exceeds the date in this database parameter plus the number of days specified through the expireAfterDays parameter. Set this parameter when you set \"criteria.type\" : \"DATE\".\n   *\n   * @schema CriteriaView#DateField\n   */\n  readonly dateField?: string;\n\n  /**\n   * Syntax used to write the date after which data moves to the online archive. Date can be expressed as ISO 8601 or Epoch timestamps. The Epoch timestamp can be expressed as nanoseconds, milliseconds, or seconds. Set this parameter when \"criteria.type\" : \"DATE\". You must set \"criteria.type\" : \"DATE\" if \"collectionType\": \"TIMESERIES\".\n   *\n   * @schema CriteriaView#DateFormat\n   */\n  readonly dateFormat?: CriteriaViewDateFormat;\n\n  /**\n   * Number of days after the value in the criteria.dateField when MongoDB Cloud archives data in the specified cluster. Set this parameter when you set \"criteria.type\" : \"DATE\".\n   *\n   * @schema CriteriaView#ExpireAfterDays\n   */\n  readonly expireAfterDays?: number;\n\n  /**\n   * MongoDB find query that selects documents to archive. The specified query follows the syntax of the db.collection.find(query) command. This query can't use the empty document ({}) to return all documents. Set this parameter when \"criteria.type\" : \"CUSTOM\".\n   *\n   * @schema CriteriaView#Query\n   */\n  readonly query?: string;\n}\n\n/**\n * Converts an object of type 'CriteriaView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CriteriaView(\n  obj: CriteriaView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Type: obj.type,\n    DateField: obj.dateField,\n    DateFormat: obj.dateFormat,\n    ExpireAfterDays: obj.expireAfterDays,\n    Query: obj.query,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema PartitionFieldView\n */\nexport interface PartitionFieldView {\n  /**\n   * Human-readable label that identifies the parameter that MongoDB Cloud uses to partition data. To specify a nested parameter, use the dot notation.\n   *\n   * @schema PartitionFieldView#FieldName\n   */\n  readonly fieldName?: string;\n\n  /**\n   * Sequence in which MongoDB Cloud slices the collection data to create partitions. The resource expresses this sequence starting with zero. The value of the **criteria.dateField** parameter defaults as the first item in the partition sequence.\n   *\n   * @schema PartitionFieldView#Order\n   */\n  readonly order?: number;\n}\n\n/**\n * Converts an object of type 'PartitionFieldView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_PartitionFieldView(\n  obj: PartitionFieldView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FieldName: obj.fieldName,\n    Order: obj.order,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScheduleView\n */\nexport interface ScheduleView {\n  /**\n   * @schema ScheduleView#Type\n   */\n  readonly type?: ScheduleViewType;\n\n  /**\n   * Hour of the day when the scheduled window to run one online archive ends.\n   *\n   * @schema ScheduleView#EndHour\n   */\n  readonly endHour?: number;\n\n  /**\n   * Minute of the hour when the scheduled window to run one online archive ends.\n   *\n   * @schema ScheduleView#EndMinute\n   */\n  readonly endMinute?: number;\n\n  /**\n   * Hour of the day when the when the scheduled window to run one online archive starts.\n   *\n   * @schema ScheduleView#StartHour\n   */\n  readonly startHour?: number;\n\n  /**\n   * Minute of the hour when the scheduled window to run one online archive starts.\n   *\n   * @schema ScheduleView#StartMinute\n   */\n  readonly startMinute?: number;\n\n  /**\n   * Day of the month when the scheduled archive starts.\n   *\n   * @schema ScheduleView#DayOfMonth\n   */\n  readonly dayOfMonth?: number;\n\n  /**\n   * Day of the month when the scheduled archive starts.\n   *\n   * @schema ScheduleView#DayOfWeek\n   */\n  readonly dayOfWeek?: number;\n}\n\n/**\n * Converts an object of type 'ScheduleView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScheduleView(\n  obj: ScheduleView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Type: obj.type,\n    EndHour: obj.endHour,\n    EndMinute: obj.endMinute,\n    StartHour: obj.startHour,\n    StartMinute: obj.startMinute,\n    DayOfMonth: obj.dayOfMonth,\n    DayOfWeek: obj.dayOfWeek,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Means by which MongoDB Cloud selects data to archive. Data can be chosen using the age of the data or a MongoDB query. **DATE** selects documents to archive based on a date. (if DATE is selected, the PartitionFields.FieldName must be completed with the Criteria.DateField value)**CUSTOM** selects documents to archive based on a custom JSON query (When selecting this option, the Query property must be inputted). MongoDB Cloud doesn't support **CUSTOM** when `collectionType: TIMESERIES`.\n *\n * @schema CriteriaViewType\n */\nexport enum CriteriaViewType {\n  /** DATE */\n  DATE = \"DATE\",\n  /** CUSTOM */\n  CUSTOM = \"CUSTOM\",\n}\n\n/**\n * Syntax used to write the date after which data moves to the online archive. Date can be expressed as ISO 8601 or Epoch timestamps. The Epoch timestamp can be expressed as nanoseconds, milliseconds, or seconds. Set this parameter when \"criteria.type\" : \"DATE\". You must set \"criteria.type\" : \"DATE\" if \"collectionType\": \"TIMESERIES\".\n *\n * @schema CriteriaViewDateFormat\n */\nexport enum CriteriaViewDateFormat {\n  /** ISODATE */\n  ISODATE = \"ISODATE\",\n  /** EPOCH_SECONDS */\n  EPOCH_SECONDS = \"EPOCH_SECONDS\",\n  /** EPOCH_MILLIS */\n  EPOCH_MILLIS = \"EPOCH_MILLIS\",\n  /** EPOCH_NANOSECONDS */\n  EPOCH_NANOSECONDS = \"EPOCH_NANOSECONDS\",\n}\n\n/**\n * @schema ScheduleViewType\n */\nexport enum ScheduleViewType {\n  /** DAILY */\n  DAILY = \"DAILY\",\n  /** MONTHLY */\n  MONTHLY = \"MONTHLY\",\n  /** DEFAULT */\n  DEFAULT = \"DEFAULT\",\n  /** WEEKLY */\n  WEEKLY = \"WEEKLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::OnlineArchive`\n *\n * @cloudformationResource MongoDB::Atlas::OnlineArchive\n * @stability external\n */\nexport class CfnOnlineArchive extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::OnlineArchive\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnOnlineArchiveProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.State`\n   */\n  public readonly attrState: string;\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n  /**\n   * Attribute `MongoDB::Atlas::OnlineArchive.ArchiveId`\n   */\n  public readonly attrArchiveId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::OnlineArchive`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnOnlineArchiveProps\n  ) {\n    super(scope, id, {\n      type: CfnOnlineArchive.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnOnlineArchiveProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrState = cdk.Token.asString(this.getAtt(\"State\"));\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n    this.attrArchiveId = cdk.Token.asString(this.getAtt(\"ArchiveId\"));\n  }\n}\n"]}

@@ -10,3 +10,3 @@ import * as cdk from "aws-cdk-lib";

/**
* Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).
*

@@ -13,0 +13,0 @@ * @schema CfnOrgInvitationProps#Profile

@@ -90,3 +90,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnOrgInvitation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOrgInvitation", version: "3.7.2" };
CfnOrgInvitation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOrgInvitation", version: "3.8.0" };
/**

@@ -96,2 +96,2 @@ * The CloudFormation resource type name for this resource class.

CfnOrgInvitation.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::OrgInvitation";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/org-invitation/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, and edits organizational units in MongoDB Cloud.\n *\n * @schema CfnOrgInvitationProps\n */\nexport interface CfnOrgInvitationProps {\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnOrgInvitationProps#Profile\n   */\n  readonly profile: string;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnOrgInvitationProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the invitation.\n   *\n   * @schema CfnOrgInvitationProps#InvitationId\n   */\n  readonly invitationId?: string;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnOrgInvitationProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects.\n   *\n   * @schema CfnOrgInvitationProps#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Human-readable label that identifies this organization.\n   *\n   * @schema CfnOrgInvitationProps#OrgName\n   */\n  readonly orgName?: string;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnOrgInvitationProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * One or more organization or project level roles to assign to the MongoDB Cloud user.\n   *\n   * @schema CfnOrgInvitationProps#Roles\n   */\n  readonly roles?: CfnOrgInvitationPropsRoles[];\n\n  /**\n   * List of unique 24-hexadecimal digit strings that identifies each team.\n   *\n   * @schema CfnOrgInvitationProps#TeamIds\n   */\n  readonly teamIds?: string[];\n\n  /**\n   * Number of documents returned in this response.\n   *\n   * @schema CfnOrgInvitationProps#TotalCount\n   */\n  readonly totalCount?: number;\n\n  /**\n   * Email address of the MongoDB Cloud user invited to join the organization.\n   *\n   * @schema CfnOrgInvitationProps#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'CfnOrgInvitationProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnOrgInvitationProps(\n  obj: CfnOrgInvitationProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    IncludeCount: obj.includeCount,\n    InvitationId: obj.invitationId,\n    ItemsPerPage: obj.itemsPerPage,\n    OrgId: obj.orgId,\n    OrgName: obj.orgName,\n    PageNum: obj.pageNum,\n    Roles: obj.roles?.map((y) => y),\n    TeamIds: obj.teamIds?.map((y) => y),\n    TotalCount: obj.totalCount,\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema CfnOrgInvitationPropsRoles\n */\nexport enum CfnOrgInvitationPropsRoles {\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::OrgInvitation`\n *\n * @cloudformationResource MongoDB::Atlas::OrgInvitation\n * @stability external\n */\nexport class CfnOrgInvitation extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::OrgInvitation\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnOrgInvitationProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.ExpiresAt`\n   */\n  public readonly attrExpiresAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.CreatedAt`\n   */\n  public readonly attrCreatedAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.InviterUsername`\n   */\n  public readonly attrInviterUsername: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::OrgInvitation`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnOrgInvitationProps\n  ) {\n    super(scope, id, {\n      type: CfnOrgInvitation.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnOrgInvitationProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrExpiresAt = cdk.Token.asString(this.getAtt(\"ExpiresAt\"));\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrCreatedAt = cdk.Token.asString(this.getAtt(\"CreatedAt\"));\n    this.attrInviterUsername = cdk.Token.asString(\n      this.getAtt(\"InviterUsername\")\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/org-invitation/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, and edits organizational units in MongoDB Cloud.\n *\n * @schema CfnOrgInvitationProps\n */\nexport interface CfnOrgInvitationProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnOrgInvitationProps#Profile\n   */\n  readonly profile: string;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnOrgInvitationProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the invitation.\n   *\n   * @schema CfnOrgInvitationProps#InvitationId\n   */\n  readonly invitationId?: string;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnOrgInvitationProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization that contains your projects.\n   *\n   * @schema CfnOrgInvitationProps#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Human-readable label that identifies this organization.\n   *\n   * @schema CfnOrgInvitationProps#OrgName\n   */\n  readonly orgName?: string;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnOrgInvitationProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * One or more organization or project level roles to assign to the MongoDB Cloud user.\n   *\n   * @schema CfnOrgInvitationProps#Roles\n   */\n  readonly roles?: CfnOrgInvitationPropsRoles[];\n\n  /**\n   * List of unique 24-hexadecimal digit strings that identifies each team.\n   *\n   * @schema CfnOrgInvitationProps#TeamIds\n   */\n  readonly teamIds?: string[];\n\n  /**\n   * Number of documents returned in this response.\n   *\n   * @schema CfnOrgInvitationProps#TotalCount\n   */\n  readonly totalCount?: number;\n\n  /**\n   * Email address of the MongoDB Cloud user invited to join the organization.\n   *\n   * @schema CfnOrgInvitationProps#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'CfnOrgInvitationProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnOrgInvitationProps(\n  obj: CfnOrgInvitationProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    IncludeCount: obj.includeCount,\n    InvitationId: obj.invitationId,\n    ItemsPerPage: obj.itemsPerPage,\n    OrgId: obj.orgId,\n    OrgName: obj.orgName,\n    PageNum: obj.pageNum,\n    Roles: obj.roles?.map((y) => y),\n    TeamIds: obj.teamIds?.map((y) => y),\n    TotalCount: obj.totalCount,\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema CfnOrgInvitationPropsRoles\n */\nexport enum CfnOrgInvitationPropsRoles {\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::OrgInvitation`\n *\n * @cloudformationResource MongoDB::Atlas::OrgInvitation\n * @stability external\n */\nexport class CfnOrgInvitation extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::OrgInvitation\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnOrgInvitationProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.ExpiresAt`\n   */\n  public readonly attrExpiresAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.CreatedAt`\n   */\n  public readonly attrCreatedAt: string;\n  /**\n   * Attribute `MongoDB::Atlas::OrgInvitation.InviterUsername`\n   */\n  public readonly attrInviterUsername: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::OrgInvitation`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnOrgInvitationProps\n  ) {\n    super(scope, id, {\n      type: CfnOrgInvitation.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnOrgInvitationProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrExpiresAt = cdk.Token.asString(this.getAtt(\"ExpiresAt\"));\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrCreatedAt = cdk.Token.asString(this.getAtt(\"CreatedAt\"));\n    this.attrInviterUsername = cdk.Token.asString(\n      this.getAtt(\"InviterUsername\")\n    );\n  }\n}\n"]}

@@ -74,3 +74,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnOrganization[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOrganization", version: "3.7.2" };
CfnOrganization[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOrganization", version: "3.8.0" };
/**

@@ -77,0 +77,0 @@ * The CloudFormation resource type name for this resource class.

@@ -53,3 +53,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivateEndpointAdl[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointAdl", version: "3.7.2" };
CfnPrivateEndpointAdl[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointAdl", version: "3.8.0" };
/**

@@ -56,0 +56,0 @@ * The CloudFormation resource type name for this resource class.

@@ -10,3 +10,3 @@ import * as cdk from "aws-cdk-lib";

/**
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup (../../../examples/profile-secret.yaml)
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml)
*

@@ -13,0 +13,0 @@ * @schema CfnPrivateEndpointAwsProps#Profile

@@ -54,3 +54,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivateEndpointAws[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointAws", version: "3.7.2" };
CfnPrivateEndpointAws[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointAws", version: "3.8.0" };
/**

@@ -60,2 +60,2 @@ * The CloudFormation resource type name for this resource class.

CfnPrivateEndpointAws.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::PrivateEndpointAWS";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbDEtcmVzb3VyY2VzL3ByaXZhdGUtZW5kcG9pbnQtYXdzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsMEJBQTBCO0FBQzFCLG1DQUFtQztBQTJEbkM7O0dBRUc7QUFDSCx5Q0FBeUM7QUFDekMsU0FBZ0IsaUNBQWlDLENBQy9DLEdBQTJDO0lBRTNDLElBQUksR0FBRyxLQUFLLFNBQVMsRUFBRTtRQUNyQixPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUNELE1BQU0sTUFBTSxHQUFHO1FBQ2IsT0FBTyxFQUFFLEdBQUcsQ0FBQyxPQUFPO1FBQ3BCLFNBQVMsRUFBRSxHQUFHLENBQUMsU0FBUztRQUN4QixpQkFBaUIsRUFBRSxHQUFHLENBQUMsaUJBQWlCO1FBQ3hDLEVBQUUsRUFBRSxHQUFHLENBQUMsRUFBRTtRQUNWLHdCQUF3QixFQUFFLEdBQUcsQ0FBQyx3QkFBd0I7UUFDdEQsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDLGdCQUFnQjtRQUN0QyxZQUFZLEVBQUUsR0FBRyxDQUFDLFlBQVk7S0FDL0IsQ0FBQztJQUNGLDBCQUEwQjtJQUMxQixPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUNsQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFDM0QsRUFBRSxDQUNILENBQUM7QUFDSixDQUFDO0FBcEJELDhFQW9CQztBQUNELHdDQUF3QztBQUV4Qzs7Ozs7R0FLRztBQUNILE1BQWEscUJBQXNCLFNBQVEsR0FBRyxDQUFDLFdBQVc7SUFZeEQ7Ozs7OztPQU1HO0lBQ0gsWUFDRSxLQUEyQixFQUMzQixFQUFVLEVBQ1YsS0FBaUM7UUFFakMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixJQUFJLEVBQUUscUJBQXFCLENBQUMsc0JBQXNCO1lBQ2xELFVBQVUsRUFBRSxpQ0FBaUMsQ0FBQyxLQUFLLENBQUU7U0FDdEQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQzs7QUE5Qkgsc0RBK0JDOzs7QUE5QkM7O0dBRUc7QUFDb0IsNENBQXNCLEdBQzNDLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gR2VuZXJhdGVkIGJ5IGNkay1pbXBvcnRcbmltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCAqIGFzIGNvbnN0cnVjdHMgZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuLyoqXG4gKiBDcmVhdGVzIG9uZSBwcml2YXRlIGVuZHBvaW50IGZvciB0aGUgc3BlY2lmaWVkIGNsb3VkIHNlcnZpY2UgcHJvdmlkZXIuIEF0IHRoaXMgY3VycmVudCB2ZXJzaW9uIG9ubHkgQVdTIGlzIHN1cHBvcnRlZFxuICpcbiAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgcHJvZmlsZSBpcyBkZWZpbmVkIGluIEFXUyBTZWNyZXQgbWFuYWdlci4gU2VlIFtTZWNyZXQgTWFuYWdlciBQcm9maWxlIHNldHVwICguLi8uLi8uLi9leGFtcGxlcy9wcm9maWxlLXNlY3JldC55YW1sKVxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI1Byb2ZpbGVcbiAgICovXG4gIHJlYWRvbmx5IHByb2ZpbGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFVuaXF1ZSAyNC1oZXhhZGVjaW1hbCBkaWdpdCBzdHJpbmcgdGhhdCBpZGVudGlmaWVzIHlvdXIgcHJvamVjdC5cbiAgICpcbiAgICogQHNjaGVtYSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyNQcm9qZWN0SWRcbiAgICovXG4gIHJlYWRvbmx5IHByb2plY3RJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBVbmlxdWUgMjQtaGV4YWRlY2ltYWwgZGlnaXQgc3RyaW5nIHRoYXQgaWRlbnRpZmllcyB0aGUgcHJpdmF0ZSBlbmRwb2ludCBzZXJ2aWNlIGZvciB3aGljaCB5b3Ugd2FudCB0byBjcmVhdGUgYSBwcml2YXRlIGVuZHBvaW50LlxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI0VuZHBvaW50U2VydmljZUlkXG4gICAqL1xuICByZWFkb25seSBlbmRwb2ludFNlcnZpY2VJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBVbmlxdWUgc3RyaW5nIHRoYXQgaWRlbnRpZmllcyB0aGUgcHJpdmF0ZSBlbmRwb2ludC4gZm9yIEFXUyBpcyB0aGUgVlBDIGVuZHBvaW50IElELCBleGFtcGxlOiB2cGNlLXh4eHh4eHh4XG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMjSWRcbiAgICovXG4gIHJlYWRvbmx5IGlkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJZiB0aGlzIHByb3BlciBpcyBzZXQgdG8gVFJVRSwgdGhlIGNsb3VkIGZvcm1hdGlvbiByZXNvdXJjZSB3aWxsIHJldHVybiBzdWNjZXNzIE9ubHkgaWYgdGhlIHByaXZhdGUgY29ubmVjdGlvbiBpcyBTdWNjZWVkZWRcbiAgICpcbiAgICogQHNjaGVtYSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyNFbmZvcmNlQ29ubmVjdGlvblN1Y2Nlc3NcbiAgICovXG4gIHJlYWRvbmx5IGVuZm9yY2VDb25uZWN0aW9uU3VjY2Vzcz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFN0YXRlIG9mIHRoZSBBbWF6b24gV2ViIFNlcnZpY2UgUHJpdmF0ZUxpbmsgY29ubmVjdGlvbiB3aGVuIE1vbmdvREIgQ2xvdWQgcmVjZWl2ZWQgdGhpcyByZXF1ZXN0LlxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI0Nvbm5lY3Rpb25TdGF0dXNcbiAgICovXG4gIHJlYWRvbmx5IGNvbm5lY3Rpb25TdGF0dXM/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEVycm9yIG1lc3NhZ2UgcmV0dXJuZWQgd2hlbiByZXF1ZXN0aW5nIHByaXZhdGUgY29ubmVjdGlvbiByZXNvdXJjZS4gVGhlIHJlc291cmNlIHJldHVybnMgbnVsbCBpZiB0aGUgcmVxdWVzdCBzdWNjZWVkZWQuXG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMjRXJyb3JNZXNzYWdlXG4gICAqL1xuICByZWFkb25seSBlcnJvck1lc3NhZ2U/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29udmVydHMgYW4gb2JqZWN0IG9mIHR5cGUgJ0NmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzJyB0byBKU09OIHJlcHJlc2VudGF0aW9uLlxuICovXG4vKiBlc2xpbnQtZGlzYWJsZSBtYXgtbGVuLCBxdW90ZS1wcm9wcyAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvSnNvbl9DZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyhcbiAgb2JqOiBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyB8IHVuZGVmaW5lZFxuKTogUmVjb3JkPHN0cmluZywgYW55PiB8IHVuZGVmaW5lZCB7XG4gIGlmIChvYmogPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbiAgY29uc3QgcmVzdWx0ID0ge1xuICAgIFByb2ZpbGU6IG9iai5wcm9maWxlLFxuICAgIFByb2plY3RJZDogb2JqLnByb2plY3RJZCxcbiAgICBFbmRwb2ludFNlcnZpY2VJZDogb2JqLmVuZHBvaW50U2VydmljZUlkLFxuICAgIElkOiBvYmouaWQsXG4gICAgRW5mb3JjZUNvbm5lY3Rpb25TdWNjZXNzOiBvYmouZW5mb3JjZUNvbm5lY3Rpb25TdWNjZXNzLFxuICAgIENvbm5lY3Rpb25TdGF0dXM6IG9iai5jb25uZWN0aW9uU3RhdHVzLFxuICAgIEVycm9yTWVzc2FnZTogb2JqLmVycm9yTWVzc2FnZSxcbiAgfTtcbiAgLy8gZmlsdGVyIHVuZGVmaW5lZCB2YWx1ZXNcbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKHJlc3VsdCkucmVkdWNlKFxuICAgIChyLCBpKSA9PiAoaVsxXSA9PT0gdW5kZWZpbmVkID8gciA6IHsgLi4uciwgW2lbMF1dOiBpWzFdIH0pLFxuICAgIHt9XG4gICk7XG59XG4vKiBlc2xpbnQtZW5hYmxlIG1heC1sZW4sIHF1b3RlLXByb3BzICovXG5cbi8qKlxuICogQSBDbG91ZEZvcm1hdGlvbiBgTW9uZ29EQjo6QXRsYXM6OlByaXZhdGVFbmRwb2ludEFXU2BcbiAqXG4gKiBAY2xvdWRmb3JtYXRpb25SZXNvdXJjZSBNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTXG4gKiBAc3RhYmlsaXR5IGV4dGVybmFsXG4gKi9cbmV4cG9ydCBjbGFzcyBDZm5Qcml2YXRlRW5kcG9pbnRBd3MgZXh0ZW5kcyBjZGsuQ2ZuUmVzb3VyY2Uge1xuICAvKipcbiAgICogVGhlIENsb3VkRm9ybWF0aW9uIHJlc291cmNlIHR5cGUgbmFtZSBmb3IgdGhpcyByZXNvdXJjZSBjbGFzcy5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgQ0ZOX1JFU09VUkNFX1RZUEVfTkFNRSA9XG4gICAgXCJNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTXCI7XG5cbiAgLyoqXG4gICAqIFJlc291cmNlIHByb3BzLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByb3BzOiBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcztcblxuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGBNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTYC5cbiAgICpcbiAgICogQHBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAqIEBwYXJhbSBpZCAgICAtIHNjb3BlZCBpZCBvZiB0aGUgcmVzb3VyY2VcbiAgICogQHBhcmFtIHByb3BzIC0gcmVzb3VyY2UgcHJvcGVydGllc1xuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgc2NvcGU6IGNvbnN0cnVjdHMuQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgdHlwZTogQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzLkNGTl9SRVNPVVJDRV9UWVBFX05BTUUsXG4gICAgICBwcm9wZXJ0aWVzOiB0b0pzb25fQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMocHJvcHMpISxcbiAgICB9KTtcblxuICAgIHRoaXMucHJvcHMgPSBwcm9wcztcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbDEtcmVzb3VyY2VzL3ByaXZhdGUtZW5kcG9pbnQtYXdzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsMEJBQTBCO0FBQzFCLG1DQUFtQztBQTJEbkM7O0dBRUc7QUFDSCx5Q0FBeUM7QUFDekMsU0FBZ0IsaUNBQWlDLENBQy9DLEdBQTJDO0lBRTNDLElBQUksR0FBRyxLQUFLLFNBQVMsRUFBRTtRQUNyQixPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUNELE1BQU0sTUFBTSxHQUFHO1FBQ2IsT0FBTyxFQUFFLEdBQUcsQ0FBQyxPQUFPO1FBQ3BCLFNBQVMsRUFBRSxHQUFHLENBQUMsU0FBUztRQUN4QixpQkFBaUIsRUFBRSxHQUFHLENBQUMsaUJBQWlCO1FBQ3hDLEVBQUUsRUFBRSxHQUFHLENBQUMsRUFBRTtRQUNWLHdCQUF3QixFQUFFLEdBQUcsQ0FBQyx3QkFBd0I7UUFDdEQsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDLGdCQUFnQjtRQUN0QyxZQUFZLEVBQUUsR0FBRyxDQUFDLFlBQVk7S0FDL0IsQ0FBQztJQUNGLDBCQUEwQjtJQUMxQixPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUNsQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFDM0QsRUFBRSxDQUNILENBQUM7QUFDSixDQUFDO0FBcEJELDhFQW9CQztBQUNELHdDQUF3QztBQUV4Qzs7Ozs7R0FLRztBQUNILE1BQWEscUJBQXNCLFNBQVEsR0FBRyxDQUFDLFdBQVc7SUFZeEQ7Ozs7OztPQU1HO0lBQ0gsWUFDRSxLQUEyQixFQUMzQixFQUFVLEVBQ1YsS0FBaUM7UUFFakMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixJQUFJLEVBQUUscUJBQXFCLENBQUMsc0JBQXNCO1lBQ2xELFVBQVUsRUFBRSxpQ0FBaUMsQ0FBQyxLQUFLLENBQUU7U0FDdEQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQzs7QUE5Qkgsc0RBK0JDOzs7QUE5QkM7O0dBRUc7QUFDb0IsNENBQXNCLEdBQzNDLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gR2VuZXJhdGVkIGJ5IGNkay1pbXBvcnRcbmltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCAqIGFzIGNvbnN0cnVjdHMgZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuLyoqXG4gKiBDcmVhdGVzIG9uZSBwcml2YXRlIGVuZHBvaW50IGZvciB0aGUgc3BlY2lmaWVkIGNsb3VkIHNlcnZpY2UgcHJvdmlkZXIuIEF0IHRoaXMgY3VycmVudCB2ZXJzaW9uIG9ubHkgQVdTIGlzIHN1cHBvcnRlZFxuICpcbiAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgcHJvZmlsZSBpcyBkZWZpbmVkIGluIEFXUyBTZWNyZXQgbWFuYWdlci4gU2VlIFtTZWNyZXQgTWFuYWdlciBQcm9maWxlIHNldHVwXSguLi8uLi8uLi9leGFtcGxlcy9wcm9maWxlLXNlY3JldC55YW1sKVxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI1Byb2ZpbGVcbiAgICovXG4gIHJlYWRvbmx5IHByb2ZpbGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFVuaXF1ZSAyNC1oZXhhZGVjaW1hbCBkaWdpdCBzdHJpbmcgdGhhdCBpZGVudGlmaWVzIHlvdXIgcHJvamVjdC5cbiAgICpcbiAgICogQHNjaGVtYSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyNQcm9qZWN0SWRcbiAgICovXG4gIHJlYWRvbmx5IHByb2plY3RJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBVbmlxdWUgMjQtaGV4YWRlY2ltYWwgZGlnaXQgc3RyaW5nIHRoYXQgaWRlbnRpZmllcyB0aGUgcHJpdmF0ZSBlbmRwb2ludCBzZXJ2aWNlIGZvciB3aGljaCB5b3Ugd2FudCB0byBjcmVhdGUgYSBwcml2YXRlIGVuZHBvaW50LlxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI0VuZHBvaW50U2VydmljZUlkXG4gICAqL1xuICByZWFkb25seSBlbmRwb2ludFNlcnZpY2VJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBVbmlxdWUgc3RyaW5nIHRoYXQgaWRlbnRpZmllcyB0aGUgcHJpdmF0ZSBlbmRwb2ludC4gZm9yIEFXUyBpcyB0aGUgVlBDIGVuZHBvaW50IElELCBleGFtcGxlOiB2cGNlLXh4eHh4eHh4XG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMjSWRcbiAgICovXG4gIHJlYWRvbmx5IGlkPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJZiB0aGlzIHByb3BlciBpcyBzZXQgdG8gVFJVRSwgdGhlIGNsb3VkIGZvcm1hdGlvbiByZXNvdXJjZSB3aWxsIHJldHVybiBzdWNjZXNzIE9ubHkgaWYgdGhlIHByaXZhdGUgY29ubmVjdGlvbiBpcyBTdWNjZWVkZWRcbiAgICpcbiAgICogQHNjaGVtYSBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyNFbmZvcmNlQ29ubmVjdGlvblN1Y2Nlc3NcbiAgICovXG4gIHJlYWRvbmx5IGVuZm9yY2VDb25uZWN0aW9uU3VjY2Vzcz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFN0YXRlIG9mIHRoZSBBbWF6b24gV2ViIFNlcnZpY2UgUHJpdmF0ZUxpbmsgY29ubmVjdGlvbiB3aGVuIE1vbmdvREIgQ2xvdWQgcmVjZWl2ZWQgdGhpcyByZXF1ZXN0LlxuICAgKlxuICAgKiBAc2NoZW1hIENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzI0Nvbm5lY3Rpb25TdGF0dXNcbiAgICovXG4gIHJlYWRvbmx5IGNvbm5lY3Rpb25TdGF0dXM/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEVycm9yIG1lc3NhZ2UgcmV0dXJuZWQgd2hlbiByZXF1ZXN0aW5nIHByaXZhdGUgY29ubmVjdGlvbiByZXNvdXJjZS4gVGhlIHJlc291cmNlIHJldHVybnMgbnVsbCBpZiB0aGUgcmVxdWVzdCBzdWNjZWVkZWQuXG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMjRXJyb3JNZXNzYWdlXG4gICAqL1xuICByZWFkb25seSBlcnJvck1lc3NhZ2U/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29udmVydHMgYW4gb2JqZWN0IG9mIHR5cGUgJ0NmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzJyB0byBKU09OIHJlcHJlc2VudGF0aW9uLlxuICovXG4vKiBlc2xpbnQtZGlzYWJsZSBtYXgtbGVuLCBxdW90ZS1wcm9wcyAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvSnNvbl9DZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyhcbiAgb2JqOiBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcyB8IHVuZGVmaW5lZFxuKTogUmVjb3JkPHN0cmluZywgYW55PiB8IHVuZGVmaW5lZCB7XG4gIGlmIChvYmogPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbiAgY29uc3QgcmVzdWx0ID0ge1xuICAgIFByb2ZpbGU6IG9iai5wcm9maWxlLFxuICAgIFByb2plY3RJZDogb2JqLnByb2plY3RJZCxcbiAgICBFbmRwb2ludFNlcnZpY2VJZDogb2JqLmVuZHBvaW50U2VydmljZUlkLFxuICAgIElkOiBvYmouaWQsXG4gICAgRW5mb3JjZUNvbm5lY3Rpb25TdWNjZXNzOiBvYmouZW5mb3JjZUNvbm5lY3Rpb25TdWNjZXNzLFxuICAgIENvbm5lY3Rpb25TdGF0dXM6IG9iai5jb25uZWN0aW9uU3RhdHVzLFxuICAgIEVycm9yTWVzc2FnZTogb2JqLmVycm9yTWVzc2FnZSxcbiAgfTtcbiAgLy8gZmlsdGVyIHVuZGVmaW5lZCB2YWx1ZXNcbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKHJlc3VsdCkucmVkdWNlKFxuICAgIChyLCBpKSA9PiAoaVsxXSA9PT0gdW5kZWZpbmVkID8gciA6IHsgLi4uciwgW2lbMF1dOiBpWzFdIH0pLFxuICAgIHt9XG4gICk7XG59XG4vKiBlc2xpbnQtZW5hYmxlIG1heC1sZW4sIHF1b3RlLXByb3BzICovXG5cbi8qKlxuICogQSBDbG91ZEZvcm1hdGlvbiBgTW9uZ29EQjo6QXRsYXM6OlByaXZhdGVFbmRwb2ludEFXU2BcbiAqXG4gKiBAY2xvdWRmb3JtYXRpb25SZXNvdXJjZSBNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTXG4gKiBAc3RhYmlsaXR5IGV4dGVybmFsXG4gKi9cbmV4cG9ydCBjbGFzcyBDZm5Qcml2YXRlRW5kcG9pbnRBd3MgZXh0ZW5kcyBjZGsuQ2ZuUmVzb3VyY2Uge1xuICAvKipcbiAgICogVGhlIENsb3VkRm9ybWF0aW9uIHJlc291cmNlIHR5cGUgbmFtZSBmb3IgdGhpcyByZXNvdXJjZSBjbGFzcy5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgQ0ZOX1JFU09VUkNFX1RZUEVfTkFNRSA9XG4gICAgXCJNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTXCI7XG5cbiAgLyoqXG4gICAqIFJlc291cmNlIHByb3BzLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByb3BzOiBDZm5Qcml2YXRlRW5kcG9pbnRBd3NQcm9wcztcblxuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGBNb25nb0RCOjpBdGxhczo6UHJpdmF0ZUVuZHBvaW50QVdTYC5cbiAgICpcbiAgICogQHBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAqIEBwYXJhbSBpZCAgICAtIHNjb3BlZCBpZCBvZiB0aGUgcmVzb3VyY2VcbiAgICogQHBhcmFtIHByb3BzIC0gcmVzb3VyY2UgcHJvcGVydGllc1xuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgc2NvcGU6IGNvbnN0cnVjdHMuQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IENmblByaXZhdGVFbmRwb2ludEF3c1Byb3BzXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgdHlwZTogQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzLkNGTl9SRVNPVVJDRV9UWVBFX05BTUUsXG4gICAgICBwcm9wZXJ0aWVzOiB0b0pzb25fQ2ZuUHJpdmF0ZUVuZHBvaW50QXdzUHJvcHMocHJvcHMpISxcbiAgICB9KTtcblxuICAgIHRoaXMucHJvcHMgPSBwcm9wcztcbiAgfVxufVxuIl19

@@ -49,3 +49,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivateEndPointRegionalMode[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndPointRegionalMode", version: "3.7.2" };
CfnPrivateEndPointRegionalMode[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndPointRegionalMode", version: "3.8.0" };
/**

@@ -52,0 +52,0 @@ * The CloudFormation resource type name for this resource class.

@@ -10,3 +10,3 @@ import * as cdk from "aws-cdk-lib";

/**
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup (../../../examples/profile-secret.yaml)
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml)
*

@@ -13,0 +13,0 @@ * @schema CfnPrivateEndpointServiceProps#Profile

@@ -70,3 +70,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivateEndpointService[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointService", version: "3.7.2" };
CfnPrivateEndpointService[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpointService", version: "3.8.0" };
/**

@@ -76,2 +76,2 @@ * The CloudFormation resource type name for this resource class.

CfnPrivateEndpointService.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::PrivateEndpointService";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/private-endpoint-service/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAsCnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,qCAAqC,CACnD,GAA+C;IAE/C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,aAAa,EAAE,GAAG,CAAC,aAAa;KACjC,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAjBD,sFAiBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,2CAOX;AAPD,WAAY,2CAA2C;IACrD,UAAU;IACV,0DAAW,CAAA;IACX,YAAY;IACZ,8DAAe,CAAA;IACf,UAAU;IACV,0DAAW,CAAA;AACb,CAAC,EAPW,2CAA2C,GAA3C,mDAA2C,KAA3C,mDAA2C,QAOtD;AAED;;;;;GAKG;AACH,MAAa,yBAA0B,SAAQ,GAAG,CAAC,WAAW;IAiC5D;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAqC;QAErC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,yBAAyB,CAAC,sBAAsB;YACtD,UAAU,EAAE,qCAAqC,CAAC,KAAK,CAAE;SAC1D,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,uBAAuB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAC/C,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,CACnC,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAC5C,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAClC,CAAC;IACJ,CAAC;;AA7DH,8DA8DC;;;AA7DC;;GAEG;AACoB,gDAAsB,GAC3C,wCAAwC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Creates one private endpoint service for the specified cloud service provider. This cloud service provider manages the private endpoint service for the project. When you create a private endpoint service, MongoDB Cloud creates a network container in the project for the cloud provider for which you create the private endpoint service if one doesn't already exist.\n *\n * @schema CfnPrivateEndpointServiceProps\n */\nexport interface CfnPrivateEndpointServiceProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup (../../../examples/profile-secret.yaml)\n   *\n   * @schema CfnPrivateEndpointServiceProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnPrivateEndpointServiceProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema CfnPrivateEndpointServiceProps#Region\n   */\n  readonly region: string;\n\n  /**\n   * Cloud service provider that manages this private endpoint, default : AWS\n   *\n   * @schema CfnPrivateEndpointServiceProps#CloudProvider\n   */\n  readonly cloudProvider: CfnPrivateEndpointServicePropsCloudProvider;\n}\n\n/**\n * Converts an object of type 'CfnPrivateEndpointServiceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnPrivateEndpointServiceProps(\n  obj: CfnPrivateEndpointServiceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n    Region: obj.region,\n    CloudProvider: obj.cloudProvider,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Cloud service provider that manages this private endpoint, default : AWS\n *\n * @schema CfnPrivateEndpointServicePropsCloudProvider\n */\nexport enum CfnPrivateEndpointServicePropsCloudProvider {\n  /** AWS */\n  AWS = \"AWS\",\n  /** AZURE */\n  AZURE = \"AZURE\",\n  /** GCP */\n  GCP = \"GCP\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::PrivateEndpointService`\n *\n * @cloudformationResource MongoDB::Atlas::PrivateEndpointService\n * @stability external\n */\nexport class CfnPrivateEndpointService extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::PrivateEndpointService\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnPrivateEndpointServiceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.EndpointServiceName`\n   */\n  public readonly attrEndpointServiceName: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.ErrorMessage`\n   */\n  public readonly attrErrorMessage: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.Status`\n   */\n  public readonly attrStatus: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.InterfaceEndpoints`\n   */\n  public readonly attrInterfaceEndpoints: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::PrivateEndpointService`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnPrivateEndpointServiceProps\n  ) {\n    super(scope, id, {\n      type: CfnPrivateEndpointService.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnPrivateEndpointServiceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEndpointServiceName = cdk.Token.asString(\n      this.getAtt(\"EndpointServiceName\")\n    );\n    this.attrErrorMessage = cdk.Token.asString(this.getAtt(\"ErrorMessage\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n    this.attrInterfaceEndpoints = cdk.Token.asList(\n      this.getAtt(\"InterfaceEndpoints\")\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/private-endpoint-service/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAsCnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,qCAAqC,CACnD,GAA+C;IAE/C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,aAAa,EAAE,GAAG,CAAC,aAAa;KACjC,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAjBD,sFAiBC;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,2CAOX;AAPD,WAAY,2CAA2C;IACrD,UAAU;IACV,0DAAW,CAAA;IACX,YAAY;IACZ,8DAAe,CAAA;IACf,UAAU;IACV,0DAAW,CAAA;AACb,CAAC,EAPW,2CAA2C,GAA3C,mDAA2C,KAA3C,mDAA2C,QAOtD;AAED;;;;;GAKG;AACH,MAAa,yBAA0B,SAAQ,GAAG,CAAC,WAAW;IAiC5D;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAqC;QAErC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,yBAAyB,CAAC,sBAAsB;YACtD,UAAU,EAAE,qCAAqC,CAAC,KAAK,CAAE;SAC1D,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,uBAAuB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAC/C,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,CACnC,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAC5C,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAClC,CAAC;IACJ,CAAC;;AA7DH,8DA8DC;;;AA7DC;;GAEG;AACoB,gDAAsB,GAC3C,wCAAwC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Creates one private endpoint service for the specified cloud service provider. This cloud service provider manages the private endpoint service for the project. When you create a private endpoint service, MongoDB Cloud creates a network container in the project for the cloud provider for which you create the private endpoint service if one doesn't already exist.\n *\n * @schema CfnPrivateEndpointServiceProps\n */\nexport interface CfnPrivateEndpointServiceProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml)\n   *\n   * @schema CfnPrivateEndpointServiceProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnPrivateEndpointServiceProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema CfnPrivateEndpointServiceProps#Region\n   */\n  readonly region: string;\n\n  /**\n   * Cloud service provider that manages this private endpoint, default : AWS\n   *\n   * @schema CfnPrivateEndpointServiceProps#CloudProvider\n   */\n  readonly cloudProvider: CfnPrivateEndpointServicePropsCloudProvider;\n}\n\n/**\n * Converts an object of type 'CfnPrivateEndpointServiceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnPrivateEndpointServiceProps(\n  obj: CfnPrivateEndpointServiceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    ProjectId: obj.projectId,\n    Region: obj.region,\n    CloudProvider: obj.cloudProvider,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Cloud service provider that manages this private endpoint, default : AWS\n *\n * @schema CfnPrivateEndpointServicePropsCloudProvider\n */\nexport enum CfnPrivateEndpointServicePropsCloudProvider {\n  /** AWS */\n  AWS = \"AWS\",\n  /** AZURE */\n  AZURE = \"AZURE\",\n  /** GCP */\n  GCP = \"GCP\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::PrivateEndpointService`\n *\n * @cloudformationResource MongoDB::Atlas::PrivateEndpointService\n * @stability external\n */\nexport class CfnPrivateEndpointService extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::PrivateEndpointService\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnPrivateEndpointServiceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.EndpointServiceName`\n   */\n  public readonly attrEndpointServiceName: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.ErrorMessage`\n   */\n  public readonly attrErrorMessage: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.Status`\n   */\n  public readonly attrStatus: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpointService.InterfaceEndpoints`\n   */\n  public readonly attrInterfaceEndpoints: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::PrivateEndpointService`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnPrivateEndpointServiceProps\n  ) {\n    super(scope, id, {\n      type: CfnPrivateEndpointService.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnPrivateEndpointServiceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEndpointServiceName = cdk.Token.asString(\n      this.getAtt(\"EndpointServiceName\")\n    );\n    this.attrErrorMessage = cdk.Token.asString(this.getAtt(\"ErrorMessage\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n    this.attrInterfaceEndpoints = cdk.Token.asList(\n      this.getAtt(\"InterfaceEndpoints\")\n    );\n  }\n}\n"]}
import * as cdk from "aws-cdk-lib";
import * as constructs from "constructs";
/**
* The Private Endpoint creation flow consists of the creation of three related resources in the next order: 1. Atlas Private Endpoint Service 2. Aws VPC private Endpoint 3. Atlas Private Endpoint
* DEPRECATED- USE MongoDB::Atlas::PrivateEndpointService and MongoDB::Atlas::PrivateEndpointAWS instead, The Private Endpoint creation flow consists of the creation of three related resources in the next order: 1. Atlas Private Endpoint Service 2. Aws VPC private Endpoint 3. Atlas Private Endpoint
*

@@ -10,3 +10,3 @@ * @schema CfnPrivateEndpointProps

/**
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup (../../../examples/profile-secret.yaml)
* The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml)
*

@@ -13,0 +13,0 @@ * @schema CfnPrivateEndpointProps#Profile

@@ -75,3 +75,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpoint", version: "3.7.2" };
CfnPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivateEndpoint", version: "3.8.0" };
/**

@@ -81,2 +81,2 @@ * The CloudFormation resource type name for this resource class.

CfnPrivateEndpoint.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::PrivateEndpoint";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/private-endpoint/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA2DnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,8BAA8B,CAC5C,GAAwC;IAExC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAChD,sBAAsB,CAAC,CAAC,CAAC,CAC1B;KACF,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAtBD,wEAsBC;AA2CD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,sBAAsB,CACpC,GAAgC;IAEhC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACvC,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,wBAAwB,EAAE,GAAG,CAAC,wBAAwB;QACtD,0BAA0B,EAAE,GAAG,CAAC,0BAA0B;KAC3D,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,wDAkBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,kBAAmB,SAAQ,GAAG,CAAC,WAAW;IAqBrD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA8B;QAE9B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,kBAAkB,CAAC,sBAAsB;YAC/C,UAAU,EAAE,8BAA8B,CAAC,KAAK,CAAE;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAC5C,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAClC,CAAC;IACJ,CAAC;;AA5CH,gDA6CC;;;AA5CC;;GAEG;AACoB,yCAAsB,GAC3C,iCAAiC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * The Private Endpoint creation flow consists of the creation of three related resources in the next order: 1. Atlas Private Endpoint Service 2. Aws VPC private Endpoint 3. Atlas Private Endpoint\n *\n * @schema CfnPrivateEndpointProps\n */\nexport interface CfnPrivateEndpointProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup (../../../examples/profile-secret.yaml)\n   *\n   * @schema CfnPrivateEndpointProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Name of the AWS PrivateLink endpoint service. Atlas returns null while it is creating the endpoint service.\n   *\n   * @schema CfnPrivateEndpointProps#EndpointServiceName\n   */\n  readonly endpointServiceName?: string;\n\n  /**\n   * Error message pertaining to the AWS PrivateLink connection. Returns null if there are no errors.\n   *\n   * @schema CfnPrivateEndpointProps#ErrorMessage\n   */\n  readonly errorMessage?: string;\n\n  /**\n   * Status of the Atlas PrivateEndpoint service connection\n   *\n   * @schema CfnPrivateEndpointProps#Status\n   */\n  readonly status?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnPrivateEndpointProps#GroupId\n   */\n  readonly groupId: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema CfnPrivateEndpointProps#Region\n   */\n  readonly region: string;\n\n  /**\n   * List of private endpoint associated to the service\n   *\n   * @schema CfnPrivateEndpointProps#PrivateEndpoints\n   */\n  readonly privateEndpoints?: PrivateEndpoint[];\n}\n\n/**\n * Converts an object of type 'CfnPrivateEndpointProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnPrivateEndpointProps(\n  obj: CfnPrivateEndpointProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    EndpointServiceName: obj.endpointServiceName,\n    ErrorMessage: obj.errorMessage,\n    Status: obj.status,\n    GroupId: obj.groupId,\n    Region: obj.region,\n    PrivateEndpoints: obj.privateEndpoints?.map((y) =>\n      toJson_PrivateEndpoint(y)\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema PrivateEndpoint\n */\nexport interface PrivateEndpoint {\n  /**\n   * String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#VpcId\n   */\n  readonly vpcId?: string;\n\n  /**\n   * List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#SubnetIds\n   */\n  readonly subnetIds?: string[];\n\n  /**\n   * Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.\n   *\n   * @schema PrivateEndpoint#InterfaceEndpointId\n   */\n  readonly interfaceEndpointId?: string;\n\n  /**\n   * Status of the AWS PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AWSPrivateEndpointStatus\n   */\n  readonly awsPrivateEndpointStatus?: string;\n\n  /**\n   * Status of the Atlas PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AtlasPrivateEndpointStatus\n   */\n  readonly atlasPrivateEndpointStatus?: string;\n}\n\n/**\n * Converts an object of type 'PrivateEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_PrivateEndpoint(\n  obj: PrivateEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    VpcId: obj.vpcId,\n    SubnetIds: obj.subnetIds?.map((y) => y),\n    InterfaceEndpointId: obj.interfaceEndpointId,\n    AWSPrivateEndpointStatus: obj.awsPrivateEndpointStatus,\n    AtlasPrivateEndpointStatus: obj.atlasPrivateEndpointStatus,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::PrivateEndpoint`\n *\n * @cloudformationResource MongoDB::Atlas::PrivateEndpoint\n * @stability external\n */\nexport class CfnPrivateEndpoint extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::PrivateEndpoint\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnPrivateEndpointProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpoint.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpoint.InterfaceEndpoints`\n   */\n  public readonly attrInterfaceEndpoints: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::PrivateEndpoint`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnPrivateEndpointProps\n  ) {\n    super(scope, id, {\n      type: CfnPrivateEndpoint.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnPrivateEndpointProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrInterfaceEndpoints = cdk.Token.asList(\n      this.getAtt(\"InterfaceEndpoints\")\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/private-endpoint/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA2DnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,8BAA8B,CAC5C,GAAwC;IAExC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAChD,sBAAsB,CAAC,CAAC,CAAC,CAC1B;KACF,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAtBD,wEAsBC;AA2CD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,sBAAsB,CACpC,GAAgC;IAEhC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACvC,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;QAC5C,wBAAwB,EAAE,GAAG,CAAC,wBAAwB;QACtD,0BAA0B,EAAE,GAAG,CAAC,0BAA0B;KAC3D,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,wDAkBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,kBAAmB,SAAQ,GAAG,CAAC,WAAW;IAqBrD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA8B;QAE9B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,kBAAkB,CAAC,sBAAsB;YAC/C,UAAU,EAAE,8BAA8B,CAAC,KAAK,CAAE;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAC5C,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAClC,CAAC;IACJ,CAAC;;AA5CH,gDA6CC;;;AA5CC;;GAEG;AACoB,yCAAsB,GAC3C,iCAAiC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * DEPRECATED- USE MongoDB::Atlas::PrivateEndpointService and MongoDB::Atlas::PrivateEndpointAWS instead, The Private Endpoint creation flow consists of the creation of three related resources in the next order: 1. Atlas Private Endpoint Service 2. Aws VPC private Endpoint 3. Atlas Private Endpoint\n *\n * @schema CfnPrivateEndpointProps\n */\nexport interface CfnPrivateEndpointProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml)\n   *\n   * @schema CfnPrivateEndpointProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Name of the AWS PrivateLink endpoint service. Atlas returns null while it is creating the endpoint service.\n   *\n   * @schema CfnPrivateEndpointProps#EndpointServiceName\n   */\n  readonly endpointServiceName?: string;\n\n  /**\n   * Error message pertaining to the AWS PrivateLink connection. Returns null if there are no errors.\n   *\n   * @schema CfnPrivateEndpointProps#ErrorMessage\n   */\n  readonly errorMessage?: string;\n\n  /**\n   * Status of the Atlas PrivateEndpoint service connection\n   *\n   * @schema CfnPrivateEndpointProps#Status\n   */\n  readonly status?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnPrivateEndpointProps#GroupId\n   */\n  readonly groupId: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema CfnPrivateEndpointProps#Region\n   */\n  readonly region: string;\n\n  /**\n   * List of private endpoint associated to the service\n   *\n   * @schema CfnPrivateEndpointProps#PrivateEndpoints\n   */\n  readonly privateEndpoints?: PrivateEndpoint[];\n}\n\n/**\n * Converts an object of type 'CfnPrivateEndpointProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnPrivateEndpointProps(\n  obj: CfnPrivateEndpointProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    EndpointServiceName: obj.endpointServiceName,\n    ErrorMessage: obj.errorMessage,\n    Status: obj.status,\n    GroupId: obj.groupId,\n    Region: obj.region,\n    PrivateEndpoints: obj.privateEndpoints?.map((y) =>\n      toJson_PrivateEndpoint(y)\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema PrivateEndpoint\n */\nexport interface PrivateEndpoint {\n  /**\n   * String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#VpcId\n   */\n  readonly vpcId?: string;\n\n  /**\n   * List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#SubnetIds\n   */\n  readonly subnetIds?: string[];\n\n  /**\n   * Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.\n   *\n   * @schema PrivateEndpoint#InterfaceEndpointId\n   */\n  readonly interfaceEndpointId?: string;\n\n  /**\n   * Status of the AWS PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AWSPrivateEndpointStatus\n   */\n  readonly awsPrivateEndpointStatus?: string;\n\n  /**\n   * Status of the Atlas PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AtlasPrivateEndpointStatus\n   */\n  readonly atlasPrivateEndpointStatus?: string;\n}\n\n/**\n * Converts an object of type 'PrivateEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_PrivateEndpoint(\n  obj: PrivateEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    VpcId: obj.vpcId,\n    SubnetIds: obj.subnetIds?.map((y) => y),\n    InterfaceEndpointId: obj.interfaceEndpointId,\n    AWSPrivateEndpointStatus: obj.awsPrivateEndpointStatus,\n    AtlasPrivateEndpointStatus: obj.atlasPrivateEndpointStatus,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::PrivateEndpoint`\n *\n * @cloudformationResource MongoDB::Atlas::PrivateEndpoint\n * @stability external\n */\nexport class CfnPrivateEndpoint extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::PrivateEndpoint\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnPrivateEndpointProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpoint.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::PrivateEndpoint.InterfaceEndpoints`\n   */\n  public readonly attrInterfaceEndpoints: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::PrivateEndpoint`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnPrivateEndpointProps\n  ) {\n    super(scope, id, {\n      type: CfnPrivateEndpoint.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnPrivateEndpointProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrInterfaceEndpoints = cdk.Token.asList(\n      this.getAtt(\"InterfaceEndpoints\")\n    );\n  }\n}\n"]}

@@ -52,3 +52,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnPrivatelinkEndpointServiceDataFederationOnlineArchive[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivatelinkEndpointServiceDataFederationOnlineArchive", version: "3.7.2" };
CfnPrivatelinkEndpointServiceDataFederationOnlineArchive[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnPrivatelinkEndpointServiceDataFederationOnlineArchive", version: "3.8.0" };
/**

@@ -55,0 +55,0 @@ * The CloudFormation resource type name for this resource class.

@@ -76,3 +76,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnProjectInvitation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProjectInvitation", version: "3.7.2" };
CfnProjectInvitation[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProjectInvitation", version: "3.8.0" };
/**

@@ -79,0 +79,0 @@ * The CloudFormation resource type name for this resource class.

import * as cdk from "aws-cdk-lib";
import * as constructs from "constructs";
/**
* Returns, adds, edits, and removes network access limits to database deployments in MongoDB Cloud.
* Returns, adds, edits, and removes network access limits to database deployments in Atlas.
*

@@ -12,3 +12,3 @@ * @schema CfnProjectIpAccessListProps

*/
readonly accessList?: AccessListDefinition[];
readonly accessList: AccessListDefinition[];
/**

@@ -21,12 +21,2 @@ * Unique 24-hexadecimal digit string that identifies your project.

/**
* @schema CfnProjectIpAccessListProps#ListOptions
*/
readonly listOptions?: ListOptions;
/**
* Number of documents returned in this response.
*
* @schema CfnProjectIpAccessListProps#TotalCount
*/
readonly totalCount?: number;
/**
* Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used

@@ -37,2 +27,6 @@ *

readonly profile?: string;
/**
* @schema CfnProjectIpAccessListProps#ListOptions
*/
readonly listOptions?: ListOptions;
}

@@ -131,2 +125,6 @@ /**

/**
* Attribute `MongoDB::Atlas::ProjectIpAccessList.TotalCount`
*/
readonly attrTotalCount: number;
/**
* Create a new `MongoDB::Atlas::ProjectIpAccessList`.

@@ -133,0 +131,0 @@ *

@@ -19,5 +19,4 @@ "use strict";

ProjectId: obj.projectId,
Profile: obj.profile,
ListOptions: toJson_ListOptions(obj.listOptions),
TotalCount: obj.totalCount,
Profile: obj.profile,
};

@@ -86,2 +85,3 @@ // filter undefined values

this.props = props;
this.attrTotalCount = cdk.Token.asNumber(this.getAtt("TotalCount"));
}

@@ -91,3 +91,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnProjectIpAccessList[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProjectIpAccessList", version: "3.7.2" };
CfnProjectIpAccessList[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProjectIpAccessList", version: "3.8.0" };
/**

@@ -97,2 +97,2 @@ * The CloudFormation resource type name for this resource class.

CfnProjectIpAccessList.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::ProjectIpAccessList";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/project-ip-access-list/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAyCnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,kCAAkC,CAChD,GAA4C;IAE5C,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,UAAU,EAAE,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,2BAA2B,CAAC,CAAC,CAAC,CAAC;QACtE,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,WAAW,CAAC;QAChD,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,OAAO,EAAE,GAAG,CAAC,OAAO;KACrB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAlBD,gFAkBC;AAkDD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,2BAA2B,CACzC,GAAqC;IAErC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;QACtC,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAnBD,kEAmBC;AA6BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,kBAAkB,CAChC,GAA4B;IAE5B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,YAAY,EAAE,GAAG,CAAC,YAAY;KAC/B,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAhBD,gDAgBC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,sBAAuB,SAAQ,GAAG,CAAC,WAAW;IAYzD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAkC;QAElC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,sBAAsB,CAAC,sBAAsB;YACnD,UAAU,EAAE,kCAAkC,CAAC,KAAK,CAAE;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;AA9BH,wDA+BC;;;AA9BC;;GAEG;AACoB,6CAAsB,GAC3C,qCAAqC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes network access limits to database deployments in MongoDB Cloud.\n *\n * @schema CfnProjectIpAccessListProps\n */\nexport interface CfnProjectIpAccessListProps {\n  /**\n   * @schema CfnProjectIpAccessListProps#AccessList\n   */\n  readonly accessList?: AccessListDefinition[];\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnProjectIpAccessListProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * @schema CfnProjectIpAccessListProps#ListOptions\n   */\n  readonly listOptions?: ListOptions;\n\n  /**\n   * Number of documents returned in this response.\n   *\n   * @schema CfnProjectIpAccessListProps#TotalCount\n   */\n  readonly totalCount?: number;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnProjectIpAccessListProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnProjectIpAccessListProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnProjectIpAccessListProps(\n  obj: CfnProjectIpAccessListProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AccessList: obj.accessList?.map((y) => toJson_AccessListDefinition(y)),\n    ProjectId: obj.projectId,\n    ListOptions: toJson_ListOptions(obj.listOptions),\n    TotalCount: obj.totalCount,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema accessListDefinition\n */\nexport interface AccessListDefinition {\n  /**\n   * Date and time after which MongoDB Cloud deletes the temporary access list entry. This parameter expresses its value in the ISO 8601 timestamp format in UTC and can include the time zone designation. The date must be later than the current date but no later than one week after you submit this request. The resource returns this parameter if you specified an expiration date when creating this IP access list entry.\n   *\n   * @schema accessListDefinition#DeleteAfterDate\n   */\n  readonly deleteAfterDate?: string;\n\n  /**\n   * Unique string of the Amazon Web Services (AWS) security group that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. You must configure Virtual Private Connection (VPC) peering for your project before you can add an AWS security group to an IP access list. You cannot set AWS security groups as temporary access list entries. Don't set this parameter if you set cidrBlock or ipAddress.\n   *\n   * @schema accessListDefinition#AwsSecurityGroup\n   */\n  readonly awsSecurityGroup?: string;\n\n  /**\n   * Range of IP addresses in Classless Inter-Domain Routing (CIDR) notation that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. Don't set this parameter if you set awsSecurityGroup or ipAddress\n   *\n   * @schema accessListDefinition#CIDRBlock\n   */\n  readonly cidrBlock?: string;\n\n  /**\n   * Remark that explains the purpose or scope of this IP access list entry.\n   *\n   * @schema accessListDefinition#Comment\n   */\n  readonly comment?: string;\n\n  /**\n   * IP address that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. Don't set this parameter if you set awsSecurityGroup or cidrBlock.\n   *\n   * @schema accessListDefinition#IPAddress\n   */\n  readonly ipAddress?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema accessListDefinition#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'AccessListDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AccessListDefinition(\n  obj: AccessListDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DeleteAfterDate: obj.deleteAfterDate,\n    AwsSecurityGroup: obj.awsSecurityGroup,\n    CIDRBlock: obj.cidrBlock,\n    Comment: obj.comment,\n    IPAddress: obj.ipAddress,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema listOptions\n */\nexport interface ListOptions {\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema listOptions#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema listOptions#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (totalCount) in the response.\n   *\n   * @schema listOptions#IncludeCount\n   */\n  readonly includeCount?: boolean;\n}\n\n/**\n * Converts an object of type 'ListOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ListOptions(\n  obj: ListOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PageNum: obj.pageNum,\n    ItemsPerPage: obj.itemsPerPage,\n    IncludeCount: obj.includeCount,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::ProjectIpAccessList`\n *\n * @cloudformationResource MongoDB::Atlas::ProjectIpAccessList\n * @stability external\n */\nexport class CfnProjectIpAccessList extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ProjectIpAccessList\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnProjectIpAccessListProps;\n\n  /**\n   * Create a new `MongoDB::Atlas::ProjectIpAccessList`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnProjectIpAccessListProps\n  ) {\n    super(scope, id, {\n      type: CfnProjectIpAccessList.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnProjectIpAccessListProps(props)!,\n    });\n\n    this.props = props;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/project-ip-access-list/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes network access limits to database deployments in Atlas.\n *\n * @schema CfnProjectIpAccessListProps\n */\nexport interface CfnProjectIpAccessListProps {\n  /**\n   * @schema CfnProjectIpAccessListProps#AccessList\n   */\n  readonly accessList: AccessListDefinition[];\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnProjectIpAccessListProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnProjectIpAccessListProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * @schema CfnProjectIpAccessListProps#ListOptions\n   */\n  readonly listOptions?: ListOptions;\n}\n\n/**\n * Converts an object of type 'CfnProjectIpAccessListProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnProjectIpAccessListProps(\n  obj: CfnProjectIpAccessListProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AccessList: obj.accessList?.map((y) => toJson_AccessListDefinition(y)),\n    ProjectId: obj.projectId,\n    Profile: obj.profile,\n    ListOptions: toJson_ListOptions(obj.listOptions),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema accessListDefinition\n */\nexport interface AccessListDefinition {\n  /**\n   * Date and time after which MongoDB Cloud deletes the temporary access list entry. This parameter expresses its value in the ISO 8601 timestamp format in UTC and can include the time zone designation. The date must be later than the current date but no later than one week after you submit this request. The resource returns this parameter if you specified an expiration date when creating this IP access list entry.\n   *\n   * @schema accessListDefinition#DeleteAfterDate\n   */\n  readonly deleteAfterDate?: string;\n\n  /**\n   * Unique string of the Amazon Web Services (AWS) security group that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. You must configure Virtual Private Connection (VPC) peering for your project before you can add an AWS security group to an IP access list. You cannot set AWS security groups as temporary access list entries. Don't set this parameter if you set cidrBlock or ipAddress.\n   *\n   * @schema accessListDefinition#AwsSecurityGroup\n   */\n  readonly awsSecurityGroup?: string;\n\n  /**\n   * Range of IP addresses in Classless Inter-Domain Routing (CIDR) notation that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. Don't set this parameter if you set awsSecurityGroup or ipAddress\n   *\n   * @schema accessListDefinition#CIDRBlock\n   */\n  readonly cidrBlock?: string;\n\n  /**\n   * Remark that explains the purpose or scope of this IP access list entry.\n   *\n   * @schema accessListDefinition#Comment\n   */\n  readonly comment?: string;\n\n  /**\n   * IP address that you want to add to the project's IP access list. Your IP access list entry can be one awsSecurityGroup, one cidrBlock, or one ipAddress. Don't set this parameter if you set awsSecurityGroup or cidrBlock.\n   *\n   * @schema accessListDefinition#IPAddress\n   */\n  readonly ipAddress?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema accessListDefinition#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'AccessListDefinition' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AccessListDefinition(\n  obj: AccessListDefinition | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    DeleteAfterDate: obj.deleteAfterDate,\n    AwsSecurityGroup: obj.awsSecurityGroup,\n    CIDRBlock: obj.cidrBlock,\n    Comment: obj.comment,\n    IPAddress: obj.ipAddress,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema listOptions\n */\nexport interface ListOptions {\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema listOptions#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema listOptions#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (totalCount) in the response.\n   *\n   * @schema listOptions#IncludeCount\n   */\n  readonly includeCount?: boolean;\n}\n\n/**\n * Converts an object of type 'ListOptions' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ListOptions(\n  obj: ListOptions | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PageNum: obj.pageNum,\n    ItemsPerPage: obj.itemsPerPage,\n    IncludeCount: obj.includeCount,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::ProjectIpAccessList`\n *\n * @cloudformationResource MongoDB::Atlas::ProjectIpAccessList\n * @stability external\n */\nexport class CfnProjectIpAccessList extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ProjectIpAccessList\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnProjectIpAccessListProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::ProjectIpAccessList.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n\n  /**\n   * Create a new `MongoDB::Atlas::ProjectIpAccessList`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnProjectIpAccessListProps\n  ) {\n    super(scope, id, {\n      type: CfnProjectIpAccessList.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnProjectIpAccessListProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n  }\n}\n"]}

@@ -112,3 +112,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnProject[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProject", version: "3.7.2" };
CfnProject[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnProject", version: "3.8.0" };
/**

@@ -115,0 +115,0 @@ * The CloudFormation resource type name for this resource class.

@@ -69,3 +69,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnSearchDeployment[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnSearchDeployment", version: "3.7.2" };
CfnSearchDeployment[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnSearchDeployment", version: "3.8.0" };
/**

@@ -72,0 +72,0 @@ * The CloudFormation resource type name for this resource class.

@@ -135,3 +135,3 @@ import * as cdk from "aws-cdk-lib";

*/
readonly tokenizer?: any;
readonly tokenizer?: ApiAtlasFtsAnalyzersTokenizer;
}

@@ -138,0 +138,0 @@ /**

@@ -148,3 +148,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnSearchIndex[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnSearchIndex", version: "3.7.2" };
CfnSearchIndex[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnSearchIndex", version: "3.8.0" };
/**

@@ -154,2 +154,2 @@ * The CloudFormation resource type name for this resource class.

CfnSearchIndex.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::SearchIndex";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/search-index/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Atlas Search indexes. Also returns and updates user-defined analyzers.\n *\n * @schema CfnSearchIndexProps\n */\nexport interface CfnSearchIndexProps {\n  /**\n   * Specific pre-defined method chosen to convert database field text into searchable words. This conversion reduces the text of fields into the smallest units of text. These units are called a **term** or **token**. This process, known as tokenization, involves a variety of changes made to the text in fields:\n   *\n   * - extracting words\n   * - removing punctuation\n   * - removing accents\n   * - changing to lowercase\n   * - removing common words\n   * - reducing words to their root form (stemming)\n   * - changing words to their base form (lemmatization)\n   * MongoDB Cloud uses the selected process to build the Atlas Search index.\n   *\n   * @schema CfnSearchIndexProps#Analyzer\n   */\n  readonly analyzer?: string;\n\n  /**\n   * List of user-defined methods to convert database field text into searchable words.\n   *\n   * @schema CfnSearchIndexProps#Analyzers\n   */\n  readonly analyzers?: ApiAtlasFtsAnalyzersViewManual[];\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnSearchIndexProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Name of the cluster that contains the database and collection with one or more Application Search indexes.\n   *\n   * @schema CfnSearchIndexProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * Human-readable label that identifies the collection that contains one or more Atlas Search indexes.\n   *\n   * @schema CfnSearchIndexProps#CollectionName\n   */\n  readonly collectionName: string;\n\n  /**\n   * Human-readable label that identifies the database that contains the collection with one or more Atlas Search indexes.\n   *\n   * @schema CfnSearchIndexProps#Database\n   */\n  readonly database: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnSearchIndexProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Index specifications for the collection's fields.\n   *\n   * @schema CfnSearchIndexProps#Mappings\n   */\n  readonly mappings?: ApiAtlasFtsMappingsViewManual;\n\n  /**\n   * Human-readable label that identifies this index. Within each namespace, names of all indexes in the namespace must be unique.\n   *\n   * @schema CfnSearchIndexProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Type of index: **search** or **vectorSearch**. Default type is **search**.\n   *\n   * @schema CfnSearchIndexProps#Type\n   */\n  readonly type?: string;\n\n  /**\n   * Method applied to identify words when searching this index.\n   *\n   * @schema CfnSearchIndexProps#SearchAnalyzer\n   */\n  readonly searchAnalyzer?: string;\n\n  /**\n   * Rule sets that map words to their synonyms in this index.\n   *\n   * @schema CfnSearchIndexProps#Synonyms\n   */\n  readonly synonyms?: ApiAtlasFtsSynonymMappingDefinitionView[];\n\n  /**\n   * Array of [Fields](https://www.mongodb.com/docs/atlas/atlas-search/field-types/knn-vector/#std-label-fts-data-types-knn-vector) to configure this vectorSearch index. Stringify json representation of field with types and properties. Required for vector indexes. It must contain at least one **vector** type field.\n   *\n   * @schema CfnSearchIndexProps#Fields\n   */\n  readonly fields?: string;\n}\n\n/**\n * Converts an object of type 'CfnSearchIndexProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnSearchIndexProps(\n  obj: CfnSearchIndexProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Analyzer: obj.analyzer,\n    Analyzers: obj.analyzers?.map((y) =>\n      toJson_ApiAtlasFtsAnalyzersViewManual(y)\n    ),\n    Profile: obj.profile,\n    ClusterName: obj.clusterName,\n    CollectionName: obj.collectionName,\n    Database: obj.database,\n    ProjectId: obj.projectId,\n    Mappings: toJson_ApiAtlasFtsMappingsViewManual(obj.mappings),\n    Name: obj.name,\n    Type: obj.type,\n    SearchAnalyzer: obj.searchAnalyzer,\n    Synonyms: obj.synonyms?.map((y) =>\n      toJson_ApiAtlasFtsSynonymMappingDefinitionView(y)\n    ),\n    Fields: obj.fields,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSAnalyzersViewManual\n */\nexport interface ApiAtlasFtsAnalyzersViewManual {\n  /**\n   * Filters that examine text one character at a time and perform filtering operations.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#CharFilters\n   */\n  readonly charFilters?: string[];\n\n  /**\n   * Human-readable name that identifies the custom analyzer. Names must be unique within an index, and must not start with any of the following strings:\n   * - `lucene.`\n   * - `builtin.`\n   * - `mongodb.`\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Filter that performs operations such as:\n   *\n   * - Stemming, which reduces related words, such as \"talking\", \"talked\", and \"talks\" to their root word \"talk\".\n   *\n   * - Redaction, the removal of sensitive information from public documents.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#TokenFilters\n   */\n  readonly tokenFilters?: string[];\n\n  /**\n   * Tokenizer that you want to use to create tokens. Tokens determine how Atlas Search splits up text into discrete chunks for indexing.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#Tokenizer\n   */\n  readonly tokenizer?: any;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsAnalyzersViewManual' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsAnalyzersViewManual(\n  obj: ApiAtlasFtsAnalyzersViewManual | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CharFilters: obj.charFilters?.map((y) => y),\n    Name: obj.name,\n    TokenFilters: obj.tokenFilters?.map((y) => y),\n    Tokenizer: toJson_ApiAtlasFtsAnalyzersTokenizer(obj.tokenizer),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSMappingsViewManual\n */\nexport interface ApiAtlasFtsMappingsViewManual {\n  /**\n   * Flag that indicates whether the index uses dynamic or static mappings. Required for search indexes if **mappings.fields** is omitted.\n   *\n   * @schema ApiAtlasFTSMappingsViewManual#Dynamic\n   */\n  readonly dynamic?: boolean;\n\n  /**\n   * One or more field specifications for the Atlas Search index. Stringify json representation of field with types and properties. Required for search indexes if **mappings.dynamic** is omitted or set to **false**.\n   *\n   * @schema ApiAtlasFTSMappingsViewManual#Fields\n   */\n  readonly fields?: string;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsMappingsViewManual' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsMappingsViewManual(\n  obj: ApiAtlasFtsMappingsViewManual | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Dynamic: obj.dynamic,\n    Fields: obj.fields,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSSynonymMappingDefinitionView\n */\nexport interface ApiAtlasFtsSynonymMappingDefinitionView {\n  /**\n   * Specific pre-defined method chosen to apply to the synonyms to be searched.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Analyzer\n   */\n  readonly analyzer: string;\n\n  /**\n   * Human-readable label that identifies the synonym definition. Each **synonym.name** must be unique within the same index definition.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Name\n   */\n  readonly name: string;\n\n  /**\n   * Data set that stores the mapping one or more words map to one or more synonyms of those words.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Source\n   */\n  readonly source: SynonymSource;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsSynonymMappingDefinitionView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsSynonymMappingDefinitionView(\n  obj: ApiAtlasFtsSynonymMappingDefinitionView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Analyzer: obj.analyzer,\n    Name: obj.name,\n    Source: toJson_SynonymSource(obj.source),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Tokenizer that you want to use to create tokens. Tokens determine how Atlas Search splits up text into discrete chunks for indexing.\n *\n * @schema ApiAtlasFTSAnalyzersTokenizer\n */\nexport interface ApiAtlasFtsAnalyzersTokenizer {\n  /**\n   * Characters to include in the longest token that Atlas Search creates.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MaxGram\n   */\n  readonly maxGram?: number;\n\n  /**\n   * Characters to include in the shortest token that Atlas Search creates.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MinGram\n   */\n  readonly minGram?: number;\n\n  /**\n   * Human-readable label that identifies this tokenizer type.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Type\n   */\n  readonly type?: string;\n\n  /**\n   * Index of the character group within the matching expression to extract into tokens. Use `0` to extract all character groups.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Group\n   */\n  readonly group?: number;\n\n  /**\n   * Regular expression to match against.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Pattern\n   */\n  readonly pattern?: string;\n\n  /**\n   * Maximum number of characters in a single token. Tokens greater than this length are split at this length into multiple tokens.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MaxTokenLength\n   */\n  readonly maxTokenLength?: number;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsAnalyzersTokenizer' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsAnalyzersTokenizer(\n  obj: ApiAtlasFtsAnalyzersTokenizer | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    MaxGram: obj.maxGram,\n    MinGram: obj.minGram,\n    Type: obj.type,\n    Group: obj.group,\n    Pattern: obj.pattern,\n    MaxTokenLength: obj.maxTokenLength,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema SynonymSource\n */\nexport interface SynonymSource {\n  /**\n   * Human-readable label that identifies the MongoDB collection that stores words and their applicable synonyms.\n   *\n   * @schema SynonymSource#Collection\n   */\n  readonly collection: string;\n}\n\n/**\n * Converts an object of type 'SynonymSource' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_SynonymSource(\n  obj: SynonymSource | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collection: obj.collection,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::SearchIndex`\n *\n * @cloudformationResource MongoDB::Atlas::SearchIndex\n * @stability external\n */\nexport class CfnSearchIndex extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::SearchIndex\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnSearchIndexProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::SearchIndex.IndexId`\n   */\n  public readonly attrIndexId: string;\n  /**\n   * Attribute `MongoDB::Atlas::SearchIndex.Status`\n   */\n  public readonly attrStatus: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::SearchIndex`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnSearchIndexProps\n  ) {\n    super(scope, id, {\n      type: CfnSearchIndex.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnSearchIndexProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrIndexId = cdk.Token.asString(this.getAtt(\"IndexId\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/search-index/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Atlas Search indexes. Also returns and updates user-defined analyzers.\n *\n * @schema CfnSearchIndexProps\n */\nexport interface CfnSearchIndexProps {\n  /**\n   * Specific pre-defined method chosen to convert database field text into searchable words. This conversion reduces the text of fields into the smallest units of text. These units are called a **term** or **token**. This process, known as tokenization, involves a variety of changes made to the text in fields:\n   *\n   * - extracting words\n   * - removing punctuation\n   * - removing accents\n   * - changing to lowercase\n   * - removing common words\n   * - reducing words to their root form (stemming)\n   * - changing words to their base form (lemmatization)\n   * MongoDB Cloud uses the selected process to build the Atlas Search index.\n   *\n   * @schema CfnSearchIndexProps#Analyzer\n   */\n  readonly analyzer?: string;\n\n  /**\n   * List of user-defined methods to convert database field text into searchable words.\n   *\n   * @schema CfnSearchIndexProps#Analyzers\n   */\n  readonly analyzers?: ApiAtlasFtsAnalyzersViewManual[];\n\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnSearchIndexProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Name of the cluster that contains the database and collection with one or more Application Search indexes.\n   *\n   * @schema CfnSearchIndexProps#ClusterName\n   */\n  readonly clusterName: string;\n\n  /**\n   * Human-readable label that identifies the collection that contains one or more Atlas Search indexes.\n   *\n   * @schema CfnSearchIndexProps#CollectionName\n   */\n  readonly collectionName: string;\n\n  /**\n   * Human-readable label that identifies the database that contains the collection with one or more Atlas Search indexes.\n   *\n   * @schema CfnSearchIndexProps#Database\n   */\n  readonly database: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnSearchIndexProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Index specifications for the collection's fields.\n   *\n   * @schema CfnSearchIndexProps#Mappings\n   */\n  readonly mappings?: ApiAtlasFtsMappingsViewManual;\n\n  /**\n   * Human-readable label that identifies this index. Within each namespace, names of all indexes in the namespace must be unique.\n   *\n   * @schema CfnSearchIndexProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Type of index: **search** or **vectorSearch**. Default type is **search**.\n   *\n   * @schema CfnSearchIndexProps#Type\n   */\n  readonly type?: string;\n\n  /**\n   * Method applied to identify words when searching this index.\n   *\n   * @schema CfnSearchIndexProps#SearchAnalyzer\n   */\n  readonly searchAnalyzer?: string;\n\n  /**\n   * Rule sets that map words to their synonyms in this index.\n   *\n   * @schema CfnSearchIndexProps#Synonyms\n   */\n  readonly synonyms?: ApiAtlasFtsSynonymMappingDefinitionView[];\n\n  /**\n   * Array of [Fields](https://www.mongodb.com/docs/atlas/atlas-search/field-types/knn-vector/#std-label-fts-data-types-knn-vector) to configure this vectorSearch index. Stringify json representation of field with types and properties. Required for vector indexes. It must contain at least one **vector** type field.\n   *\n   * @schema CfnSearchIndexProps#Fields\n   */\n  readonly fields?: string;\n}\n\n/**\n * Converts an object of type 'CfnSearchIndexProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnSearchIndexProps(\n  obj: CfnSearchIndexProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Analyzer: obj.analyzer,\n    Analyzers: obj.analyzers?.map((y) =>\n      toJson_ApiAtlasFtsAnalyzersViewManual(y)\n    ),\n    Profile: obj.profile,\n    ClusterName: obj.clusterName,\n    CollectionName: obj.collectionName,\n    Database: obj.database,\n    ProjectId: obj.projectId,\n    Mappings: toJson_ApiAtlasFtsMappingsViewManual(obj.mappings),\n    Name: obj.name,\n    Type: obj.type,\n    SearchAnalyzer: obj.searchAnalyzer,\n    Synonyms: obj.synonyms?.map((y) =>\n      toJson_ApiAtlasFtsSynonymMappingDefinitionView(y)\n    ),\n    Fields: obj.fields,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSAnalyzersViewManual\n */\nexport interface ApiAtlasFtsAnalyzersViewManual {\n  /**\n   * Filters that examine text one character at a time and perform filtering operations.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#CharFilters\n   */\n  readonly charFilters?: string[];\n\n  /**\n   * Human-readable name that identifies the custom analyzer. Names must be unique within an index, and must not start with any of the following strings:\n   * - `lucene.`\n   * - `builtin.`\n   * - `mongodb.`\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Filter that performs operations such as:\n   *\n   * - Stemming, which reduces related words, such as \"talking\", \"talked\", and \"talks\" to their root word \"talk\".\n   *\n   * - Redaction, the removal of sensitive information from public documents.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#TokenFilters\n   */\n  readonly tokenFilters?: string[];\n\n  /**\n   * Tokenizer that you want to use to create tokens. Tokens determine how Atlas Search splits up text into discrete chunks for indexing.\n   *\n   * @schema ApiAtlasFTSAnalyzersViewManual#Tokenizer\n   */\n  readonly tokenizer?: ApiAtlasFtsAnalyzersTokenizer;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsAnalyzersViewManual' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsAnalyzersViewManual(\n  obj: ApiAtlasFtsAnalyzersViewManual | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CharFilters: obj.charFilters?.map((y) => y),\n    Name: obj.name,\n    TokenFilters: obj.tokenFilters?.map((y) => y),\n    Tokenizer: toJson_ApiAtlasFtsAnalyzersTokenizer(obj.tokenizer),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSMappingsViewManual\n */\nexport interface ApiAtlasFtsMappingsViewManual {\n  /**\n   * Flag that indicates whether the index uses dynamic or static mappings. Required for search indexes if **mappings.fields** is omitted.\n   *\n   * @schema ApiAtlasFTSMappingsViewManual#Dynamic\n   */\n  readonly dynamic?: boolean;\n\n  /**\n   * One or more field specifications for the Atlas Search index. Stringify json representation of field with types and properties. Required for search indexes if **mappings.dynamic** is omitted or set to **false**.\n   *\n   * @schema ApiAtlasFTSMappingsViewManual#Fields\n   */\n  readonly fields?: string;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsMappingsViewManual' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsMappingsViewManual(\n  obj: ApiAtlasFtsMappingsViewManual | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Dynamic: obj.dynamic,\n    Fields: obj.fields,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ApiAtlasFTSSynonymMappingDefinitionView\n */\nexport interface ApiAtlasFtsSynonymMappingDefinitionView {\n  /**\n   * Specific pre-defined method chosen to apply to the synonyms to be searched.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Analyzer\n   */\n  readonly analyzer: string;\n\n  /**\n   * Human-readable label that identifies the synonym definition. Each **synonym.name** must be unique within the same index definition.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Name\n   */\n  readonly name: string;\n\n  /**\n   * Data set that stores the mapping one or more words map to one or more synonyms of those words.\n   *\n   * @schema ApiAtlasFTSSynonymMappingDefinitionView#Source\n   */\n  readonly source: SynonymSource;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsSynonymMappingDefinitionView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsSynonymMappingDefinitionView(\n  obj: ApiAtlasFtsSynonymMappingDefinitionView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Analyzer: obj.analyzer,\n    Name: obj.name,\n    Source: toJson_SynonymSource(obj.source),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Tokenizer that you want to use to create tokens. Tokens determine how Atlas Search splits up text into discrete chunks for indexing.\n *\n * @schema ApiAtlasFTSAnalyzersTokenizer\n */\nexport interface ApiAtlasFtsAnalyzersTokenizer {\n  /**\n   * Characters to include in the longest token that Atlas Search creates.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MaxGram\n   */\n  readonly maxGram?: number;\n\n  /**\n   * Characters to include in the shortest token that Atlas Search creates.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MinGram\n   */\n  readonly minGram?: number;\n\n  /**\n   * Human-readable label that identifies this tokenizer type.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Type\n   */\n  readonly type?: string;\n\n  /**\n   * Index of the character group within the matching expression to extract into tokens. Use `0` to extract all character groups.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Group\n   */\n  readonly group?: number;\n\n  /**\n   * Regular expression to match against.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#Pattern\n   */\n  readonly pattern?: string;\n\n  /**\n   * Maximum number of characters in a single token. Tokens greater than this length are split at this length into multiple tokens.\n   *\n   * @schema ApiAtlasFTSAnalyzersTokenizer#MaxTokenLength\n   */\n  readonly maxTokenLength?: number;\n}\n\n/**\n * Converts an object of type 'ApiAtlasFtsAnalyzersTokenizer' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasFtsAnalyzersTokenizer(\n  obj: ApiAtlasFtsAnalyzersTokenizer | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    MaxGram: obj.maxGram,\n    MinGram: obj.minGram,\n    Type: obj.type,\n    Group: obj.group,\n    Pattern: obj.pattern,\n    MaxTokenLength: obj.maxTokenLength,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema SynonymSource\n */\nexport interface SynonymSource {\n  /**\n   * Human-readable label that identifies the MongoDB collection that stores words and their applicable synonyms.\n   *\n   * @schema SynonymSource#Collection\n   */\n  readonly collection: string;\n}\n\n/**\n * Converts an object of type 'SynonymSource' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_SynonymSource(\n  obj: SynonymSource | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Collection: obj.collection,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::SearchIndex`\n *\n * @cloudformationResource MongoDB::Atlas::SearchIndex\n * @stability external\n */\nexport class CfnSearchIndex extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::SearchIndex\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnSearchIndexProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::SearchIndex.IndexId`\n   */\n  public readonly attrIndexId: string;\n  /**\n   * Attribute `MongoDB::Atlas::SearchIndex.Status`\n   */\n  public readonly attrStatus: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::SearchIndex`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnSearchIndexProps\n  ) {\n    super(scope, id, {\n      type: CfnSearchIndex.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnSearchIndexProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrIndexId = cdk.Token.asString(this.getAtt(\"IndexId\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n  }\n}\n"]}

@@ -150,3 +150,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnServerlessInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnServerlessInstance", version: "3.7.2" };
CfnServerlessInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnServerlessInstance", version: "3.8.0" };
/**

@@ -156,2 +156,2 @@ * The CloudFormation resource type name for this resource class.

CfnServerlessInstance.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::ServerlessInstance";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/serverless-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes serverless instances.\n *\n * @schema CfnServerlessInstanceProps\n */\nexport interface CfnServerlessInstanceProps {\n  /**\n   * Collection of Uniform Resource Locators that point to the MongoDB database.\n   *\n   * @schema CfnServerlessInstanceProps#ConnectionStrings\n   */\n  readonly connectionStrings?: ServerlessInstanceConnectionStrings;\n\n  /**\n   * Flag that indicates whether the serverless instances uses Serverless Continuous Backup. If this parameter is false, the serverless instance uses Basic Backup. | Option | Description | |---|---| | Serverless Continuous Backup | Atlas takes incremental snapshots of the data in your serverless instance every six hours and lets you restore the data from a selected point in time within the last 72 hours. Atlas also takes daily snapshots and retains these daily snapshots for 35 days. To learn more, see Serverless Instance Costs. | | Basic Backup | Atlas takes incremental snapshots of the data in your serverless instance every six hours and retains only the two most recent snapshots. You can use this option for free.\n   *\n   * @schema CfnServerlessInstanceProps#ContinuousBackupEnabled\n   */\n  readonly continuousBackupEnabled?: boolean;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnServerlessInstanceProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnServerlessInstanceProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Human-readable label that identifies the serverless instance.\n   *\n   * @schema CfnServerlessInstanceProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnServerlessInstanceProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnServerlessInstanceProps#ProjectID\n   */\n  readonly projectId?: string;\n\n  /**\n   * Group of settings that configure the provisioned MongoDB serverless instance. The options available relate to the cloud service provider.\n   *\n   * @schema CfnServerlessInstanceProps#ProviderSettings\n   */\n  readonly providerSettings?: ServerlessInstanceProviderSettings;\n\n  /**\n   * Flag that indicates whether termination protection is enabled on the serverless instance. If set to true, MongoDB Cloud won't delete the serverless instance. If set to false, MongoDB cloud will delete the serverless instance.\"\n   *\n   * @schema CfnServerlessInstanceProps#TerminationProtectionEnabled\n   */\n  readonly terminationProtectionEnabled?: boolean;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnServerlessInstanceProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnServerlessInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnServerlessInstanceProps(\n  obj: CfnServerlessInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ConnectionStrings: toJson_ServerlessInstanceConnectionStrings(\n      obj.connectionStrings\n    ),\n    ContinuousBackupEnabled: obj.continuousBackupEnabled,\n    IncludeCount: obj.includeCount,\n    ItemsPerPage: obj.itemsPerPage,\n    Name: obj.name,\n    PageNum: obj.pageNum,\n    ProjectID: obj.projectId,\n    ProviderSettings: toJson_ServerlessInstanceProviderSettings(\n      obj.providerSettings\n    ),\n    TerminationProtectionEnabled: obj.terminationProtectionEnabled,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstanceConnectionStrings\n */\nexport interface ServerlessInstanceConnectionStrings {\n  /**\n   * List of private endpoint connection strings that you can use to connect to this serverless instance through a private endpoint. This parameter returns only if you created a private endpoint for this serverless instance and it is AVAILABLE.\n   *\n   * @schema ServerlessInstanceConnectionStrings#PrivateEndpoint\n   */\n  readonly privateEndpoint?: ServerlessInstancePrivateEndpoint[];\n\n  /**\n   * Public connection string that you can use to connect to this serverless instance. This connection string uses the `mongodb+srv://` protocol.\n   *\n   * @schema ServerlessInstanceConnectionStrings#StandardSrv\n   */\n  readonly standardSrv?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstanceConnectionStrings' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstanceConnectionStrings(\n  obj: ServerlessInstanceConnectionStrings | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PrivateEndpoint: obj.privateEndpoint?.map((y) =>\n      toJson_ServerlessInstancePrivateEndpoint(y)\n    ),\n    StandardSrv: obj.standardSrv,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstanceProviderSettings\n */\nexport interface ServerlessInstanceProviderSettings {\n  /**\n   * Human-readable label that identifies the cloud service provider.\n   *\n   * @schema ServerlessInstanceProviderSettings#ProviderName\n   */\n  readonly providerName?: ServerlessInstanceProviderSettingsProviderName;\n\n  /**\n   * Human-readable label that identifies the geographic location of your MongoDB serverless instance. The region you choose can affect network latency for clients accessing your databases. For a complete list of region names, see [AWS](https://docs.atlas.mongodb.com/reference/amazon-aws/#std-label-amazon-aws), [GCP](https://docs.atlas.mongodb.com/reference/google-gcp/), and [Azure](https://docs.atlas.mongodb.com/reference/microsoft-azure/).\n   *\n   * @schema ServerlessInstanceProviderSettings#RegionName\n   */\n  readonly regionName?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstanceProviderSettings' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstanceProviderSettings(\n  obj: ServerlessInstanceProviderSettings | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProviderName: obj.providerName,\n    RegionName: obj.regionName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstancePrivateEndpoint\n */\nexport interface ServerlessInstancePrivateEndpoint {\n  /**\n   * List that contains the private endpoints through which you connect to MongoDB Cloud when you use **connectionStrings.privateEndpoint[n].srvConnectionString**.\n   *\n   * @schema ServerlessInstancePrivateEndpoint#Endpoints\n   */\n  readonly endpoints?: ServerlessInstancePrivateEndpointEndpoint[];\n\n  /**\n   * Private endpoint-aware connection string that uses the `mongodb+srv://` protocol to connect to MongoDB Cloud through a private endpoint. The `mongodb+srv` protocol tells the driver to look up the seed list of hosts in the Domain Name System (DNS).\n   *\n   * @schema ServerlessInstancePrivateEndpoint#SrvConnectionString\n   */\n  readonly srvConnectionString?: string;\n\n  /**\n   * MongoDB process type to which your application connects.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpoint#Type\n   */\n  readonly type?: ServerlessInstancePrivateEndpointType;\n}\n\n/**\n * Converts an object of type 'ServerlessInstancePrivateEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstancePrivateEndpoint(\n  obj: ServerlessInstancePrivateEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Endpoints: obj.endpoints?.map((y) =>\n      toJson_ServerlessInstancePrivateEndpointEndpoint(y)\n    ),\n    SrvConnectionString: obj.srvConnectionString,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies the cloud service provider.\n *\n * @schema ServerlessInstanceProviderSettingsProviderName\n */\nexport enum ServerlessInstanceProviderSettingsProviderName {\n  /** SERVERLESS */\n  SERVERLESS = \"SERVERLESS\",\n}\n\n/**\n * @schema ServerlessInstancePrivateEndpointEndpoint\n */\nexport interface ServerlessInstancePrivateEndpointEndpoint {\n  /**\n   * Unique provider identifier of the private endpoint.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#EndpointId\n   */\n  readonly endpointId?: string;\n\n  /**\n   * Cloud provider where the private endpoint is deployed.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#ProviderName\n   */\n  readonly providerName?: string;\n\n  /**\n   * Region where the private endpoint is deployed.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstancePrivateEndpointEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstancePrivateEndpointEndpoint(\n  obj: ServerlessInstancePrivateEndpointEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    EndpointId: obj.endpointId,\n    ProviderName: obj.providerName,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * MongoDB process type to which your application connects.\n *\n *\n * @schema ServerlessInstancePrivateEndpointType\n */\nexport enum ServerlessInstancePrivateEndpointType {\n  /** MONGOS */\n  MONGOS = \"MONGOS\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::ServerlessInstance`\n *\n * @cloudformationResource MongoDB::Atlas::ServerlessInstance\n * @stability external\n */\nexport class CfnServerlessInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ServerlessInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnServerlessInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.CreateDate`\n   */\n  public readonly attrCreateDate: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.StateName`\n   */\n  public readonly attrStateName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.MongoDBVersion`\n   */\n  public readonly attrMongoDBVersion: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::ServerlessInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnServerlessInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnServerlessInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnServerlessInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrCreateDate = cdk.Token.asString(this.getAtt(\"CreateDate\"));\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n    this.attrStateName = cdk.Token.asString(this.getAtt(\"StateName\"));\n    this.attrMongoDBVersion = cdk.Token.asString(this.getAtt(\"MongoDBVersion\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/serverless-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes serverless instances.\n *\n * @schema CfnServerlessInstanceProps\n */\nexport interface CfnServerlessInstanceProps {\n  /**\n   * Collection of Uniform Resource Locators that point to the MongoDB database.\n   *\n   * @schema CfnServerlessInstanceProps#ConnectionStrings\n   */\n  readonly connectionStrings?: ServerlessInstanceConnectionStrings;\n\n  /**\n   * Flag that indicates whether the serverless instances uses Serverless Continuous Backup. If this parameter is false, the serverless instance uses Basic Backup. | Option | Description | |---|---| | Serverless Continuous Backup | Atlas takes incremental snapshots of the data in your serverless instance every six hours and lets you restore the data from a selected point in time within the last 72 hours. Atlas also takes daily snapshots and retains these daily snapshots for 35 days. To learn more, see Serverless Instance Costs. | | Basic Backup | Atlas takes incremental snapshots of the data in your serverless instance every six hours and retains only the two most recent snapshots. You can use this option for free.\n   *\n   * @schema CfnServerlessInstanceProps#ContinuousBackupEnabled\n   */\n  readonly continuousBackupEnabled?: boolean;\n\n  /**\n   * Flag that indicates whether the response returns the total number of items (**totalCount**) in the response.\n   *\n   * @schema CfnServerlessInstanceProps#IncludeCount\n   */\n  readonly includeCount?: boolean;\n\n  /**\n   * Number of items that the response returns per page.\n   *\n   * @schema CfnServerlessInstanceProps#ItemsPerPage\n   */\n  readonly itemsPerPage?: number;\n\n  /**\n   * Human-readable label that identifies the serverless instance.\n   *\n   * @schema CfnServerlessInstanceProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Number of the page that displays the current set of the total objects that the response returns.\n   *\n   * @schema CfnServerlessInstanceProps#PageNum\n   */\n  readonly pageNum?: number;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnServerlessInstanceProps#ProjectID\n   */\n  readonly projectId?: string;\n\n  /**\n   * Group of settings that configure the provisioned MongoDB serverless instance. The options available relate to the cloud service provider.\n   *\n   * @schema CfnServerlessInstanceProps#ProviderSettings\n   */\n  readonly providerSettings?: ServerlessInstanceProviderSettings;\n\n  /**\n   * Flag that indicates whether termination protection is enabled on the serverless instance. If set to true, MongoDB Cloud won't delete the serverless instance. If set to false, MongoDB cloud will delete the serverless instance.\"\n   *\n   * @schema CfnServerlessInstanceProps#TerminationProtectionEnabled\n   */\n  readonly terminationProtectionEnabled?: boolean;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnServerlessInstanceProps#Profile\n   */\n  readonly profile?: string;\n}\n\n/**\n * Converts an object of type 'CfnServerlessInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnServerlessInstanceProps(\n  obj: CfnServerlessInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ConnectionStrings: toJson_ServerlessInstanceConnectionStrings(\n      obj.connectionStrings\n    ),\n    ContinuousBackupEnabled: obj.continuousBackupEnabled,\n    IncludeCount: obj.includeCount,\n    ItemsPerPage: obj.itemsPerPage,\n    Name: obj.name,\n    PageNum: obj.pageNum,\n    ProjectID: obj.projectId,\n    ProviderSettings: toJson_ServerlessInstanceProviderSettings(\n      obj.providerSettings\n    ),\n    TerminationProtectionEnabled: obj.terminationProtectionEnabled,\n    Profile: obj.profile,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstanceConnectionStrings\n */\nexport interface ServerlessInstanceConnectionStrings {\n  /**\n   * List of private endpoint connection strings that you can use to connect to this serverless instance through a private endpoint. This parameter returns only if you created a private endpoint for this serverless instance and it is AVAILABLE.\n   *\n   * @schema ServerlessInstanceConnectionStrings#PrivateEndpoint\n   */\n  readonly privateEndpoint?: ServerlessInstancePrivateEndpoint[];\n\n  /**\n   * Public connection string that you can use to connect to this serverless instance. This connection string uses the `mongodb+srv://` protocol.\n   *\n   * @schema ServerlessInstanceConnectionStrings#StandardSrv\n   */\n  readonly standardSrv?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstanceConnectionStrings' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstanceConnectionStrings(\n  obj: ServerlessInstanceConnectionStrings | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    PrivateEndpoint: obj.privateEndpoint?.map((y) =>\n      toJson_ServerlessInstancePrivateEndpoint(y)\n    ),\n    StandardSrv: obj.standardSrv,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstanceProviderSettings\n */\nexport interface ServerlessInstanceProviderSettings {\n  /**\n   * Human-readable label that identifies the cloud service provider.\n   *\n   * @schema ServerlessInstanceProviderSettings#ProviderName\n   */\n  readonly providerName?: ServerlessInstanceProviderSettingsProviderName;\n\n  /**\n   * Human-readable label that identifies the geographic location of your MongoDB serverless instance. The region you choose can affect network latency for clients accessing your databases. For a complete list of region names, see [AWS](https://docs.atlas.mongodb.com/reference/amazon-aws/#std-label-amazon-aws), [GCP](https://docs.atlas.mongodb.com/reference/google-gcp/), and [Azure](https://docs.atlas.mongodb.com/reference/microsoft-azure/).\n   *\n   * @schema ServerlessInstanceProviderSettings#RegionName\n   */\n  readonly regionName?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstanceProviderSettings' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstanceProviderSettings(\n  obj: ServerlessInstanceProviderSettings | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProviderName: obj.providerName,\n    RegionName: obj.regionName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ServerlessInstancePrivateEndpoint\n */\nexport interface ServerlessInstancePrivateEndpoint {\n  /**\n   * List that contains the private endpoints through which you connect to MongoDB Cloud when you use **connectionStrings.privateEndpoint[n].srvConnectionString**.\n   *\n   * @schema ServerlessInstancePrivateEndpoint#Endpoints\n   */\n  readonly endpoints?: ServerlessInstancePrivateEndpointEndpoint[];\n\n  /**\n   * Private endpoint-aware connection string that uses the `mongodb+srv://` protocol to connect to MongoDB Cloud through a private endpoint. The `mongodb+srv` protocol tells the driver to look up the seed list of hosts in the Domain Name System (DNS).\n   *\n   * @schema ServerlessInstancePrivateEndpoint#SrvConnectionString\n   */\n  readonly srvConnectionString?: string;\n\n  /**\n   * MongoDB process type to which your application connects.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpoint#Type\n   */\n  readonly type?: ServerlessInstancePrivateEndpointType;\n}\n\n/**\n * Converts an object of type 'ServerlessInstancePrivateEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstancePrivateEndpoint(\n  obj: ServerlessInstancePrivateEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Endpoints: obj.endpoints?.map((y) =>\n      toJson_ServerlessInstancePrivateEndpointEndpoint(y)\n    ),\n    SrvConnectionString: obj.srvConnectionString,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies the cloud service provider.\n *\n * @schema ServerlessInstanceProviderSettingsProviderName\n */\nexport enum ServerlessInstanceProviderSettingsProviderName {\n  /** SERVERLESS */\n  SERVERLESS = \"SERVERLESS\",\n}\n\n/**\n * @schema ServerlessInstancePrivateEndpointEndpoint\n */\nexport interface ServerlessInstancePrivateEndpointEndpoint {\n  /**\n   * Unique provider identifier of the private endpoint.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#EndpointId\n   */\n  readonly endpointId?: string;\n\n  /**\n   * Cloud provider where the private endpoint is deployed.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#ProviderName\n   */\n  readonly providerName?: string;\n\n  /**\n   * Region where the private endpoint is deployed.\n   *\n   *\n   * @schema ServerlessInstancePrivateEndpointEndpoint#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'ServerlessInstancePrivateEndpointEndpoint' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ServerlessInstancePrivateEndpointEndpoint(\n  obj: ServerlessInstancePrivateEndpointEndpoint | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    EndpointId: obj.endpointId,\n    ProviderName: obj.providerName,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * MongoDB process type to which your application connects.\n *\n *\n * @schema ServerlessInstancePrivateEndpointType\n */\nexport enum ServerlessInstancePrivateEndpointType {\n  /** MONGOS */\n  MONGOS = \"MONGOS\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::ServerlessInstance`\n *\n * @cloudformationResource MongoDB::Atlas::ServerlessInstance\n * @stability external\n */\nexport class CfnServerlessInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ServerlessInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnServerlessInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.CreateDate`\n   */\n  public readonly attrCreateDate: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.StateName`\n   */\n  public readonly attrStateName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessInstance.MongoDBVersion`\n   */\n  public readonly attrMongoDBVersion: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::ServerlessInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnServerlessInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnServerlessInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnServerlessInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrCreateDate = cdk.Token.asString(this.getAtt(\"CreateDate\"));\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n    this.attrStateName = cdk.Token.asString(this.getAtt(\"StateName\"));\n    this.attrMongoDBVersion = cdk.Token.asString(this.getAtt(\"MongoDBVersion\"));\n  }\n}\n"]}

@@ -151,42 +151,1 @@ import * as cdk from "aws-cdk-lib";

}
/**
* @schema PrivateEndpoint
*/
export interface ServerlessPrivateEndpoint {
/**
* String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)
*
* @schema PrivateEndpoint#VpcId
*/
readonly vpcId?: string;
/**
* List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)
*
* @schema PrivateEndpoint#SubnetIds
*/
readonly subnetIds?: string[];
/**
* Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.
*
* @schema PrivateEndpoint#InterfaceEndpointId
*/
readonly interfaceEndpointId?: string;
/**
* string to represent the comment
* @schema PrivateEndpoint#comment
*/
readonly comment?: string;
/**
* Status of the AWS PrivateEndpoint connection.
*
* @schema PrivateEndpoint#AWSPrivateEndpointStatus
*/
readonly awsPrivateEndpointStatus?: string;
/**
* Status of the Atlas PrivateEndpoint connection.
*
* @schema PrivateEndpoint#AtlasPrivateEndpointStatus
*/
readonly atlasPrivateEndpointStatus?: string;
readonly createAndAssignAWSPrivateEndpoint?: boolean;
}

@@ -80,3 +80,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnServerlessPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnServerlessPrivateEndpoint", version: "3.7.2" };
CfnServerlessPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnServerlessPrivateEndpoint", version: "3.8.0" };
/**

@@ -86,2 +86,2 @@ * The CloudFormation resource type name for this resource class.

CfnServerlessPrivateEndpoint.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::ServerlessPrivateEndpoint";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/serverless-private-endpoint/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes private endpoints for serverless instances. To learn more, see the Atlas Administration API tab on the following tutorial.\n *\n * @schema CfnServerlessPrivateEndpointProps\n */\nexport interface CfnServerlessPrivateEndpointProps {\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the serverless instance for which the tenant endpoint will be created.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * Human-readable comment associated with the private endpoint.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#Comment\n   */\n  readonly comment?: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnServerlessPrivateEndpointProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique string that identifies the private endpoint's network interface.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#CloudProviderEndpointId\n   */\n  readonly cloudProviderEndpointId?: string;\n\n  /**\n   * IPv4 address of the private endpoint in your Azure VNet that someone added to this private endpoint service.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#PrivateEndpointIpAddress\n   */\n  readonly privateEndpointIpAddress?: string;\n\n  /**\n   * If true the resource will create the aws private endpoint and assign the Endpoint ID\n   *\n   * @schema CfnServerlessPrivateEndpointProps#CreateAndAssignAWSPrivateEndpoint\n   */\n  readonly createAndAssignAwsPrivateEndpoint?: boolean;\n\n  /**\n   * Properties used to configure Aws private endpoint\n   *\n   * @schema CfnServerlessPrivateEndpointProps#AwsPrivateEndpointConfigurationProperties\n   */\n  readonly awsPrivateEndpointConfigurationProperties?: AwsPrivateEndpointConfig;\n}\n\n/**\n * Converts an object of type 'CfnServerlessPrivateEndpointProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnServerlessPrivateEndpointProps(\n  obj: CfnServerlessPrivateEndpointProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    InstanceName: obj.instanceName,\n    Comment: obj.comment,\n    Profile: obj.profile,\n    CloudProviderEndpointId: obj.cloudProviderEndpointId,\n    PrivateEndpointIpAddress: obj.privateEndpointIpAddress,\n    CreateAndAssignAWSPrivateEndpoint: obj.createAndAssignAwsPrivateEndpoint,\n    AwsPrivateEndpointConfigurationProperties: toJson_AwsPrivateEndpointConfig(\n      obj.awsPrivateEndpointConfigurationProperties\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * AWS Private endpoint configuration properties\n *\n * @schema awsPrivateEndpointConfig\n */\nexport interface AwsPrivateEndpointConfig {\n  /**\n   * String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema awsPrivateEndpointConfig#VpcId\n   */\n  readonly vpcId?: string;\n\n  /**\n   * List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema awsPrivateEndpointConfig#SubnetIds\n   */\n  readonly subnetIds?: string[];\n\n  /**\n   * Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.\n   *\n   * @schema awsPrivateEndpointConfig#InterfaceEndpointId\n   */\n  readonly interfaceEndpointId?: string;\n\n  /**\n   * Status of the AWS PrivateEndpoint connection.\n   *\n   * @schema awsPrivateEndpointConfig#AWSPrivateEndpointStatus\n   */\n  readonly awsPrivateEndpointStatus?: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema awsPrivateEndpointConfig#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'AwsPrivateEndpointConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AwsPrivateEndpointConfig(\n  obj: AwsPrivateEndpointConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    VpcId: obj.vpcId,\n    SubnetIds: obj.subnetIds?.map((y) => y),\n    InterfaceEndpointId: obj.interfaceEndpointId,\n    AWSPrivateEndpointStatus: obj.awsPrivateEndpointStatus,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::ServerlessPrivateEndpoint`\n *\n * @cloudformationResource MongoDB::Atlas::ServerlessPrivateEndpoint\n * @stability external\n */\nexport class CfnServerlessPrivateEndpoint extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ServerlessPrivateEndpoint\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnServerlessPrivateEndpointProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.EndpointServiceName`\n   */\n  public readonly attrEndpointServiceName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.ErrorMessage`\n   */\n  public readonly attrErrorMessage: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.ProviderName`\n   */\n  public readonly attrProviderName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.Status`\n   */\n  public readonly attrStatus: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.AwsPrivateEndpointMetaData`\n   */\n  public readonly attrAwsPrivateEndpointMetaData: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::ServerlessPrivateEndpoint`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnServerlessPrivateEndpointProps\n  ) {\n    super(scope, id, {\n      type: CfnServerlessPrivateEndpoint.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnServerlessPrivateEndpointProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEndpointServiceName = cdk.Token.asString(\n      this.getAtt(\"EndpointServiceName\")\n    );\n    this.attrErrorMessage = cdk.Token.asString(this.getAtt(\"ErrorMessage\"));\n    this.attrProviderName = cdk.Token.asString(this.getAtt(\"ProviderName\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n    this.attrAwsPrivateEndpointMetaData = cdk.Token.asString(\n      this.getAtt(\"AwsPrivateEndpointMetaData\")\n    );\n  }\n}\n\n/**\n * @schema PrivateEndpoint\n */\nexport interface ServerlessPrivateEndpoint {\n  /**\n   * String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#VpcId\n   */\n  readonly vpcId?: string;\n\n  /**\n   * List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema PrivateEndpoint#SubnetIds\n   */\n  readonly subnetIds?: string[];\n\n  /**\n   * Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.\n   *\n   * @schema PrivateEndpoint#InterfaceEndpointId\n   */\n  readonly interfaceEndpointId?: string;\n\n  /**\n   * string to represent the comment\n   * @schema PrivateEndpoint#comment\n   */\n  readonly comment?: string;\n\n  /**\n   * Status of the AWS PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AWSPrivateEndpointStatus\n   */\n  readonly awsPrivateEndpointStatus?: string;\n\n  /**\n   * Status of the Atlas PrivateEndpoint connection.\n   *\n   * @schema PrivateEndpoint#AtlasPrivateEndpointStatus\n   */\n  readonly atlasPrivateEndpointStatus?: string;\n\n  readonly createAndAssignAWSPrivateEndpoint?: boolean;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/serverless-private-endpoint/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes private endpoints for serverless instances. To learn more, see the Atlas Administration API tab on the following tutorial.\n *\n * @schema CfnServerlessPrivateEndpointProps\n */\nexport interface CfnServerlessPrivateEndpointProps {\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Human-readable label that identifies the serverless instance for which the tenant endpoint will be created.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * Human-readable comment associated with the private endpoint.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#Comment\n   */\n  readonly comment?: string;\n\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnServerlessPrivateEndpointProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Unique string that identifies the private endpoint's network interface.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#CloudProviderEndpointId\n   */\n  readonly cloudProviderEndpointId?: string;\n\n  /**\n   * IPv4 address of the private endpoint in your Azure VNet that someone added to this private endpoint service.\n   *\n   * @schema CfnServerlessPrivateEndpointProps#PrivateEndpointIpAddress\n   */\n  readonly privateEndpointIpAddress?: string;\n\n  /**\n   * If true the resource will create the aws private endpoint and assign the Endpoint ID\n   *\n   * @schema CfnServerlessPrivateEndpointProps#CreateAndAssignAWSPrivateEndpoint\n   */\n  readonly createAndAssignAwsPrivateEndpoint?: boolean;\n\n  /**\n   * Properties used to configure Aws private endpoint\n   *\n   * @schema CfnServerlessPrivateEndpointProps#AwsPrivateEndpointConfigurationProperties\n   */\n  readonly awsPrivateEndpointConfigurationProperties?: AwsPrivateEndpointConfig;\n}\n\n/**\n * Converts an object of type 'CfnServerlessPrivateEndpointProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnServerlessPrivateEndpointProps(\n  obj: CfnServerlessPrivateEndpointProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    InstanceName: obj.instanceName,\n    Comment: obj.comment,\n    Profile: obj.profile,\n    CloudProviderEndpointId: obj.cloudProviderEndpointId,\n    PrivateEndpointIpAddress: obj.privateEndpointIpAddress,\n    CreateAndAssignAWSPrivateEndpoint: obj.createAndAssignAwsPrivateEndpoint,\n    AwsPrivateEndpointConfigurationProperties: toJson_AwsPrivateEndpointConfig(\n      obj.awsPrivateEndpointConfigurationProperties\n    ),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * AWS Private endpoint configuration properties\n *\n * @schema awsPrivateEndpointConfig\n */\nexport interface AwsPrivateEndpointConfig {\n  /**\n   * String Representing the AWS VPC ID (like: vpc-xxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema awsPrivateEndpointConfig#VpcId\n   */\n  readonly vpcId?: string;\n\n  /**\n   * List of string representing the AWS VPC Subnet ID (like: subnet-xxxxxxxxxxxxxxxxx) (Used For Creating the AWS VPC Endpoint)\n   *\n   * @schema awsPrivateEndpointConfig#SubnetIds\n   */\n  readonly subnetIds?: string[];\n\n  /**\n   * Unique identifiers of the interface endpoints in your VPC that you added to the AWS PrivateLink connection.\n   *\n   * @schema awsPrivateEndpointConfig#InterfaceEndpointId\n   */\n  readonly interfaceEndpointId?: string;\n\n  /**\n   * Status of the AWS PrivateEndpoint connection.\n   *\n   * @schema awsPrivateEndpointConfig#AWSPrivateEndpointStatus\n   */\n  readonly awsPrivateEndpointStatus?: string;\n\n  /**\n   * Aws Region\n   *\n   * @schema awsPrivateEndpointConfig#Region\n   */\n  readonly region?: string;\n}\n\n/**\n * Converts an object of type 'AwsPrivateEndpointConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AwsPrivateEndpointConfig(\n  obj: AwsPrivateEndpointConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    VpcId: obj.vpcId,\n    SubnetIds: obj.subnetIds?.map((y) => y),\n    InterfaceEndpointId: obj.interfaceEndpointId,\n    AWSPrivateEndpointStatus: obj.awsPrivateEndpointStatus,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::ServerlessPrivateEndpoint`\n *\n * @cloudformationResource MongoDB::Atlas::ServerlessPrivateEndpoint\n * @stability external\n */\nexport class CfnServerlessPrivateEndpoint extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::ServerlessPrivateEndpoint\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnServerlessPrivateEndpointProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.EndpointServiceName`\n   */\n  public readonly attrEndpointServiceName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.ErrorMessage`\n   */\n  public readonly attrErrorMessage: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.ProviderName`\n   */\n  public readonly attrProviderName: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.Status`\n   */\n  public readonly attrStatus: string;\n  /**\n   * Attribute `MongoDB::Atlas::ServerlessPrivateEndpoint.AwsPrivateEndpointMetaData`\n   */\n  public readonly attrAwsPrivateEndpointMetaData: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::ServerlessPrivateEndpoint`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnServerlessPrivateEndpointProps\n  ) {\n    super(scope, id, {\n      type: CfnServerlessPrivateEndpoint.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnServerlessPrivateEndpointProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrEndpointServiceName = cdk.Token.asString(\n      this.getAtt(\"EndpointServiceName\")\n    );\n    this.attrErrorMessage = cdk.Token.asString(this.getAtt(\"ErrorMessage\"));\n    this.attrProviderName = cdk.Token.asString(this.getAtt(\"ProviderName\"));\n    this.attrStatus = cdk.Token.asString(this.getAtt(\"Status\"));\n    this.attrAwsPrivateEndpointMetaData = cdk.Token.asString(\n      this.getAtt(\"AwsPrivateEndpointMetaData\")\n    );\n  }\n}\n"]}

@@ -134,3 +134,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnStreamConnection[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamConnection", version: "3.7.2" };
CfnStreamConnection[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamConnection", version: "3.8.0" };
/**

@@ -137,0 +137,0 @@ * The CloudFormation resource type name for this resource class.

@@ -235,3 +235,3 @@ import * as cdk from "aws-cdk-lib";

/** BUILT_IN */
BUILT_UNDERSCORE_IN = "BUILT_IN",
BUILT_IN = "BUILT_IN",
/** CUSTOM */

@@ -238,0 +238,0 @@ CUSTOM = "CUSTOM"

@@ -170,3 +170,3 @@ "use strict";

/** BUILT_IN */
DbRoleToExecuteType["BUILT_UNDERSCORE_IN"] = "BUILT_IN";
DbRoleToExecuteType["BUILT_IN"] = "BUILT_IN";
/** CUSTOM */

@@ -201,3 +201,3 @@ DbRoleToExecuteType["CUSTOM"] = "CUSTOM";

_a = JSII_RTTI_SYMBOL_1;
CfnStreamInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamInstance", version: "3.7.2" };
CfnStreamInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamInstance", version: "3.8.0" };
/**

@@ -207,2 +207,2 @@ * The CloudFormation resource type name for this resource class.

CfnStreamInstance.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::StreamInstance";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/stream-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Atlas Stream Processing Instances.\n *\n * @schema CfnStreamInstanceProps\n */\nexport interface CfnStreamInstanceProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnStreamInstanceProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Human-readable label that identifies the stream connection.\n   *\n   * @schema CfnStreamInstanceProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * @schema CfnStreamInstanceProps#DataProcessRegion\n   */\n  readonly dataProcessRegion: StreamsDataProcessRegion;\n\n  /**\n   * @schema CfnStreamInstanceProps#StreamConfig\n   */\n  readonly streamConfig: StreamConfig;\n\n  /**\n   * @schema CfnStreamInstanceProps#Connections\n   */\n  readonly connections?: StreamsConnection[];\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the project.\n   *\n   * @schema CfnStreamInstanceProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnStreamInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnStreamInstanceProps(\n  obj: CfnStreamInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    InstanceName: obj.instanceName,\n    DataProcessRegion: toJson_StreamsDataProcessRegion(obj.dataProcessRegion),\n    StreamConfig: toJson_StreamConfig(obj.streamConfig),\n    Connections: obj.connections?.map((y) => toJson_StreamsConnection(y)),\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Information about the cloud provider region in which MongoDB Cloud processes the stream.\n *\n * @schema StreamsDataProcessRegion\n */\nexport interface StreamsDataProcessRegion {\n  /**\n   * Label that identifies the cloud service provider where MongoDB Cloud performs stream processing. Currently, this parameter supports AWS only.\n   *\n   * @schema StreamsDataProcessRegion#CloudProvider\n   */\n  readonly cloudProvider: StreamsDataProcessRegionCloudProvider;\n\n  /**\n   * @schema StreamsDataProcessRegion#Region\n   */\n  readonly region: string;\n}\n\n/**\n * Converts an object of type 'StreamsDataProcessRegion' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsDataProcessRegion(\n  obj: StreamsDataProcessRegion | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Configuration options for an Atlas Stream Processing Instance.\n *\n * @schema StreamConfig\n */\nexport interface StreamConfig {\n  /**\n   * Selected tier for the Stream Instance. Configures Memory / VCPU allowances.\n   *\n   * @schema StreamConfig#Tier\n   */\n  readonly tier?: string;\n}\n\n/**\n * Converts an object of type 'StreamConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamConfig(\n  obj: StreamConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Tier: obj.tier,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Settings that define a connection to an external data store.\n *\n * @schema StreamsConnection\n */\nexport interface StreamsConnection {\n  /**\n   * Human-readable label that identifies the stream connection.\n   *\n   * @schema StreamsConnection#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Type of the connection. Can be either Cluster or Kafka.\n   *\n   * @schema StreamsConnection#Type\n   */\n  readonly type?: StreamsConnectionType;\n\n  /**\n   * @schema StreamsConnection#Authentication\n   */\n  readonly authentication?: StreamsKafkaAuthentication;\n\n  /**\n   * Comma separated list of server addresses.\n   *\n   * @schema StreamsConnection#BootstrapServers\n   */\n  readonly bootstrapServers?: string;\n\n  /**\n   * @schema StreamsConnection#Security\n   */\n  readonly security?: StreamsKafkaSecurity;\n\n  /**\n   * Name of the cluster configured for this connection.\n   *\n   * @schema StreamsConnection#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * @schema StreamsConnection#DbRoleToExecute\n   */\n  readonly dbRoleToExecute?: DbRoleToExecute;\n}\n\n/**\n * Converts an object of type 'StreamsConnection' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsConnection(\n  obj: StreamsConnection | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Type: obj.type,\n    Authentication: toJson_StreamsKafkaAuthentication(obj.authentication),\n    BootstrapServers: obj.bootstrapServers,\n    Security: toJson_StreamsKafkaSecurity(obj.security),\n    ClusterName: obj.clusterName,\n    DbRoleToExecute: toJson_DbRoleToExecute(obj.dbRoleToExecute),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Label that identifies the cloud service provider where MongoDB Cloud performs stream processing. Currently, this parameter supports AWS only.\n *\n * @schema StreamsDataProcessRegionCloudProvider\n */\nexport enum StreamsDataProcessRegionCloudProvider {\n  /** AWS */\n  AWS = \"AWS\",\n  /** GCP */\n  GCP = \"GCP\",\n  /** AZURE */\n  AZURE = \"AZURE\",\n  /** TENANT */\n  TENANT = \"TENANT\",\n  /** SERVERLESS */\n  SERVERLESS = \"SERVERLESS\",\n}\n\n/**\n * Type of the connection. Can be either Cluster or Kafka.\n *\n * @schema StreamsConnectionType\n */\nexport enum StreamsConnectionType {\n  /** Kafka */\n  KAFKA = \"Kafka\",\n  /** Cluster */\n  CLUSTER = \"Cluster\",\n  /** Sample */\n  SAMPLE = \"Sample\",\n}\n\n/**\n * User credentials required to connect to a Kafka Cluster. Includes the authentication type, as well as the parameters for that authentication mode.\n *\n * @schema StreamsKafkaAuthentication\n */\nexport interface StreamsKafkaAuthentication {\n  /**\n   * Style of authentication. Can be one of PLAIN, SCRAM-256, or SCRAM-512.\n   *\n   * @schema StreamsKafkaAuthentication#Mechanism\n   */\n  readonly mechanism?: string;\n\n  /**\n   * Username of the account to connect to the Kafka cluster.\n   *\n   * @schema StreamsKafkaAuthentication#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'StreamsKafkaAuthentication' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsKafkaAuthentication(\n  obj: StreamsKafkaAuthentication | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Mechanism: obj.mechanism,\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Properties for the secure transport connection to Kafka. For SSL, this can include the trusted certificate to use.\n *\n * @schema StreamsKafkaSecurity\n */\nexport interface StreamsKafkaSecurity {\n  /**\n   * A trusted, public x509 certificate for connecting to Kafka over SSL.\n   *\n   * @schema StreamsKafkaSecurity#BrokerPublicCertificate\n   */\n  readonly brokerPublicCertificate?: string;\n\n  /**\n   * Describes the transport type. Can be either PLAINTEXT or SSL.\n   *\n   * @schema StreamsKafkaSecurity#Protocol\n   */\n  readonly protocol?: string;\n}\n\n/**\n * Converts an object of type 'StreamsKafkaSecurity' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsKafkaSecurity(\n  obj: StreamsKafkaSecurity | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    BrokerPublicCertificate: obj.brokerPublicCertificate,\n    Protocol: obj.protocol,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * The name of a Built in or Custom DB Role to connect to an Atlas Cluster.\n *\n * @schema DBRoleToExecute\n */\nexport interface DbRoleToExecute {\n  /**\n   * The name of the role to use. Can be a built in role or a custom role.\n   *\n   * @schema DBRoleToExecute#Role\n   */\n  readonly role?: string;\n\n  /**\n   * Type of the DB role. Can be either BuiltIn or Custom.\n   *\n   * @schema DBRoleToExecute#Type\n   */\n  readonly type?: DbRoleToExecuteType;\n}\n\n/**\n * Converts an object of type 'DbRoleToExecute' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DbRoleToExecute(\n  obj: DbRoleToExecute | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Role: obj.role,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Type of the DB role. Can be either BuiltIn or Custom.\n *\n * @schema DbRoleToExecuteType\n */\nexport enum DbRoleToExecuteType {\n  /** BUILT_IN */\n  BUILT_UNDERSCORE_IN = \"BUILT_IN\",\n  /** CUSTOM */\n  CUSTOM = \"CUSTOM\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::StreamInstance`\n *\n * @cloudformationResource MongoDB::Atlas::StreamInstance\n * @stability external\n */\nexport class CfnStreamInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::StreamInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnStreamInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::StreamInstance.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::StreamInstance.Hostnames`\n   */\n  public readonly attrHostnames: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::StreamInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnStreamInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnStreamInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnStreamInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrHostnames = cdk.Token.asList(this.getAtt(\"Hostnames\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/stream-instance/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, adds, edits, and removes Atlas Stream Processing Instances.\n *\n * @schema CfnStreamInstanceProps\n */\nexport interface CfnStreamInstanceProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnStreamInstanceProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Human-readable label that identifies the stream connection.\n   *\n   * @schema CfnStreamInstanceProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * @schema CfnStreamInstanceProps#DataProcessRegion\n   */\n  readonly dataProcessRegion: StreamsDataProcessRegion;\n\n  /**\n   * @schema CfnStreamInstanceProps#StreamConfig\n   */\n  readonly streamConfig: StreamConfig;\n\n  /**\n   * @schema CfnStreamInstanceProps#Connections\n   */\n  readonly connections?: StreamsConnection[];\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the project.\n   *\n   * @schema CfnStreamInstanceProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnStreamInstanceProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnStreamInstanceProps(\n  obj: CfnStreamInstanceProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    InstanceName: obj.instanceName,\n    DataProcessRegion: toJson_StreamsDataProcessRegion(obj.dataProcessRegion),\n    StreamConfig: toJson_StreamConfig(obj.streamConfig),\n    Connections: obj.connections?.map((y) => toJson_StreamsConnection(y)),\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Information about the cloud provider region in which MongoDB Cloud processes the stream.\n *\n * @schema StreamsDataProcessRegion\n */\nexport interface StreamsDataProcessRegion {\n  /**\n   * Label that identifies the cloud service provider where MongoDB Cloud performs stream processing. Currently, this parameter supports AWS only.\n   *\n   * @schema StreamsDataProcessRegion#CloudProvider\n   */\n  readonly cloudProvider: StreamsDataProcessRegionCloudProvider;\n\n  /**\n   * @schema StreamsDataProcessRegion#Region\n   */\n  readonly region: string;\n}\n\n/**\n * Converts an object of type 'StreamsDataProcessRegion' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsDataProcessRegion(\n  obj: StreamsDataProcessRegion | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    CloudProvider: obj.cloudProvider,\n    Region: obj.region,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Configuration options for an Atlas Stream Processing Instance.\n *\n * @schema StreamConfig\n */\nexport interface StreamConfig {\n  /**\n   * Selected tier for the Stream Instance. Configures Memory / VCPU allowances.\n   *\n   * @schema StreamConfig#Tier\n   */\n  readonly tier?: string;\n}\n\n/**\n * Converts an object of type 'StreamConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamConfig(\n  obj: StreamConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Tier: obj.tier,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Settings that define a connection to an external data store.\n *\n * @schema StreamsConnection\n */\nexport interface StreamsConnection {\n  /**\n   * Human-readable label that identifies the stream connection.\n   *\n   * @schema StreamsConnection#Name\n   */\n  readonly name?: string;\n\n  /**\n   * Type of the connection. Can be either Cluster or Kafka.\n   *\n   * @schema StreamsConnection#Type\n   */\n  readonly type?: StreamsConnectionType;\n\n  /**\n   * @schema StreamsConnection#Authentication\n   */\n  readonly authentication?: StreamsKafkaAuthentication;\n\n  /**\n   * Comma separated list of server addresses.\n   *\n   * @schema StreamsConnection#BootstrapServers\n   */\n  readonly bootstrapServers?: string;\n\n  /**\n   * @schema StreamsConnection#Security\n   */\n  readonly security?: StreamsKafkaSecurity;\n\n  /**\n   * Name of the cluster configured for this connection.\n   *\n   * @schema StreamsConnection#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * @schema StreamsConnection#DbRoleToExecute\n   */\n  readonly dbRoleToExecute?: DbRoleToExecute;\n}\n\n/**\n * Converts an object of type 'StreamsConnection' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsConnection(\n  obj: StreamsConnection | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Name: obj.name,\n    Type: obj.type,\n    Authentication: toJson_StreamsKafkaAuthentication(obj.authentication),\n    BootstrapServers: obj.bootstrapServers,\n    Security: toJson_StreamsKafkaSecurity(obj.security),\n    ClusterName: obj.clusterName,\n    DbRoleToExecute: toJson_DbRoleToExecute(obj.dbRoleToExecute),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Label that identifies the cloud service provider where MongoDB Cloud performs stream processing. Currently, this parameter supports AWS only.\n *\n * @schema StreamsDataProcessRegionCloudProvider\n */\nexport enum StreamsDataProcessRegionCloudProvider {\n  /** AWS */\n  AWS = \"AWS\",\n  /** GCP */\n  GCP = \"GCP\",\n  /** AZURE */\n  AZURE = \"AZURE\",\n  /** TENANT */\n  TENANT = \"TENANT\",\n  /** SERVERLESS */\n  SERVERLESS = \"SERVERLESS\",\n}\n\n/**\n * Type of the connection. Can be either Cluster or Kafka.\n *\n * @schema StreamsConnectionType\n */\nexport enum StreamsConnectionType {\n  /** Kafka */\n  KAFKA = \"Kafka\",\n  /** Cluster */\n  CLUSTER = \"Cluster\",\n  /** Sample */\n  SAMPLE = \"Sample\",\n}\n\n/**\n * User credentials required to connect to a Kafka Cluster. Includes the authentication type, as well as the parameters for that authentication mode.\n *\n * @schema StreamsKafkaAuthentication\n */\nexport interface StreamsKafkaAuthentication {\n  /**\n   * Style of authentication. Can be one of PLAIN, SCRAM-256, or SCRAM-512.\n   *\n   * @schema StreamsKafkaAuthentication#Mechanism\n   */\n  readonly mechanism?: string;\n\n  /**\n   * Username of the account to connect to the Kafka cluster.\n   *\n   * @schema StreamsKafkaAuthentication#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'StreamsKafkaAuthentication' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsKafkaAuthentication(\n  obj: StreamsKafkaAuthentication | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Mechanism: obj.mechanism,\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Properties for the secure transport connection to Kafka. For SSL, this can include the trusted certificate to use.\n *\n * @schema StreamsKafkaSecurity\n */\nexport interface StreamsKafkaSecurity {\n  /**\n   * A trusted, public x509 certificate for connecting to Kafka over SSL.\n   *\n   * @schema StreamsKafkaSecurity#BrokerPublicCertificate\n   */\n  readonly brokerPublicCertificate?: string;\n\n  /**\n   * Describes the transport type. Can be either PLAINTEXT or SSL.\n   *\n   * @schema StreamsKafkaSecurity#Protocol\n   */\n  readonly protocol?: string;\n}\n\n/**\n * Converts an object of type 'StreamsKafkaSecurity' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_StreamsKafkaSecurity(\n  obj: StreamsKafkaSecurity | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    BrokerPublicCertificate: obj.brokerPublicCertificate,\n    Protocol: obj.protocol,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * The name of a Built in or Custom DB Role to connect to an Atlas Cluster.\n *\n * @schema DBRoleToExecute\n */\nexport interface DbRoleToExecute {\n  /**\n   * The name of the role to use. Can be a built in role or a custom role.\n   *\n   * @schema DBRoleToExecute#Role\n   */\n  readonly role?: string;\n\n  /**\n   * Type of the DB role. Can be either BuiltIn or Custom.\n   *\n   * @schema DBRoleToExecute#Type\n   */\n  readonly type?: DbRoleToExecuteType;\n}\n\n/**\n * Converts an object of type 'DbRoleToExecute' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DbRoleToExecute(\n  obj: DbRoleToExecute | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Role: obj.role,\n    Type: obj.type,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Type of the DB role. Can be either BuiltIn or Custom.\n *\n * @schema DbRoleToExecuteType\n */\nexport enum DbRoleToExecuteType {\n  /** BUILT_IN */\n  BUILT_IN = \"BUILT_IN\",\n  /** CUSTOM */\n  CUSTOM = \"CUSTOM\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::StreamInstance`\n *\n * @cloudformationResource MongoDB::Atlas::StreamInstance\n * @stability external\n */\nexport class CfnStreamInstance extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::StreamInstance\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnStreamInstanceProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::StreamInstance.Id`\n   */\n  public readonly attrId: string;\n  /**\n   * Attribute `MongoDB::Atlas::StreamInstance.Hostnames`\n   */\n  public readonly attrHostnames: string[];\n\n  /**\n   * Create a new `MongoDB::Atlas::StreamInstance`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnStreamInstanceProps\n  ) {\n    super(scope, id, {\n      type: CfnStreamInstance.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnStreamInstanceProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n    this.attrHostnames = cdk.Token.asList(this.getAtt(\"Hostnames\"));\n  }\n}\n"]}

@@ -22,3 +22,3 @@ import * as cdk from "aws-cdk-lib";

/**
* Unique 24-hexadecimal character string that identifies the team.
* Unique 24-hexadecimal character string that identifies the organization.
*

@@ -35,3 +35,3 @@ * @schema CfnTeamsProps#OrgId

/**
* Unique 24-hexadecimal character string that identifies the team.
* Human-readable label that identifies the team.
*

@@ -42,3 +42,3 @@ * @schema CfnTeamsProps#Name

/**
* One or more organization- or project-level roles to assign to the MongoDB Cloud user.
* List that contains the MongoDB Cloud users in this team.
*

@@ -45,0 +45,0 @@ * @schema CfnTeamsProps#Usernames

@@ -181,3 +181,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnTeams[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnTeams", version: "3.7.2" };
CfnTeams[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnTeams", version: "3.8.0" };
/**

@@ -187,2 +187,2 @@ * The CloudFormation resource type name for this resource class.

CfnTeams.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::Teams";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/teams/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Adds one team to the specified project. All members of the team share the same project access. To use this resource, the requesting API Key must have the Project User Admin role. This resource doesn't require the API Key to have an Access List.\n *\n * @schema CfnTeamsProps\n */\nexport interface CfnTeamsProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnTeamsProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * One or more organization- or project-level roles to assign to the MongoDB Cloud user.\n   *\n   * @schema CfnTeamsProps#RoleNames\n   */\n  readonly roleNames?: CfnTeamsPropsRoleNames[];\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the team.\n   *\n   * @schema CfnTeamsProps#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the project.\n   *\n   * @schema CfnTeamsProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the team.\n   *\n   * @schema CfnTeamsProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * One or more organization- or project-level roles to assign to the MongoDB Cloud user.\n   *\n   * @schema CfnTeamsProps#Usernames\n   */\n  readonly usernames?: string[];\n\n  /**\n   * List of returned documents that MongoDB Cloud provides when completing this request.\n   *\n   * @schema CfnTeamsProps#Users\n   */\n  readonly users?: AtlasUser[];\n}\n\n/**\n * Converts an object of type 'CfnTeamsProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnTeamsProps(\n  obj: CfnTeamsProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    RoleNames: obj.roleNames?.map((y) => y),\n    OrgId: obj.orgId,\n    ProjectId: obj.projectId,\n    Name: obj.name,\n    Usernames: obj.usernames?.map((y) => y),\n    Users: obj.users?.map((y) => toJson_AtlasUser(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema CfnTeamsPropsRoleNames\n */\nexport enum CfnTeamsPropsRoleNames {\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * @schema AtlasUser\n */\nexport interface AtlasUser {\n  /**\n   * Two alphabet characters that identifies MongoDB Cloud user's geographic location. This parameter uses the ISO 3166-1a2 code format.\n   *\n   * @schema AtlasUser#Country\n   */\n  readonly country?: string;\n\n  /**\n   * Email address that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#EmailAddress\n   */\n  readonly emailAddress?: string;\n\n  /**\n   * First or given name that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#FirstName\n   */\n  readonly firstName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#Id\n   */\n  readonly id?: string;\n\n  /**\n   * Last name, family name, or surname that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#LastName\n   */\n  readonly lastName?: string;\n\n  /**\n   * List of one or more Uniform Resource Locators (URLs) that point to API sub-resources, related API resources, or both. RFC 5988 outlines these relationships.\n   *\n   * @schema AtlasUser#Links\n   */\n  readonly links?: Link[];\n\n  /**\n   * Mobile phone number that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#MobileNumber\n   */\n  readonly mobileNumber?: string;\n\n  /**\n   * Password applied with the username to log in to MongoDB Cloud. MongoDB Cloud does not return this parameter except in response to creating a new MongoDB Cloud user. Only the MongoDB Cloud user can update their password after it has been set from the MongoDB Cloud console.\n   *\n   * @schema AtlasUser#Password\n   */\n  readonly password?: string;\n\n  /**\n   * List of objects that display the MongoDB Cloud user's roles and the corresponding organization or project to which that role applies. A role can apply to one organization or one project but not both.\n   *\n   * @schema AtlasUser#Roles\n   */\n  readonly roles?: AtlasRole[];\n\n  /**\n   * List of unique 24-hexadecimal digit strings that identifies the teams to which this MongoDB Cloud user belongs.\n   *\n   * @schema AtlasUser#TeamIds\n   */\n  readonly teamIds?: string[];\n\n  /**\n   * Email address that represents the username of the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'AtlasUser' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AtlasUser(\n  obj: AtlasUser | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Country: obj.country,\n    EmailAddress: obj.emailAddress,\n    FirstName: obj.firstName,\n    Id: obj.id,\n    LastName: obj.lastName,\n    Links: obj.links?.map((y) => toJson_Link(y)),\n    MobileNumber: obj.mobileNumber,\n    Password: obj.password,\n    Roles: obj.roles?.map((y) => toJson_AtlasRole(y)),\n    TeamIds: obj.teamIds?.map((y) => y),\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * One or more links to sub-resources and/or related resources.\n *\n * @schema Link\n */\nexport interface Link {\n  /**\n   * @schema Link#Rel\n   */\n  readonly rel?: string;\n\n  /**\n   * @schema Link#Href\n   */\n  readonly href?: string;\n}\n\n/**\n * Converts an object of type 'Link' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Link(\n  obj: Link | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Rel: obj.rel,\n    Href: obj.href,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema AtlasRole\n */\nexport interface AtlasRole {\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project to which this role belongs. You can set a value for this parameter or **orgId** but not both in the same request.\n   *\n   * @schema AtlasRole#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization to which this role belongs. You can set a value for this parameter or **groupId** but not both in the same request\n   *\n   * @schema AtlasRole#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Human-readable label that identifies the collection of privileges that MongoDB Cloud grants a specific API key, MongoDB Cloud user, or MongoDB Cloud team. These roles include organization- and project-level roles.\n   *\n   * Organization Roles\n   *\n   * * ORG_OWNER\n   * * ORG_MEMBER\n   * * ORG_GROUP_CREATOR\n   * * ORG_BILLING_ADMIN\n   * * ORG_READ_ONLY\n   *\n   * Project Roles\n   *\n   * * GROUP_CLUSTER_MANAGER\n   * * GROUP_DATA_ACCESS_ADMIN\n   * * GROUP_DATA_ACCESS_READ_ONLY\n   * * GROUP_DATA_ACCESS_READ_WRITE\n   * * GROUP_OWNER\n   * * GROUP_READ_ONLY\n   *\n   *\n   *\n   * @schema AtlasRole#RoleName\n   */\n  readonly roleName?: AtlasRoleRoleName;\n}\n\n/**\n * Converts an object of type 'AtlasRole' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AtlasRole(\n  obj: AtlasRole | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    OrgId: obj.orgId,\n    RoleName: obj.roleName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies the collection of privileges that MongoDB Cloud grants a specific API key, MongoDB Cloud user, or MongoDB Cloud team. These roles include organization- and project-level roles.\n *\n * Organization Roles\n *\n * * ORG_OWNER\n * * ORG_MEMBER\n * * ORG_GROUP_CREATOR\n * * ORG_BILLING_ADMIN\n * * ORG_READ_ONLY\n *\n * Project Roles\n *\n * * GROUP_CLUSTER_MANAGER\n * * GROUP_DATA_ACCESS_ADMIN\n * * GROUP_DATA_ACCESS_READ_ONLY\n * * GROUP_DATA_ACCESS_READ_WRITE\n * * GROUP_OWNER\n * * GROUP_READ_ONLY\n *\n *\n *\n * @schema AtlasRoleRoleName\n */\nexport enum AtlasRoleRoleName {\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::Teams`\n *\n * @cloudformationResource MongoDB::Atlas::Teams\n * @stability external\n */\nexport class CfnTeams extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::Teams\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnTeamsProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::Teams.TeamId`\n   */\n  public readonly attrTeamId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::Teams`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnTeamsProps) {\n    super(scope, id, {\n      type: CfnTeams.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnTeamsProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrTeamId = cdk.Token.asString(this.getAtt(\"TeamId\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/teams/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Adds one team to the specified project. All members of the team share the same project access. To use this resource, the requesting API Key must have the Project User Admin role. This resource doesn't require the API Key to have an Access List.\n *\n * @schema CfnTeamsProps\n */\nexport interface CfnTeamsProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnTeamsProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * One or more organization- or project-level roles to assign to the MongoDB Cloud user.\n   *\n   * @schema CfnTeamsProps#RoleNames\n   */\n  readonly roleNames?: CfnTeamsPropsRoleNames[];\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the organization.\n   *\n   * @schema CfnTeamsProps#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Unique 24-hexadecimal character string that identifies the project.\n   *\n   * @schema CfnTeamsProps#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Human-readable label that identifies the team.\n   *\n   * @schema CfnTeamsProps#Name\n   */\n  readonly name?: string;\n\n  /**\n   * List that contains the MongoDB Cloud users in this team.\n   *\n   * @schema CfnTeamsProps#Usernames\n   */\n  readonly usernames?: string[];\n\n  /**\n   * List of returned documents that MongoDB Cloud provides when completing this request.\n   *\n   * @schema CfnTeamsProps#Users\n   */\n  readonly users?: AtlasUser[];\n}\n\n/**\n * Converts an object of type 'CfnTeamsProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnTeamsProps(\n  obj: CfnTeamsProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    RoleNames: obj.roleNames?.map((y) => y),\n    OrgId: obj.orgId,\n    ProjectId: obj.projectId,\n    Name: obj.name,\n    Usernames: obj.usernames?.map((y) => y),\n    Users: obj.users?.map((y) => toJson_AtlasUser(y)),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema CfnTeamsPropsRoleNames\n */\nexport enum CfnTeamsPropsRoleNames {\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * @schema AtlasUser\n */\nexport interface AtlasUser {\n  /**\n   * Two alphabet characters that identifies MongoDB Cloud user's geographic location. This parameter uses the ISO 3166-1a2 code format.\n   *\n   * @schema AtlasUser#Country\n   */\n  readonly country?: string;\n\n  /**\n   * Email address that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#EmailAddress\n   */\n  readonly emailAddress?: string;\n\n  /**\n   * First or given name that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#FirstName\n   */\n  readonly firstName?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#Id\n   */\n  readonly id?: string;\n\n  /**\n   * Last name, family name, or surname that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#LastName\n   */\n  readonly lastName?: string;\n\n  /**\n   * List of one or more Uniform Resource Locators (URLs) that point to API sub-resources, related API resources, or both. RFC 5988 outlines these relationships.\n   *\n   * @schema AtlasUser#Links\n   */\n  readonly links?: Link[];\n\n  /**\n   * Mobile phone number that belongs to the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#MobileNumber\n   */\n  readonly mobileNumber?: string;\n\n  /**\n   * Password applied with the username to log in to MongoDB Cloud. MongoDB Cloud does not return this parameter except in response to creating a new MongoDB Cloud user. Only the MongoDB Cloud user can update their password after it has been set from the MongoDB Cloud console.\n   *\n   * @schema AtlasUser#Password\n   */\n  readonly password?: string;\n\n  /**\n   * List of objects that display the MongoDB Cloud user's roles and the corresponding organization or project to which that role applies. A role can apply to one organization or one project but not both.\n   *\n   * @schema AtlasUser#Roles\n   */\n  readonly roles?: AtlasRole[];\n\n  /**\n   * List of unique 24-hexadecimal digit strings that identifies the teams to which this MongoDB Cloud user belongs.\n   *\n   * @schema AtlasUser#TeamIds\n   */\n  readonly teamIds?: string[];\n\n  /**\n   * Email address that represents the username of the MongoDB Cloud user.\n   *\n   * @schema AtlasUser#Username\n   */\n  readonly username?: string;\n}\n\n/**\n * Converts an object of type 'AtlasUser' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AtlasUser(\n  obj: AtlasUser | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Country: obj.country,\n    EmailAddress: obj.emailAddress,\n    FirstName: obj.firstName,\n    Id: obj.id,\n    LastName: obj.lastName,\n    Links: obj.links?.map((y) => toJson_Link(y)),\n    MobileNumber: obj.mobileNumber,\n    Password: obj.password,\n    Roles: obj.roles?.map((y) => toJson_AtlasRole(y)),\n    TeamIds: obj.teamIds?.map((y) => y),\n    Username: obj.username,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * One or more links to sub-resources and/or related resources.\n *\n * @schema Link\n */\nexport interface Link {\n  /**\n   * @schema Link#Rel\n   */\n  readonly rel?: string;\n\n  /**\n   * @schema Link#Href\n   */\n  readonly href?: string;\n}\n\n/**\n * Converts an object of type 'Link' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Link(\n  obj: Link | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Rel: obj.rel,\n    Href: obj.href,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema AtlasRole\n */\nexport interface AtlasRole {\n  /**\n   * Unique 24-hexadecimal digit string that identifies the project to which this role belongs. You can set a value for this parameter or **orgId** but not both in the same request.\n   *\n   * @schema AtlasRole#ProjectId\n   */\n  readonly projectId?: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies the organization to which this role belongs. You can set a value for this parameter or **groupId** but not both in the same request\n   *\n   * @schema AtlasRole#OrgId\n   */\n  readonly orgId?: string;\n\n  /**\n   * Human-readable label that identifies the collection of privileges that MongoDB Cloud grants a specific API key, MongoDB Cloud user, or MongoDB Cloud team. These roles include organization- and project-level roles.\n   *\n   * Organization Roles\n   *\n   * * ORG_OWNER\n   * * ORG_MEMBER\n   * * ORG_GROUP_CREATOR\n   * * ORG_BILLING_ADMIN\n   * * ORG_READ_ONLY\n   *\n   * Project Roles\n   *\n   * * GROUP_CLUSTER_MANAGER\n   * * GROUP_DATA_ACCESS_ADMIN\n   * * GROUP_DATA_ACCESS_READ_ONLY\n   * * GROUP_DATA_ACCESS_READ_WRITE\n   * * GROUP_OWNER\n   * * GROUP_READ_ONLY\n   *\n   *\n   *\n   * @schema AtlasRole#RoleName\n   */\n  readonly roleName?: AtlasRoleRoleName;\n}\n\n/**\n * Converts an object of type 'AtlasRole' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AtlasRole(\n  obj: AtlasRole | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    OrgId: obj.orgId,\n    RoleName: obj.roleName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * Human-readable label that identifies the collection of privileges that MongoDB Cloud grants a specific API key, MongoDB Cloud user, or MongoDB Cloud team. These roles include organization- and project-level roles.\n *\n * Organization Roles\n *\n * * ORG_OWNER\n * * ORG_MEMBER\n * * ORG_GROUP_CREATOR\n * * ORG_BILLING_ADMIN\n * * ORG_READ_ONLY\n *\n * Project Roles\n *\n * * GROUP_CLUSTER_MANAGER\n * * GROUP_DATA_ACCESS_ADMIN\n * * GROUP_DATA_ACCESS_READ_ONLY\n * * GROUP_DATA_ACCESS_READ_WRITE\n * * GROUP_OWNER\n * * GROUP_READ_ONLY\n *\n *\n *\n * @schema AtlasRoleRoleName\n */\nexport enum AtlasRoleRoleName {\n  /** ORG_OWNER */\n  ORG_OWNER = \"ORG_OWNER\",\n  /** ORG_MEMBER */\n  ORG_MEMBER = \"ORG_MEMBER\",\n  /** ORG_GROUP_CREATOR */\n  ORG_GROUP_CREATOR = \"ORG_GROUP_CREATOR\",\n  /** ORG_BILLING_ADMIN */\n  ORG_BILLING_ADMIN = \"ORG_BILLING_ADMIN\",\n  /** ORG_READ_ONLY */\n  ORG_READ_ONLY = \"ORG_READ_ONLY\",\n  /** GROUP_CLUSTER_MANAGER */\n  GROUP_CLUSTER_MANAGER = \"GROUP_CLUSTER_MANAGER\",\n  /** GROUP_DATA_ACCESS_ADMIN */\n  GROUP_DATA_ACCESS_ADMIN = \"GROUP_DATA_ACCESS_ADMIN\",\n  /** GROUP_DATA_ACCESS_READ_ONLY */\n  GROUP_DATA_ACCESS_READ_ONLY = \"GROUP_DATA_ACCESS_READ_ONLY\",\n  /** GROUP_DATA_ACCESS_READ_WRITE */\n  GROUP_DATA_ACCESS_READ_WRITE = \"GROUP_DATA_ACCESS_READ_WRITE\",\n  /** GROUP_OWNER */\n  GROUP_OWNER = \"GROUP_OWNER\",\n  /** GROUP_READ_ONLY */\n  GROUP_READ_ONLY = \"GROUP_READ_ONLY\",\n}\n\n/**\n * A CloudFormation `MongoDB::Atlas::Teams`\n *\n * @cloudformationResource MongoDB::Atlas::Teams\n * @stability external\n */\nexport class CfnTeams extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::Teams\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnTeamsProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::Teams.TeamId`\n   */\n  public readonly attrTeamId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::Teams`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnTeamsProps) {\n    super(scope, id, {\n      type: CfnTeams.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnTeamsProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrTeamId = cdk.Token.asString(this.getAtt(\"TeamId\"));\n  }\n}\n"]}

@@ -115,3 +115,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnThirdPartyIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnThirdPartyIntegration", version: "3.7.2" };
CfnThirdPartyIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnThirdPartyIntegration", version: "3.8.0" };
/**

@@ -118,0 +118,0 @@ * The CloudFormation resource type name for this resource class.

import * as cdk from "aws-cdk-lib";
import * as constructs from "constructs";
/**
* View and manage your application's [triggers](https://www.mongodb.com/docs/atlas/app-services/triggers/overview/).
* View and manage your application's triggers: https://www.mongodb.com/docs/atlas/app-services/triggers/
*

@@ -6,0 +6,0 @@ * @schema CfnTriggerProps

@@ -247,3 +247,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
CfnTrigger[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnTrigger", version: "3.7.2" };
CfnTrigger[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnTrigger", version: "3.8.0" };
/**

@@ -253,2 +253,2 @@ * The CloudFormation resource type name for this resource class.

CfnTrigger.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::Trigger";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/trigger/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * View and manage your application's [triggers](https://www.mongodb.com/docs/atlas/app-services/triggers/overview/).\n *\n * @schema CfnTriggerProps\n */\nexport interface CfnTriggerProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnTriggerProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * @schema CfnTriggerProps#DatabaseTrigger\n   */\n  readonly databaseTrigger?: DatabaseConfig;\n\n  /**\n   * @schema CfnTriggerProps#AuthTrigger\n   */\n  readonly authTrigger?: AuthConfig;\n\n  /**\n   * @schema CfnTriggerProps#ScheduleTrigger\n   */\n  readonly scheduleTrigger?: ScheduleConfig;\n\n  /**\n   * The trigger's name.\n   *\n   * @schema CfnTriggerProps#Name\n   */\n  readonly name: string;\n\n  /**\n   * The trigger's type.\n   *\n   * @schema CfnTriggerProps#Type\n   */\n  readonly type: string;\n\n  /**\n   * If `true`, the trigger is disabled and does not listen for events or execute.\n   *\n   * @schema CfnTriggerProps#Disabled\n   */\n  readonly disabled?: boolean;\n\n  /**\n   * The ID of the function that the trigger calls when it fires.\n   *\n   * This value is the same as `event_processors.FUNCTION.function_id`.\n   * You can either define the value here or in `event_processors.FUNCTION.function_id`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `function_id`, the backend duplicates it to `event_processors.FUNCTION.function_id`.\n   *\n   * @schema CfnTriggerProps#FunctionId\n   */\n  readonly functionId?: string;\n\n  /**\n   * The name of the function that the trigger calls when it\n   * fires, i.e. the function described by `function_id`.\n   *\n   * This value is the same as `event_processors.FUNCTION.function_name`.\n   * You can either define the value here or in `event_processors.FUNCTION.function_name`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `function_name`, the backend duplicates it to `event_processors.FUNCTION.function_name`.\n   *\n   * @schema CfnTriggerProps#FunctionName\n   */\n  readonly functionName?: string;\n\n  /**\n   * An object where each field name is an event processor ID and\n   * each value is an object that configures its corresponding\n   * event processor. For an example configuration object, see\n   * [Send Trigger Events to AWS\n   * EventBridge](https://www.mongodb.com/docs/realm/triggers/examples/send-events-aws-eventbridge#std-label-event_processor_example).\n   *\n   * @schema CfnTriggerProps#EventProcessors\n   */\n  readonly eventProcessors?: Event;\n\n  /**\n   * App Services Application ID\n   *\n   * @schema CfnTriggerProps#AppId\n   */\n  readonly appId: string;\n\n  /**\n   * Project Id for application services\n   *\n   * @schema CfnTriggerProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnTriggerProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnTriggerProps(\n  obj: CfnTriggerProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    DatabaseTrigger: toJson_DatabaseConfig(obj.databaseTrigger),\n    AuthTrigger: toJson_AuthConfig(obj.authTrigger),\n    ScheduleTrigger: toJson_ScheduleConfig(obj.scheduleTrigger),\n    Name: obj.name,\n    Type: obj.type,\n    Disabled: obj.disabled,\n    FunctionId: obj.functionId,\n    FunctionName: obj.functionName,\n    EventProcessors: toJson_Event(obj.eventProcessors),\n    AppId: obj.appId,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DatabaseConfig\n */\nexport interface DatabaseConfig {\n  /**\n   * The _id value of a linked MongoDB data source.\n   *\n   * See [Get a Data Source](#operation/adminGetService).\n   *\n   *\n   * @schema DatabaseConfig#ServiceId\n   */\n  readonly serviceId?: string;\n\n  /**\n   * The name of a database in the linked data source.\n   *\n   * @schema DatabaseConfig#Database\n   */\n  readonly database?: string;\n\n  /**\n   * The name of a collection in the specified database. The\n   * trigger listens to events from this collection.\n   *\n   * @schema DatabaseConfig#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * The type(s) of MongoDB change event that the trigger listens for.\n   *\n   * @schema DatabaseConfig#OperationTypes\n   */\n  readonly operationTypes?: DatabaseConfigOperationTypes[];\n\n  /**\n   * stringify version of a [$match](https://www.mongodb.com/docs/manual/reference/operator/aggregation/match) expression filters change events. The trigger will only fire if the expression evaluates to true for a given change event.\n   *\n   * @schema DatabaseConfig#Match\n   */\n  readonly match?: string;\n\n  /**\n   * stringify version of a [$project](https://www.mongodb.com/docs/manual/reference/operator/aggregation/project/) expressions to limit the data included in each event.\n   *\n   * @schema DatabaseConfig#Project\n   */\n  readonly project?: string;\n\n  /**\n   * If `true`, indicates that `UPDATE` change events should\n   * include the most current\n   * [majority-committed](https://www.mongodb.com/docs/manual/reference/read-concern-majority/)\n   * version of the modified document in the `fullDocument`\n   * field.\n   *\n   * @schema DatabaseConfig#FullDocument\n   */\n  readonly fullDocument?: boolean;\n\n  /**\n   * If true, indicates that `UPDATE` change events should\n   * include a snapshot of the modified document from\n   * immediately before the update was applied.\n   *\n   * You must enable [document\n   * preimages](https://www.mongodb.com/docs/atlas/app-services/mongodb/preimages/)\n   * for your cluster to include these snapshots.\n   *\n   * @schema DatabaseConfig#FullDocumentBeforeChange\n   */\n  readonly fullDocumentBeforeChange?: boolean;\n\n  /**\n   * If `true`, enabling the Trigger after it was disabled\n   * will not invoke events that occurred while the Trigger\n   * was disabled.\n   *\n   * @schema DatabaseConfig#SkipCatchupEvents\n   */\n  readonly skipCatchupEvents?: boolean;\n\n  /**\n   * If `true`, when this Trigger's resume token\n   * cannot be found in the cluster's oplog, the Trigger automatically resumes\n   * processing events at the next relevant change stream event.\n   * All change stream events from when the Trigger was suspended until the Trigger\n   * resumes execution do not have the Trigger fire for them.\n   *\n   * @schema DatabaseConfig#TolerateResumeErrors\n   */\n  readonly tolerateResumeErrors?: boolean;\n\n  /**\n   * If `true`, event ordering is disabled and this Trigger\n   * can process events in parallel. If `false`, event\n   * ordering is enabled and the Trigger executes events\n   * serially.\n   *\n   * @schema DatabaseConfig#Unordered\n   */\n  readonly unordered?: boolean;\n}\n\n/**\n * Converts an object of type 'DatabaseConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DatabaseConfig(\n  obj: DatabaseConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ServiceId: obj.serviceId,\n    Database: obj.database,\n    Collection: obj.collection,\n    OperationTypes: obj.operationTypes?.map((y) => y),\n    Match: obj.match,\n    Project: obj.project,\n    FullDocument: obj.fullDocument,\n    FullDocumentBeforeChange: obj.fullDocumentBeforeChange,\n    SkipCatchupEvents: obj.skipCatchupEvents,\n    TolerateResumeErrors: obj.tolerateResumeErrors,\n    Unordered: obj.unordered,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema AuthConfig\n */\nexport interface AuthConfig {\n  /**\n   * The type of authentication event that the trigger listens for.\n   *\n   * @schema AuthConfig#OperationType\n   */\n  readonly operationType: AuthConfigOperationType;\n\n  /**\n   * The type(s) of authentication provider that the trigger listens to.\n   *\n   * @schema AuthConfig#Providers\n   */\n  readonly providers: AuthConfigProviders[];\n}\n\n/**\n * Converts an object of type 'AuthConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AuthConfig(\n  obj: AuthConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    OperationType: obj.operationType,\n    Providers: obj.providers?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScheduleConfig\n */\nexport interface ScheduleConfig {\n  /**\n   * A [cron expression](https://www.mongodb.com/docs/atlas/app-services/triggers/scheduled-triggers/#cron-expressions) that specifies when the trigger executes.\n   *\n   * @schema ScheduleConfig#Schedule\n   */\n  readonly schedule?: string;\n\n  /**\n   * If `true`, enabling the trigger after it was disabled\n   * will not invoke events that occurred while the trigger\n   * was disabled.\n   *\n   * @schema ScheduleConfig#SkipcatchupEvents\n   */\n  readonly skipcatchupEvents?: boolean;\n}\n\n/**\n * Converts an object of type 'ScheduleConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScheduleConfig(\n  obj: ScheduleConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Schedule: obj.schedule,\n    SkipcatchupEvents: obj.skipcatchupEvents,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Event\n */\nexport interface Event {\n  /**\n   * @schema Event#FUNCTION\n   */\n  readonly function?: EventFunction;\n\n  /**\n   * @schema Event#AWSEVENTBRIDGE\n   */\n  readonly awseventbridge?: EventAwseventbridge;\n}\n\n/**\n * Converts an object of type 'Event' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Event(\n  obj: Event | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FUNCTION: toJson_EventFunction(obj.function),\n    AWSEVENTBRIDGE: toJson_EventAwseventbridge(obj.awseventbridge),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DatabaseConfigOperationTypes\n */\nexport enum DatabaseConfigOperationTypes {\n  /** INSERT */\n  INSERT = \"INSERT\",\n  /** UPDATE */\n  UPDATE = \"UPDATE\",\n  /** REPLACE */\n  REPLACE = \"REPLACE\",\n  /** DELETE */\n  DELETE = \"DELETE\",\n}\n\n/**\n * The type of authentication event that the trigger listens for.\n *\n * @schema AuthConfigOperationType\n */\nexport enum AuthConfigOperationType {\n  /** LOGIN */\n  LOGIN = \"LOGIN\",\n  /** CREATE */\n  CREATE = \"CREATE\",\n  /** DELETE */\n  DELETE = \"DELETE\",\n}\n\n/**\n * @schema AuthConfigProviders\n */\nexport enum AuthConfigProviders {\n  /** anon-user */\n  ANON_USER = \"anon-user\",\n  /** api-key */\n  API_KEY = \"api-key\",\n  /** custom-token */\n  CUSTOM_TOKEN = \"custom-token\",\n  /** custom-function */\n  CUSTOM_FUNCTION = \"custom-function\",\n  /** local-userpass */\n  LOCAL_USERPASS = \"local-userpass\",\n  /** oauth2-apple */\n  OAUTH2_APPLE = \"oauth2-apple\",\n  /** oauth2-facebook */\n  OAUTH2_FACEBOOK = \"oauth2-facebook\",\n  /** oauth2-google */\n  OAUTH2_GOOGLE = \"oauth2-google\",\n}\n\n/**\n * @schema EventFunction\n */\nexport interface EventFunction {\n  /**\n   * @schema EventFunction#FuncConfig\n   */\n  readonly funcConfig?: EventFunctionFuncConfig;\n}\n\n/**\n * Converts an object of type 'EventFunction' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventFunction(\n  obj: EventFunction | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FuncConfig: toJson_EventFunctionFuncConfig(obj.funcConfig),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventAwseventbridge\n */\nexport interface EventAwseventbridge {\n  /**\n   * @schema EventAwseventbridge#AWSConfig\n   */\n  readonly awsConfig?: EventAwseventbridgeAwsConfig;\n}\n\n/**\n * Converts an object of type 'EventAwseventbridge' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventAwseventbridge(\n  obj: EventAwseventbridge | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AWSConfig: toJson_EventAwseventbridgeAwsConfig(obj.awsConfig),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventFunctionFuncConfig\n */\nexport interface EventFunctionFuncConfig {\n  /**\n   * The ID of the function that the trigger calls when it fires.\n   *\n   * This value is the same as the root-level `function_id`.\n   * You can either define the value here or in `function_id`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `event_processors.FUNCTION.function_id`, the backend duplicates it to `function_id`.\n   *\n   * @schema EventFunctionFuncConfig#FunctionId\n   */\n  readonly functionId?: string;\n\n  /**\n   * The name of the function that the trigger calls when it\n   * fires, i.e. the function described by `function_id`.\n   *\n   * This value is the same as the root-level `function_name`.\n   * You can either define the value here or in `function_name`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `event_processors.FUNCTION.function_name`, the backend duplicates it to `function_name`.\n   *\n   * @schema EventFunctionFuncConfig#FunctionName\n   */\n  readonly functionName?: string;\n}\n\n/**\n * Converts an object of type 'EventFunctionFuncConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventFunctionFuncConfig(\n  obj: EventFunctionFuncConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FunctionId: obj.functionId,\n    FunctionName: obj.functionName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventAwseventbridgeAwsConfig\n */\nexport interface EventAwseventbridgeAwsConfig {\n  /**\n   * An AWS Account ID.\n   *\n   * @schema EventAwseventbridgeAwsConfig#AccountId\n   */\n  readonly accountId?: string;\n\n  /**\n   * An AWS region.\n   *\n   * @schema EventAwseventbridgeAwsConfig#Region\n   */\n  readonly region?: string;\n\n  /**\n   * If `true`, event objects are serialized using EJSON.\n   *\n   * @schema EventAwseventbridgeAwsConfig#ExtendedJsonEnabled\n   */\n  readonly extendedJsonEnabled?: boolean;\n}\n\n/**\n * Converts an object of type 'EventAwseventbridgeAwsConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventAwseventbridgeAwsConfig(\n  obj: EventAwseventbridgeAwsConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AccountId: obj.accountId,\n    Region: obj.region,\n    ExtendedJsonEnabled: obj.extendedJsonEnabled,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::Trigger`\n *\n * @cloudformationResource MongoDB::Atlas::Trigger\n * @stability external\n */\nexport class CfnTrigger extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::Trigger\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnTriggerProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::Trigger.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::Trigger`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnTriggerProps) {\n    super(scope, id, {\n      type: CfnTrigger.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnTriggerProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/trigger/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * View and manage your application's triggers: https://www.mongodb.com/docs/atlas/app-services/triggers/\n *\n * @schema CfnTriggerProps\n */\nexport interface CfnTriggerProps {\n  /**\n   * The profile is defined in AWS Secret manager. See [Secret Manager Profile setup](../../../examples/profile-secret.yaml).\n   *\n   * @schema CfnTriggerProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * @schema CfnTriggerProps#DatabaseTrigger\n   */\n  readonly databaseTrigger?: DatabaseConfig;\n\n  /**\n   * @schema CfnTriggerProps#AuthTrigger\n   */\n  readonly authTrigger?: AuthConfig;\n\n  /**\n   * @schema CfnTriggerProps#ScheduleTrigger\n   */\n  readonly scheduleTrigger?: ScheduleConfig;\n\n  /**\n   * The trigger's name.\n   *\n   * @schema CfnTriggerProps#Name\n   */\n  readonly name: string;\n\n  /**\n   * The trigger's type.\n   *\n   * @schema CfnTriggerProps#Type\n   */\n  readonly type: string;\n\n  /**\n   * If `true`, the trigger is disabled and does not listen for events or execute.\n   *\n   * @schema CfnTriggerProps#Disabled\n   */\n  readonly disabled?: boolean;\n\n  /**\n   * The ID of the function that the trigger calls when it fires.\n   *\n   * This value is the same as `event_processors.FUNCTION.function_id`.\n   * You can either define the value here or in `event_processors.FUNCTION.function_id`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `function_id`, the backend duplicates it to `event_processors.FUNCTION.function_id`.\n   *\n   * @schema CfnTriggerProps#FunctionId\n   */\n  readonly functionId?: string;\n\n  /**\n   * The name of the function that the trigger calls when it\n   * fires, i.e. the function described by `function_id`.\n   *\n   * This value is the same as `event_processors.FUNCTION.function_name`.\n   * You can either define the value here or in `event_processors.FUNCTION.function_name`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `function_name`, the backend duplicates it to `event_processors.FUNCTION.function_name`.\n   *\n   * @schema CfnTriggerProps#FunctionName\n   */\n  readonly functionName?: string;\n\n  /**\n   * An object where each field name is an event processor ID and\n   * each value is an object that configures its corresponding\n   * event processor. For an example configuration object, see\n   * [Send Trigger Events to AWS\n   * EventBridge](https://www.mongodb.com/docs/realm/triggers/examples/send-events-aws-eventbridge#std-label-event_processor_example).\n   *\n   * @schema CfnTriggerProps#EventProcessors\n   */\n  readonly eventProcessors?: Event;\n\n  /**\n   * App Services Application ID\n   *\n   * @schema CfnTriggerProps#AppId\n   */\n  readonly appId: string;\n\n  /**\n   * Project Id for application services\n   *\n   * @schema CfnTriggerProps#ProjectId\n   */\n  readonly projectId: string;\n}\n\n/**\n * Converts an object of type 'CfnTriggerProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnTriggerProps(\n  obj: CfnTriggerProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    DatabaseTrigger: toJson_DatabaseConfig(obj.databaseTrigger),\n    AuthTrigger: toJson_AuthConfig(obj.authTrigger),\n    ScheduleTrigger: toJson_ScheduleConfig(obj.scheduleTrigger),\n    Name: obj.name,\n    Type: obj.type,\n    Disabled: obj.disabled,\n    FunctionId: obj.functionId,\n    FunctionName: obj.functionName,\n    EventProcessors: toJson_Event(obj.eventProcessors),\n    AppId: obj.appId,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DatabaseConfig\n */\nexport interface DatabaseConfig {\n  /**\n   * The _id value of a linked MongoDB data source.\n   *\n   * See [Get a Data Source](#operation/adminGetService).\n   *\n   *\n   * @schema DatabaseConfig#ServiceId\n   */\n  readonly serviceId?: string;\n\n  /**\n   * The name of a database in the linked data source.\n   *\n   * @schema DatabaseConfig#Database\n   */\n  readonly database?: string;\n\n  /**\n   * The name of a collection in the specified database. The\n   * trigger listens to events from this collection.\n   *\n   * @schema DatabaseConfig#Collection\n   */\n  readonly collection?: string;\n\n  /**\n   * The type(s) of MongoDB change event that the trigger listens for.\n   *\n   * @schema DatabaseConfig#OperationTypes\n   */\n  readonly operationTypes?: DatabaseConfigOperationTypes[];\n\n  /**\n   * stringify version of a [$match](https://www.mongodb.com/docs/manual/reference/operator/aggregation/match) expression filters change events. The trigger will only fire if the expression evaluates to true for a given change event.\n   *\n   * @schema DatabaseConfig#Match\n   */\n  readonly match?: string;\n\n  /**\n   * stringify version of a [$project](https://www.mongodb.com/docs/manual/reference/operator/aggregation/project/) expressions to limit the data included in each event.\n   *\n   * @schema DatabaseConfig#Project\n   */\n  readonly project?: string;\n\n  /**\n   * If `true`, indicates that `UPDATE` change events should\n   * include the most current\n   * [majority-committed](https://www.mongodb.com/docs/manual/reference/read-concern-majority/)\n   * version of the modified document in the `fullDocument`\n   * field.\n   *\n   * @schema DatabaseConfig#FullDocument\n   */\n  readonly fullDocument?: boolean;\n\n  /**\n   * If true, indicates that `UPDATE` change events should\n   * include a snapshot of the modified document from\n   * immediately before the update was applied.\n   *\n   * You must enable [document\n   * preimages](https://www.mongodb.com/docs/atlas/app-services/mongodb/preimages/)\n   * for your cluster to include these snapshots.\n   *\n   * @schema DatabaseConfig#FullDocumentBeforeChange\n   */\n  readonly fullDocumentBeforeChange?: boolean;\n\n  /**\n   * If `true`, enabling the Trigger after it was disabled\n   * will not invoke events that occurred while the Trigger\n   * was disabled.\n   *\n   * @schema DatabaseConfig#SkipCatchupEvents\n   */\n  readonly skipCatchupEvents?: boolean;\n\n  /**\n   * If `true`, when this Trigger's resume token\n   * cannot be found in the cluster's oplog, the Trigger automatically resumes\n   * processing events at the next relevant change stream event.\n   * All change stream events from when the Trigger was suspended until the Trigger\n   * resumes execution do not have the Trigger fire for them.\n   *\n   * @schema DatabaseConfig#TolerateResumeErrors\n   */\n  readonly tolerateResumeErrors?: boolean;\n\n  /**\n   * If `true`, event ordering is disabled and this Trigger\n   * can process events in parallel. If `false`, event\n   * ordering is enabled and the Trigger executes events\n   * serially.\n   *\n   * @schema DatabaseConfig#Unordered\n   */\n  readonly unordered?: boolean;\n}\n\n/**\n * Converts an object of type 'DatabaseConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_DatabaseConfig(\n  obj: DatabaseConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ServiceId: obj.serviceId,\n    Database: obj.database,\n    Collection: obj.collection,\n    OperationTypes: obj.operationTypes?.map((y) => y),\n    Match: obj.match,\n    Project: obj.project,\n    FullDocument: obj.fullDocument,\n    FullDocumentBeforeChange: obj.fullDocumentBeforeChange,\n    SkipCatchupEvents: obj.skipCatchupEvents,\n    TolerateResumeErrors: obj.tolerateResumeErrors,\n    Unordered: obj.unordered,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema AuthConfig\n */\nexport interface AuthConfig {\n  /**\n   * The type of authentication event that the trigger listens for.\n   *\n   * @schema AuthConfig#OperationType\n   */\n  readonly operationType: AuthConfigOperationType;\n\n  /**\n   * The type(s) of authentication provider that the trigger listens to.\n   *\n   * @schema AuthConfig#Providers\n   */\n  readonly providers: AuthConfigProviders[];\n}\n\n/**\n * Converts an object of type 'AuthConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_AuthConfig(\n  obj: AuthConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    OperationType: obj.operationType,\n    Providers: obj.providers?.map((y) => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema ScheduleConfig\n */\nexport interface ScheduleConfig {\n  /**\n   * A [cron expression](https://www.mongodb.com/docs/atlas/app-services/triggers/scheduled-triggers/#cron-expressions) that specifies when the trigger executes.\n   *\n   * @schema ScheduleConfig#Schedule\n   */\n  readonly schedule?: string;\n\n  /**\n   * If `true`, enabling the trigger after it was disabled\n   * will not invoke events that occurred while the trigger\n   * was disabled.\n   *\n   * @schema ScheduleConfig#SkipcatchupEvents\n   */\n  readonly skipcatchupEvents?: boolean;\n}\n\n/**\n * Converts an object of type 'ScheduleConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ScheduleConfig(\n  obj: ScheduleConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Schedule: obj.schedule,\n    SkipcatchupEvents: obj.skipcatchupEvents,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema Event\n */\nexport interface Event {\n  /**\n   * @schema Event#FUNCTION\n   */\n  readonly function?: EventFunction;\n\n  /**\n   * @schema Event#AWSEVENTBRIDGE\n   */\n  readonly awseventbridge?: EventAwseventbridge;\n}\n\n/**\n * Converts an object of type 'Event' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_Event(\n  obj: Event | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FUNCTION: toJson_EventFunction(obj.function),\n    AWSEVENTBRIDGE: toJson_EventAwseventbridge(obj.awseventbridge),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema DatabaseConfigOperationTypes\n */\nexport enum DatabaseConfigOperationTypes {\n  /** INSERT */\n  INSERT = \"INSERT\",\n  /** UPDATE */\n  UPDATE = \"UPDATE\",\n  /** REPLACE */\n  REPLACE = \"REPLACE\",\n  /** DELETE */\n  DELETE = \"DELETE\",\n}\n\n/**\n * The type of authentication event that the trigger listens for.\n *\n * @schema AuthConfigOperationType\n */\nexport enum AuthConfigOperationType {\n  /** LOGIN */\n  LOGIN = \"LOGIN\",\n  /** CREATE */\n  CREATE = \"CREATE\",\n  /** DELETE */\n  DELETE = \"DELETE\",\n}\n\n/**\n * @schema AuthConfigProviders\n */\nexport enum AuthConfigProviders {\n  /** anon-user */\n  ANON_USER = \"anon-user\",\n  /** api-key */\n  API_KEY = \"api-key\",\n  /** custom-token */\n  CUSTOM_TOKEN = \"custom-token\",\n  /** custom-function */\n  CUSTOM_FUNCTION = \"custom-function\",\n  /** local-userpass */\n  LOCAL_USERPASS = \"local-userpass\",\n  /** oauth2-apple */\n  OAUTH2_APPLE = \"oauth2-apple\",\n  /** oauth2-facebook */\n  OAUTH2_FACEBOOK = \"oauth2-facebook\",\n  /** oauth2-google */\n  OAUTH2_GOOGLE = \"oauth2-google\",\n}\n\n/**\n * @schema EventFunction\n */\nexport interface EventFunction {\n  /**\n   * @schema EventFunction#FuncConfig\n   */\n  readonly funcConfig?: EventFunctionFuncConfig;\n}\n\n/**\n * Converts an object of type 'EventFunction' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventFunction(\n  obj: EventFunction | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FuncConfig: toJson_EventFunctionFuncConfig(obj.funcConfig),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventAwseventbridge\n */\nexport interface EventAwseventbridge {\n  /**\n   * @schema EventAwseventbridge#AWSConfig\n   */\n  readonly awsConfig?: EventAwseventbridgeAwsConfig;\n}\n\n/**\n * Converts an object of type 'EventAwseventbridge' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventAwseventbridge(\n  obj: EventAwseventbridge | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AWSConfig: toJson_EventAwseventbridgeAwsConfig(obj.awsConfig),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventFunctionFuncConfig\n */\nexport interface EventFunctionFuncConfig {\n  /**\n   * The ID of the function that the trigger calls when it fires.\n   *\n   * This value is the same as the root-level `function_id`.\n   * You can either define the value here or in `function_id`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `event_processors.FUNCTION.function_id`, the backend duplicates it to `function_id`.\n   *\n   * @schema EventFunctionFuncConfig#FunctionId\n   */\n  readonly functionId?: string;\n\n  /**\n   * The name of the function that the trigger calls when it\n   * fires, i.e. the function described by `function_id`.\n   *\n   * This value is the same as the root-level `function_name`.\n   * You can either define the value here or in `function_name`.\n   * The App Services backend duplicates the value to the configuration location where you did not define it.\n   *\n   * For example, if you define `event_processors.FUNCTION.function_name`, the backend duplicates it to `function_name`.\n   *\n   * @schema EventFunctionFuncConfig#FunctionName\n   */\n  readonly functionName?: string;\n}\n\n/**\n * Converts an object of type 'EventFunctionFuncConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventFunctionFuncConfig(\n  obj: EventFunctionFuncConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    FunctionId: obj.functionId,\n    FunctionName: obj.functionName,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema EventAwseventbridgeAwsConfig\n */\nexport interface EventAwseventbridgeAwsConfig {\n  /**\n   * An AWS Account ID.\n   *\n   * @schema EventAwseventbridgeAwsConfig#AccountId\n   */\n  readonly accountId?: string;\n\n  /**\n   * An AWS region.\n   *\n   * @schema EventAwseventbridgeAwsConfig#Region\n   */\n  readonly region?: string;\n\n  /**\n   * If `true`, event objects are serialized using EJSON.\n   *\n   * @schema EventAwseventbridgeAwsConfig#ExtendedJsonEnabled\n   */\n  readonly extendedJsonEnabled?: boolean;\n}\n\n/**\n * Converts an object of type 'EventAwseventbridgeAwsConfig' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_EventAwseventbridgeAwsConfig(\n  obj: EventAwseventbridgeAwsConfig | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    AccountId: obj.accountId,\n    Region: obj.region,\n    ExtendedJsonEnabled: obj.extendedJsonEnabled,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::Trigger`\n *\n * @cloudformationResource MongoDB::Atlas::Trigger\n * @stability external\n */\nexport class CfnTrigger extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME = \"MongoDB::Atlas::Trigger\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnTriggerProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::Trigger.Id`\n   */\n  public readonly attrId: string;\n\n  /**\n   * Create a new `MongoDB::Atlas::Trigger`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(scope: constructs.Construct, id: string, props: CfnTriggerProps) {\n    super(scope, id, {\n      type: CfnTrigger.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnTriggerProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrId = cdk.Token.asString(this.getAtt(\"Id\"));\n  }\n}\n"]}

@@ -20,8 +20,2 @@ import * as cdk from "aws-cdk-lib";

/**
* Total number of unexpired certificates returned in this response.
*
* @schema CfnX509AuthenticationDatabaseUserProps#TotalCount
*/
readonly totalCount?: number;
/**
* CustomerX509 represents Customer-managed X.509 configuration for an Atlas project.

@@ -39,8 +33,2 @@ *

/**
* A number of months that the created certificate is valid for before expiry, up to 24 months.default 3.
*
* @schema CfnX509AuthenticationDatabaseUserProps#MonthsUntilExpiration
*/
readonly monthsUntilExpiration?: number;
/**
* The unique identifier for the project .

@@ -87,2 +75,10 @@ *

/**
* Attribute `MongoDB::Atlas::X509AuthenticationDatabaseUser.TotalCount`
*/
readonly attrTotalCount: number;
/**
* Attribute `MongoDB::Atlas::X509AuthenticationDatabaseUser.MonthsUntilExpiration`
*/
readonly attrMonthsUntilExpiration: number;
/**
* Create a new `MongoDB::Atlas::X509AuthenticationDatabaseUser`.

@@ -89,0 +85,0 @@ *

@@ -18,6 +18,4 @@ "use strict";

Profile: obj.profile,
TotalCount: obj.totalCount,
CustomerX509: toJson_CustomerX509(obj.customerX509),
UserName: obj.userName,
MonthsUntilExpiration: obj.monthsUntilExpiration,
ProjectId: obj.projectId,

@@ -65,2 +63,4 @@ };

this.props = props;
this.attrTotalCount = cdk.Token.asNumber(this.getAtt("TotalCount"));
this.attrMonthsUntilExpiration = cdk.Token.asNumber(this.getAtt("MonthsUntilExpiration"));
}

@@ -70,3 +70,3 @@ }

_a = JSII_RTTI_SYMBOL_1;
CfnX509AuthenticationDatabaseUser[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnX509AuthenticationDatabaseUser", version: "3.7.2" };
CfnX509AuthenticationDatabaseUser[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnX509AuthenticationDatabaseUser", version: "3.8.0" };
/**

@@ -76,2 +76,2 @@ * The CloudFormation resource type name for this resource class.

CfnX509AuthenticationDatabaseUser.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::X509AuthenticationDatabaseUser";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/x509-authentication-database-user/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AAwDnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,6CAA6C,CAC3D,GAAuD;IAEvD,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,YAAY,EAAE,mBAAmB,CAAC,GAAG,CAAC,YAAY,CAAC;QACnD,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,qBAAqB,EAAE,GAAG,CAAC,qBAAqB;QAChD,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAnBD,sGAmBC;AAeD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,mBAAmB,CACjC,GAA6B;IAE7B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,GAAG,EAAE,GAAG,CAAC,GAAG;KACb,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAdD,kDAcC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,iCAAkC,SAAQ,GAAG,CAAC,WAAW;IAYpE;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA6C;QAE7C,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,iCAAiC,CAAC,sBAAsB;YAC9D,UAAU,EAAE,6CAA6C,CAAC,KAAK,CAAE;SAClE,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;AA9BH,8EA+BC;;;AA9BC;;GAEG;AACoB,wDAAsB,GAC3C,gDAAgD,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Generates one X.509 certificate for the specified MongoDB user. Atlas manages the certificate and MongoDB user that belong to one project. To use this resource, the requesting API Key must have the Project Atlas Admin role. This resource doesn't require the API Key to have an Access List.\n *\n * To get MongoDB Cloud to generate a managed certificate for a database user, set `\"x509Type\" : \"MANAGED\"` on the desired MongoDB Database User.\n *\n * If you are managing your own Certificate Authority (CA) in Self-Managed X.509 mode, you must generate certificates for database users using your own CA.\n *\n * @schema CfnX509AuthenticationDatabaseUserProps\n */\nexport interface CfnX509AuthenticationDatabaseUserProps {\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Total number of unexpired certificates returned in this response.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#TotalCount\n   */\n  readonly totalCount?: number;\n\n  /**\n   * CustomerX509 represents Customer-managed X.509 configuration for an Atlas project.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#CustomerX509\n   */\n  readonly customerX509?: CustomerX509;\n\n  /**\n   * Username of the database user to create a certificate for.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#UserName\n   */\n  readonly userName?: string;\n\n  /**\n   * A number of months that the created certificate is valid for before expiry, up to 24 months.default 3.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#MonthsUntilExpiration\n   */\n  readonly monthsUntilExpiration?: number;\n\n  /**\n   * The unique identifier for the project .\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'CfnX509AuthenticationDatabaseUserProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnX509AuthenticationDatabaseUserProps(\n  obj: CfnX509AuthenticationDatabaseUserProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    TotalCount: obj.totalCount,\n    CustomerX509: toJson_CustomerX509(obj.customerX509),\n    UserName: obj.userName,\n    MonthsUntilExpiration: obj.monthsUntilExpiration,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema customerX509\n */\nexport interface CustomerX509 {\n  /**\n   * PEM string containing one or more customer CAs for database user authentication.\n   *\n   * @schema customerX509#Cas\n   */\n  readonly cas?: string;\n}\n\n/**\n * Converts an object of type 'CustomerX509' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CustomerX509(\n  obj: CustomerX509 | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Cas: obj.cas,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::X509AuthenticationDatabaseUser`\n *\n * @cloudformationResource MongoDB::Atlas::X509AuthenticationDatabaseUser\n * @stability external\n */\nexport class CfnX509AuthenticationDatabaseUser extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::X509AuthenticationDatabaseUser\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnX509AuthenticationDatabaseUserProps;\n\n  /**\n   * Create a new `MongoDB::Atlas::X509AuthenticationDatabaseUser`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnX509AuthenticationDatabaseUserProps\n  ) {\n    super(scope, id, {\n      type: CfnX509AuthenticationDatabaseUser.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnX509AuthenticationDatabaseUserProps(props)!,\n    });\n\n    this.props = props;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/x509-authentication-database-user/index.ts"],"names":[],"mappings":";;;;;AAAA,0BAA0B;AAC1B,mCAAmC;AA0CnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,6CAA6C,CAC3D,GAAuD;IAEvD,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,YAAY,EAAE,mBAAmB,CAAC,GAAG,CAAC,YAAY,CAAC;QACnD,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,SAAS,EAAE,GAAG,CAAC,SAAS;KACzB,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAjBD,sGAiBC;AAeD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,mBAAmB,CACjC,GAA6B;IAE7B,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,OAAO,SAAS,CAAC;KAClB;IACD,MAAM,MAAM,GAAG;QACb,GAAG,EAAE,GAAG,CAAC,GAAG;KACb,CAAC;IACF,0BAA0B;IAC1B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3D,EAAE,CACH,CAAC;AACJ,CAAC;AAdD,kDAcC;AACD,wCAAwC;AAExC;;;;;GAKG;AACH,MAAa,iCAAkC,SAAQ,GAAG,CAAC,WAAW;IAqBpE;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAA6C;QAE7C,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,iCAAiC,CAAC,sBAAsB;YAC9D,UAAU,EAAE,6CAA6C,CAAC,KAAK,CAAE;SAClE,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;QACpE,IAAI,CAAC,yBAAyB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CACjD,IAAI,CAAC,MAAM,CAAC,uBAAuB,CAAC,CACrC,CAAC;IACJ,CAAC;;AA5CH,8EA6CC;;;AA5CC;;GAEG;AACoB,wDAAsB,GAC3C,gDAAgD,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Generates one X.509 certificate for the specified MongoDB user. Atlas manages the certificate and MongoDB user that belong to one project. To use this resource, the requesting API Key must have the Project Atlas Admin role. This resource doesn't require the API Key to have an Access List.\n *\n * To get MongoDB Cloud to generate a managed certificate for a database user, set `\"x509Type\" : \"MANAGED\"` on the desired MongoDB Database User.\n *\n * If you are managing your own Certificate Authority (CA) in Self-Managed X.509 mode, you must generate certificates for database users using your own CA.\n *\n * @schema CfnX509AuthenticationDatabaseUserProps\n */\nexport interface CfnX509AuthenticationDatabaseUserProps {\n  /**\n   * Profile used to provide credentials information, (a secret with the cfn/atlas/profile/{Profile}, is required), if not provided default is used\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * CustomerX509 represents Customer-managed X.509 configuration for an Atlas project.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#CustomerX509\n   */\n  readonly customerX509?: CustomerX509;\n\n  /**\n   * Username of the database user to create a certificate for.\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#UserName\n   */\n  readonly userName?: string;\n\n  /**\n   * The unique identifier for the project .\n   *\n   * @schema CfnX509AuthenticationDatabaseUserProps#ProjectId\n   */\n  readonly projectId?: string;\n}\n\n/**\n * Converts an object of type 'CfnX509AuthenticationDatabaseUserProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnX509AuthenticationDatabaseUserProps(\n  obj: CfnX509AuthenticationDatabaseUserProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    CustomerX509: toJson_CustomerX509(obj.customerX509),\n    UserName: obj.userName,\n    ProjectId: obj.projectId,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * @schema customerX509\n */\nexport interface CustomerX509 {\n  /**\n   * PEM string containing one or more customer CAs for database user authentication.\n   *\n   * @schema customerX509#Cas\n   */\n  readonly cas?: string;\n}\n\n/**\n * Converts an object of type 'CustomerX509' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CustomerX509(\n  obj: CustomerX509 | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Cas: obj.cas,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce(\n    (r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }),\n    {}\n  );\n}\n/* eslint-enable max-len, quote-props */\n\n/**\n * A CloudFormation `MongoDB::Atlas::X509AuthenticationDatabaseUser`\n *\n * @cloudformationResource MongoDB::Atlas::X509AuthenticationDatabaseUser\n * @stability external\n */\nexport class CfnX509AuthenticationDatabaseUser extends cdk.CfnResource {\n  /**\n   * The CloudFormation resource type name for this resource class.\n   */\n  public static readonly CFN_RESOURCE_TYPE_NAME =\n    \"MongoDB::Atlas::X509AuthenticationDatabaseUser\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnX509AuthenticationDatabaseUserProps;\n\n  /**\n   * Attribute `MongoDB::Atlas::X509AuthenticationDatabaseUser.TotalCount`\n   */\n  public readonly attrTotalCount: number;\n  /**\n   * Attribute `MongoDB::Atlas::X509AuthenticationDatabaseUser.MonthsUntilExpiration`\n   */\n  public readonly attrMonthsUntilExpiration: number;\n\n  /**\n   * Create a new `MongoDB::Atlas::X509AuthenticationDatabaseUser`.\n   *\n   * @param scope - scope in which this resource is defined\n   * @param id    - scoped id of the resource\n   * @param props - resource properties\n   */\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: CfnX509AuthenticationDatabaseUserProps\n  ) {\n    super(scope, id, {\n      type: CfnX509AuthenticationDatabaseUser.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnX509AuthenticationDatabaseUserProps(props)!,\n    });\n\n    this.props = props;\n\n    this.attrTotalCount = cdk.Token.asNumber(this.getAtt(\"TotalCount\"));\n    this.attrMonthsUntilExpiration = cdk.Token.asNumber(\n      this.getAtt(\"MonthsUntilExpiration\")\n    );\n  }\n}\n"]}

@@ -49,3 +49,3 @@ "use strict";

this.cfnEncryptionAtRest = new index_1.CfnEncryptionAtRest(this, "AtlasEncryptionAtRest", {
awsKms: {
awsKmsConfig: {
enabled: props.enabled == undefined ? true : props.enabled,

@@ -63,3 +63,3 @@ region: !props.region ? US_EAST_1 : props.region,

_a = JSII_RTTI_SYMBOL_1;
AtlasEncryptionAtRest[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasEncryptionAtRest", version: "3.7.2" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbDItcmVzb3VyY2VzL2VuY3J5cHRpb24tYXQtcmVzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUE2QjtBQUM3QixFQUFFO0FBQ0Ysa0VBQWtFO0FBQ2xFLG1FQUFtRTtBQUNuRSwwQ0FBMEM7QUFDMUMsRUFBRTtBQUNGLGtEQUFrRDtBQUNsRCxFQUFFO0FBQ0Ysc0VBQXNFO0FBQ3RFLG9FQUFvRTtBQUNwRSwyRUFBMkU7QUFDM0Usc0VBQXNFO0FBQ3RFLGlDQUFpQztBQUVqQywyQ0FBdUM7QUFDdkMsdUNBQWtEO0FBRWxELE1BQU0sU0FBUyxHQUFHLFdBQVcsQ0FBQztBQTRDOUI7OztHQUdHO0FBQ0gsTUFBTSxRQUFRLEdBQUcsQ0FBQyxLQUFpQyxFQUFFLEVBQUU7SUFDckQsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUU7UUFDcEIsTUFBTSxLQUFLLENBQUMsNENBQTRDLENBQUMsQ0FBQztLQUMzRDtJQUVELElBQUksQ0FBQyxLQUFLLENBQUMsbUJBQW1CLEVBQUU7UUFDOUIsTUFBTSxLQUFLLENBQUMsc0RBQXNELENBQUMsQ0FBQztLQUNyRTtJQUVELElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO1FBQ2pCLE1BQU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDLENBQUM7S0FDeEQ7QUFDSCxDQUFDLENBQUM7QUFFRjs7Ozs7O0dBTUc7QUFDSCxNQUFhLHFCQUFzQixTQUFRLHNCQUFTO0lBU2xELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBaUM7UUFDekUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEIsSUFBSSxDQUFDLG1CQUFtQixHQUFHLElBQUksMkJBQW1CLENBQ2hELElBQUksRUFDSix1QkFBdUIsRUFDdkI7WUFDRSxNQUFNLEVBQUU7Z0JBQ04sT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPO2dCQUMxRCxNQUFNLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNO2dCQUNoRCxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Z0JBQ3BCLG1CQUFtQixFQUFFLEtBQUssQ0FBQyxtQkFBbUI7YUFDL0M7WUFDRCxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87WUFDdEIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1NBQzNCLENBQ0YsQ0FBQztJQUNKLENBQUM7O0FBM0JILHNEQTRCQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAyMDIzIE1vbmdvREIgSW5jXG4vL1xuLy8gTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbi8vIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbi8vIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuLy8gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuLy8gV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4vLyBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4vLyBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cblxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IENmbkVuY3J5cHRpb25BdFJlc3QgfSBmcm9tIFwiLi4vLi4vaW5kZXhcIjtcblxuY29uc3QgVVNfRUFTVF8xID0gXCJVU19FQVNUXzFcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBdGxhc0VuY3J5cHRpb25BdFJlc3RQcm9wcyB7XG4gIC8qKlxuICAgKiBJRCBvZiBhbiBBV1MgSUFNIHJvbGUgYXV0aG9yaXplZCB0byBtYW5hZ2UgYW4gQVdTIGN1c3RvbWVyIG1hc3RlciBrZXkuXG4gICAqXG4gICAqIEBzY2hlbWEgQXdzS21zI1JvbGVJRFxuICAgKi9cbiAgcmVhZG9ubHkgcm9sZUlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgQVdTIGN1c3RvbWVyIG1hc3RlciBrZXkgdXNlZCB0byBlbmNyeXB0IGFuZCBkZWNyeXB0IHRoZSBNb25nb0RCIG1hc3RlciBrZXlzLlxuICAgKlxuICAgKiBAc2NoZW1hIEF3c0ttcyNDdXN0b21lck1hc3RlcktleUlEXG4gICAqL1xuICByZWFkb25seSBjdXN0b21lck1hc3RlcktleUlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgd2hldGhlciBFbmNyeXB0aW9uIGF0IFJlc3QgaXMgZW5hYmxlZCBmb3IgYW4gQXRsYXMgcHJvamVjdC4gVG8gZGlzYWJsZSBFbmNyeXB0aW9uIGF0IFJlc3QsIHBhc3Mgb25seSB0aGlzIHBhcmFtZXRlciB3aXRoIGEgdmFsdWUgb2YgZmFsc2UuIFdoZW4geW91IGRpc2FibGUgRW5jcnlwdGlvbiBhdCBSZXN0LCBBdGxhcyBhbHNvIHJlbW92ZXMgdGhlIGNvbmZpZ3VyYXRpb24gZGV0YWlscy5cbiAgICogRGVmYXVsdCBWYWx1ZTogdHJ1ZVxuICAgKiBAc2NoZW1hIEF3c0ttcyNFbmFibGVkXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFRoZSBBV1MgcmVnaW9uIGluIHdoaWNoIHRoZSBBV1MgY3VzdG9tZXIgbWFzdGVyIGtleSBleGlzdHMuXG4gICAqIERlZmF1bHQgVmFsdWU6IFVTX0VBU1RfMVxuICAgKiBAc2NoZW1hIEF3c0ttcyNSZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIEF0bGFzIHByb2plY3QgdG8gd2hpY2ggdGhlIHVzZXIgYmVsb25ncy5cbiAgICpcbiAgICogQHNjaGVtYSBDZm5FbmNyeXB0aW9uQXRSZXN0UHJvcHMjUHJvamVjdElkXG4gICAqL1xuICByZWFkb25seSBwcm9qZWN0SWQ6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHByb2ZpbGUgaXMgZGVmaW5lZCBpbiBBV1MgU2VjcmV0IG1hbmFnZXIuXG4gICAqIFNlZSBbU2VjcmV0IE1hbmFnZXIgUHJvZmlsZSBzZXR1cF0oLi4vLi4vLi4vZXhhbXBsZXMvcHJvZmlsZS1zZWNyZXQueWFtbCkuXG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuRW5jcnlwdGlvbkF0UmVzdFByb3BzI1Byb2ZpbGVcbiAgICovXG4gIHJlYWRvbmx5IHByb2ZpbGU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogSXQgdGhyb3dzIGFuIGVycm9yIGlmIGFueSBvZiB0aGUgcmVxdWlyZWQgcHJvcGVydGllcyBhcmUgbm90IGRlZmluZWRcbiAqIEBwYXJhbSB7QXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHN9IHByb3BzIC0gQXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHNcbiAqL1xuY29uc3QgdmFsaWRhdGUgPSAocHJvcHM6IEF0bGFzRW5jcnlwdGlvbkF0UmVzdFByb3BzKSA9PiB7XG4gIGlmICghcHJvcHMucHJvamVjdElkKSB7XG4gICAgdGhyb3cgRXJyb3IoXCJWYWxpZGF0aW9uIGVycm9yOiBwcm9qZWN0SWQgaXMgbm90IGRlZmluZWRcIik7XG4gIH1cblxuICBpZiAoIXByb3BzLmN1c3RvbWVyTWFzdGVyS2V5SWQpIHtcbiAgICB0aHJvdyBFcnJvcihcIlZhbGlkYXRpb24gZXJyb3I6IGN1c3RvbWVyTWFzdGVyS2V5SWQgaXMgbm90IGRlZmluZWRcIik7XG4gIH1cblxuICBpZiAoIXByb3BzLnJvbGVJZCkge1xuICAgIHRocm93IEVycm9yKFwiVmFsaWRhdGlvbiBlcnJvcjogcm9sZUlkIGlzIG5vdCBkZWZpbmVkXCIpO1xuICB9XG59O1xuXG4vKipcbiAqXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIEF0bGFzRW5jcnlwdGlvbkF0UmVzdFxuICogQGV4dGVuZHMge0NvbnN0cnVjdH1cbiAqL1xuZXhwb3J0IGNsYXNzIEF0bGFzRW5jcnlwdGlvbkF0UmVzdCBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8qKlxuICAgKlxuICAgKlxuICAgKiBAdHlwZSB7Q2ZuRW5jcnlwdGlvbkF0UmVzdH1cbiAgICogQG1lbWJlcm9mIEF0bGFzRW5jcnlwdGlvbkF0UmVzdFxuICAgKi9cbiAgcmVhZG9ubHkgY2ZuRW5jcnlwdGlvbkF0UmVzdDogQ2ZuRW5jcnlwdGlvbkF0UmVzdDtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdmFsaWRhdGUocHJvcHMpO1xuICAgIHRoaXMuY2ZuRW5jcnlwdGlvbkF0UmVzdCA9IG5ldyBDZm5FbmNyeXB0aW9uQXRSZXN0KFxuICAgICAgdGhpcyxcbiAgICAgIFwiQXRsYXNFbmNyeXB0aW9uQXRSZXN0XCIsXG4gICAgICB7XG4gICAgICAgIGF3c0ttczoge1xuICAgICAgICAgIGVuYWJsZWQ6IHByb3BzLmVuYWJsZWQgPT0gdW5kZWZpbmVkID8gdHJ1ZSA6IHByb3BzLmVuYWJsZWQsXG4gICAgICAgICAgcmVnaW9uOiAhcHJvcHMucmVnaW9uID8gVVNfRUFTVF8xIDogcHJvcHMucmVnaW9uLFxuICAgICAgICAgIHJvbGVJZDogcHJvcHMucm9sZUlkLFxuICAgICAgICAgIGN1c3RvbWVyTWFzdGVyS2V5SWQ6IHByb3BzLmN1c3RvbWVyTWFzdGVyS2V5SWQsXG4gICAgICAgIH0sXG4gICAgICAgIHByb2ZpbGU6IHByb3BzLnByb2ZpbGUsXG4gICAgICAgIHByb2plY3RJZDogcHJvcHMucHJvamVjdElkLFxuICAgICAgfVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
AtlasEncryptionAtRest[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasEncryptionAtRest", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbDItcmVzb3VyY2VzL2VuY3J5cHRpb24tYXQtcmVzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUE2QjtBQUM3QixFQUFFO0FBQ0Ysa0VBQWtFO0FBQ2xFLG1FQUFtRTtBQUNuRSwwQ0FBMEM7QUFDMUMsRUFBRTtBQUNGLGtEQUFrRDtBQUNsRCxFQUFFO0FBQ0Ysc0VBQXNFO0FBQ3RFLG9FQUFvRTtBQUNwRSwyRUFBMkU7QUFDM0Usc0VBQXNFO0FBQ3RFLGlDQUFpQztBQUVqQywyQ0FBdUM7QUFDdkMsdUNBQWtEO0FBRWxELE1BQU0sU0FBUyxHQUFHLFdBQVcsQ0FBQztBQTRDOUI7OztHQUdHO0FBQ0gsTUFBTSxRQUFRLEdBQUcsQ0FBQyxLQUFpQyxFQUFFLEVBQUU7SUFDckQsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUU7UUFDcEIsTUFBTSxLQUFLLENBQUMsNENBQTRDLENBQUMsQ0FBQztLQUMzRDtJQUVELElBQUksQ0FBQyxLQUFLLENBQUMsbUJBQW1CLEVBQUU7UUFDOUIsTUFBTSxLQUFLLENBQUMsc0RBQXNELENBQUMsQ0FBQztLQUNyRTtJQUVELElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO1FBQ2pCLE1BQU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDLENBQUM7S0FDeEQ7QUFDSCxDQUFDLENBQUM7QUFFRjs7Ozs7O0dBTUc7QUFDSCxNQUFhLHFCQUFzQixTQUFRLHNCQUFTO0lBU2xELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBaUM7UUFDekUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEIsSUFBSSxDQUFDLG1CQUFtQixHQUFHLElBQUksMkJBQW1CLENBQ2hELElBQUksRUFDSix1QkFBdUIsRUFDdkI7WUFDRSxZQUFZLEVBQUU7Z0JBQ1osT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPO2dCQUMxRCxNQUFNLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNO2dCQUNoRCxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Z0JBQ3BCLG1CQUFtQixFQUFFLEtBQUssQ0FBQyxtQkFBbUI7YUFDL0M7WUFDRCxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87WUFDdEIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1NBQzNCLENBQ0YsQ0FBQztJQUNKLENBQUM7O0FBM0JILHNEQTRCQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAyMDIzIE1vbmdvREIgSW5jXG4vL1xuLy8gTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbi8vIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbi8vIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuLy8gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuLy8gV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4vLyBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4vLyBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cblxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IENmbkVuY3J5cHRpb25BdFJlc3QgfSBmcm9tIFwiLi4vLi4vaW5kZXhcIjtcblxuY29uc3QgVVNfRUFTVF8xID0gXCJVU19FQVNUXzFcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBdGxhc0VuY3J5cHRpb25BdFJlc3RQcm9wcyB7XG4gIC8qKlxuICAgKiBJRCBvZiBhbiBBV1MgSUFNIHJvbGUgYXV0aG9yaXplZCB0byBtYW5hZ2UgYW4gQVdTIGN1c3RvbWVyIG1hc3RlciBrZXkuXG4gICAqXG4gICAqIEBzY2hlbWEgQXdzS21zI1JvbGVJRFxuICAgKi9cbiAgcmVhZG9ubHkgcm9sZUlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgQVdTIGN1c3RvbWVyIG1hc3RlciBrZXkgdXNlZCB0byBlbmNyeXB0IGFuZCBkZWNyeXB0IHRoZSBNb25nb0RCIG1hc3RlciBrZXlzLlxuICAgKlxuICAgKiBAc2NoZW1hIEF3c0ttcyNDdXN0b21lck1hc3RlcktleUlEXG4gICAqL1xuICByZWFkb25seSBjdXN0b21lck1hc3RlcktleUlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgd2hldGhlciBFbmNyeXB0aW9uIGF0IFJlc3QgaXMgZW5hYmxlZCBmb3IgYW4gQXRsYXMgcHJvamVjdC4gVG8gZGlzYWJsZSBFbmNyeXB0aW9uIGF0IFJlc3QsIHBhc3Mgb25seSB0aGlzIHBhcmFtZXRlciB3aXRoIGEgdmFsdWUgb2YgZmFsc2UuIFdoZW4geW91IGRpc2FibGUgRW5jcnlwdGlvbiBhdCBSZXN0LCBBdGxhcyBhbHNvIHJlbW92ZXMgdGhlIGNvbmZpZ3VyYXRpb24gZGV0YWlscy5cbiAgICogRGVmYXVsdCBWYWx1ZTogdHJ1ZVxuICAgKiBAc2NoZW1hIEF3c0ttcyNFbmFibGVkXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFRoZSBBV1MgcmVnaW9uIGluIHdoaWNoIHRoZSBBV1MgY3VzdG9tZXIgbWFzdGVyIGtleSBleGlzdHMuXG4gICAqIERlZmF1bHQgVmFsdWU6IFVTX0VBU1RfMVxuICAgKiBAc2NoZW1hIEF3c0ttcyNSZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIEF0bGFzIHByb2plY3QgdG8gd2hpY2ggdGhlIHVzZXIgYmVsb25ncy5cbiAgICpcbiAgICogQHNjaGVtYSBDZm5FbmNyeXB0aW9uQXRSZXN0UHJvcHMjUHJvamVjdElkXG4gICAqL1xuICByZWFkb25seSBwcm9qZWN0SWQ6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHByb2ZpbGUgaXMgZGVmaW5lZCBpbiBBV1MgU2VjcmV0IG1hbmFnZXIuXG4gICAqIFNlZSBbU2VjcmV0IE1hbmFnZXIgUHJvZmlsZSBzZXR1cF0oLi4vLi4vLi4vZXhhbXBsZXMvcHJvZmlsZS1zZWNyZXQueWFtbCkuXG4gICAqXG4gICAqIEBzY2hlbWEgQ2ZuRW5jcnlwdGlvbkF0UmVzdFByb3BzI1Byb2ZpbGVcbiAgICovXG4gIHJlYWRvbmx5IHByb2ZpbGU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogSXQgdGhyb3dzIGFuIGVycm9yIGlmIGFueSBvZiB0aGUgcmVxdWlyZWQgcHJvcGVydGllcyBhcmUgbm90IGRlZmluZWRcbiAqIEBwYXJhbSB7QXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHN9IHByb3BzIC0gQXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHNcbiAqL1xuY29uc3QgdmFsaWRhdGUgPSAocHJvcHM6IEF0bGFzRW5jcnlwdGlvbkF0UmVzdFByb3BzKSA9PiB7XG4gIGlmICghcHJvcHMucHJvamVjdElkKSB7XG4gICAgdGhyb3cgRXJyb3IoXCJWYWxpZGF0aW9uIGVycm9yOiBwcm9qZWN0SWQgaXMgbm90IGRlZmluZWRcIik7XG4gIH1cblxuICBpZiAoIXByb3BzLmN1c3RvbWVyTWFzdGVyS2V5SWQpIHtcbiAgICB0aHJvdyBFcnJvcihcIlZhbGlkYXRpb24gZXJyb3I6IGN1c3RvbWVyTWFzdGVyS2V5SWQgaXMgbm90IGRlZmluZWRcIik7XG4gIH1cblxuICBpZiAoIXByb3BzLnJvbGVJZCkge1xuICAgIHRocm93IEVycm9yKFwiVmFsaWRhdGlvbiBlcnJvcjogcm9sZUlkIGlzIG5vdCBkZWZpbmVkXCIpO1xuICB9XG59O1xuXG4vKipcbiAqXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIEF0bGFzRW5jcnlwdGlvbkF0UmVzdFxuICogQGV4dGVuZHMge0NvbnN0cnVjdH1cbiAqL1xuZXhwb3J0IGNsYXNzIEF0bGFzRW5jcnlwdGlvbkF0UmVzdCBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8qKlxuICAgKlxuICAgKlxuICAgKiBAdHlwZSB7Q2ZuRW5jcnlwdGlvbkF0UmVzdH1cbiAgICogQG1lbWJlcm9mIEF0bGFzRW5jcnlwdGlvbkF0UmVzdFxuICAgKi9cbiAgcmVhZG9ubHkgY2ZuRW5jcnlwdGlvbkF0UmVzdDogQ2ZuRW5jcnlwdGlvbkF0UmVzdDtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXRsYXNFbmNyeXB0aW9uQXRSZXN0UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdmFsaWRhdGUocHJvcHMpO1xuICAgIHRoaXMuY2ZuRW5jcnlwdGlvbkF0UmVzdCA9IG5ldyBDZm5FbmNyeXB0aW9uQXRSZXN0KFxuICAgICAgdGhpcyxcbiAgICAgIFwiQXRsYXNFbmNyeXB0aW9uQXRSZXN0XCIsXG4gICAgICB7XG4gICAgICAgIGF3c0ttc0NvbmZpZzoge1xuICAgICAgICAgIGVuYWJsZWQ6IHByb3BzLmVuYWJsZWQgPT0gdW5kZWZpbmVkID8gdHJ1ZSA6IHByb3BzLmVuYWJsZWQsXG4gICAgICAgICAgcmVnaW9uOiAhcHJvcHMucmVnaW9uID8gVVNfRUFTVF8xIDogcHJvcHMucmVnaW9uLFxuICAgICAgICAgIHJvbGVJZDogcHJvcHMucm9sZUlkLFxuICAgICAgICAgIGN1c3RvbWVyTWFzdGVyS2V5SWQ6IHByb3BzLmN1c3RvbWVyTWFzdGVyS2V5SWQsXG4gICAgICAgIH0sXG4gICAgICAgIHByb2ZpbGU6IHByb3BzLnByb2ZpbGUsXG4gICAgICAgIHByb2plY3RJZDogcHJvcHMucHJvamVjdElkLFxuICAgICAgfVxuICAgICk7XG4gIH1cbn1cbiJdfQ==

@@ -50,3 +50,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
DatadogIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.DatadogIntegration", version: "3.7.2" };
DatadogIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.DatadogIntegration", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWRvZ0ludGVncmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2wyLXJlc291cmNlcy90aGlyZC1wYXJ0eS1pbnRlZ3JhdGlvbi9kYXRhZG9nSW50ZWdyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2QkFBNkI7QUFDN0IsRUFBRTtBQUNGLGtFQUFrRTtBQUNsRSxtRUFBbUU7QUFDbkUsMENBQTBDO0FBQzFDLEVBQUU7QUFDRixrREFBa0Q7QUFDbEQsRUFBRTtBQUNGLHNFQUFzRTtBQUN0RSxvRUFBb0U7QUFDcEUsMkVBQTJFO0FBQzNFLHNFQUFzRTtBQUN0RSxpQ0FBaUM7QUFFakMsMkNBQXVDO0FBRXZDLCtCQUErQjtBQUMvQix1Q0FHcUI7QUFFckIsSUFBWSxhQUtYO0FBTEQsV0FBWSxhQUFhO0lBQ3ZCLDBCQUFTLENBQUE7SUFDVCwwQkFBUyxDQUFBO0lBQ1QsNEJBQVcsQ0FBQTtJQUNYLDRCQUFXLENBQUE7QUFDYixDQUFDLEVBTFcsYUFBYSxHQUFiLHFCQUFhLEtBQWIscUJBQWEsUUFLeEI7QUFjRCxNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQThCLEVBQUUsRUFBRTtJQUNsRCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO1FBQ2pCLE1BQU0sS0FBSyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0tBQ2pEO0lBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7UUFDakIsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7S0FDakQ7QUFDSCxDQUFDLENBQUM7QUFFRixNQUFhLGtCQUFtQixTQUFRLHNCQUFTO0lBRy9DLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBOEI7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFaEIsSUFBSSxDQUFDLHdCQUF3QixHQUFHLElBQUksZ0NBQXdCLENBQzFELElBQUksRUFDSixxQkFBcUIsRUFDckI7WUFDRSxHQUFHLEtBQUs7WUFDUixJQUFJLEVBQUUseUNBQWlDLENBQUMsT0FBTztTQUNoRCxDQUNGLENBQUM7SUFDSixDQUFDOztBQWZILGdEQWdCQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAyMDIzIE1vbmdvREIgSW5jXG4vL1xuLy8gTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbi8vIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbi8vIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuLy8gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuLy8gV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4vLyBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4vLyBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cblxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IFRoaXJkUGFydHlJbnRlZ3JhdGlvblByb3BzIH0gZnJvbSBcIi4vdGhpcmRQYXJ0eUludGVncmF0aW9uQmFzZVwiO1xuaW1wb3J0ICogYXMgdXRpbCBmcm9tIFwiLi91dGlsXCI7XG5pbXBvcnQge1xuICBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb24sXG4gIENmblRoaXJkUGFydHlJbnRlZ3JhdGlvblByb3BzVHlwZSxcbn0gZnJvbSBcIi4uLy4uL2luZGV4XCI7XG5cbmV4cG9ydCBlbnVtIERhdGFkb2dSZWdpb24ge1xuICBVUyA9IFwiVVNcIixcbiAgRVUgPSBcIkVVXCIsXG4gIFVTMyA9IFwiVVMzXCIsXG4gIFVTNSA9IFwiVVM1XCIsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGF0YWRvZ0ludGVncmF0aW9uUHJvcHMgZXh0ZW5kcyBUaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBLZXkgdGhhdCBhbGxvd3MgTW9uZ29EQiBDbG91ZCB0byBhY2Nlc3MgeW91ciBEYXRhZG9nIGFjY291bnQuXG4gICAqL1xuICByZWFkb25seSBhcGlLZXk6IHN0cmluZztcblxuICAvKipcbiAgICogVHdvLWxldHRlciBjb2RlIHRoYXQgaW5kaWNhdGVzIHdoaWNoIHJlZ2lvbmFsIFVSTCBNb25nb0RCIHVzZXMgdG8gYWNjZXNzIHRoZSBEYXRhZG9nIEFQSS5cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbjogRGF0YWRvZ1JlZ2lvbjtcbn1cblxuY29uc3QgdmFsaWRhdGUgPSAocHJvcHM6IERhdGFkb2dJbnRlZ3JhdGlvblByb3BzKSA9PiB7XG4gIHV0aWwudmFsaWRhdGUocHJvcHMpO1xuICBpZiAoIXByb3BzLmFwaUtleSkge1xuICAgIHRocm93IEVycm9yKHV0aWwuZ2V0UHJvcFVuZGVmaW5lZE1zZyhcImFwaUtleVwiKSk7XG4gIH1cbiAgaWYgKCFwcm9wcy5yZWdpb24pIHtcbiAgICB0aHJvdyBFcnJvcih1dGlsLmdldFByb3BVbmRlZmluZWRNc2coXCJyZWdpb25cIikpO1xuICB9XG59O1xuXG5leHBvcnQgY2xhc3MgRGF0YWRvZ0ludGVncmF0aW9uIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcmVhZG9ubHkgY2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uOiBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IERhdGFkb2dJbnRlZ3JhdGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICB2YWxpZGF0ZShwcm9wcyk7XG5cbiAgICB0aGlzLmNmblRoaXJkUGFydHlJbnRlZ3JhdGlvbiA9IG5ldyBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb24oXG4gICAgICB0aGlzLFxuICAgICAgXCJEQVRBRE9HX0ludGVncmF0aW9uXCIsXG4gICAgICB7XG4gICAgICAgIC4uLnByb3BzLFxuICAgICAgICB0eXBlOiBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wc1R5cGUuREFUQURPRyxcbiAgICAgIH1cbiAgICApO1xuICB9XG59XG4iXX0=

@@ -40,3 +40,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
MicrosoftTeamsIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.MicrosoftTeamsIntegration", version: "3.7.2" };
MicrosoftTeamsIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.MicrosoftTeamsIntegration", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWljcm9zb2Z0VGVhbXNJbnRlZ3JhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sMi1yZXNvdXJjZXMvdGhpcmQtcGFydHktaW50ZWdyYXRpb24vbWljcm9zb2Z0VGVhbXNJbnRlZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUE2QjtBQUM3QixFQUFFO0FBQ0Ysa0VBQWtFO0FBQ2xFLG1FQUFtRTtBQUNuRSwwQ0FBMEM7QUFDMUMsRUFBRTtBQUNGLGtEQUFrRDtBQUNsRCxFQUFFO0FBQ0Ysc0VBQXNFO0FBQ3RFLG9FQUFvRTtBQUNwRSwyRUFBMkU7QUFDM0Usc0VBQXNFO0FBQ3RFLGlDQUFpQztBQUVqQywyQ0FBdUM7QUFFdkMsK0JBQStCO0FBQy9CLHVDQUdxQjtBQVVyQixNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQXFDLEVBQUUsRUFBRTtJQUN6RCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsd0JBQXdCLEVBQUU7UUFDbkMsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLDBCQUEwQixDQUFDLENBQUMsQ0FBQztLQUNuRTtBQUNILENBQUMsQ0FBQztBQUVGLE1BQWEseUJBQTBCLFNBQVEsc0JBQVM7SUFHdEQsWUFDRSxLQUFnQixFQUNoQixFQUFVLEVBQ1YsS0FBcUM7UUFFckMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFaEIsSUFBSSxDQUFDLHdCQUF3QixHQUFHLElBQUksZ0NBQXdCLENBQzFELElBQUksRUFDSiw2QkFBNkIsRUFDN0I7WUFDRSxHQUFHLEtBQUs7WUFDUixJQUFJLEVBQUUseUNBQWlDLENBQUMsZUFBZTtTQUN4RCxDQUNGLENBQUM7SUFDSixDQUFDOztBQW5CSCw4REFvQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgMjAyMyBNb25nb0RCIEluY1xuLy9cbi8vIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIik7XG4vLyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4vLyBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbi8vXG4vLyAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuLy9cbi8vIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbi8vIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbi8vIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuLy8gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuLy8gbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG5cbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBUaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wcyB9IGZyb20gXCIuL3RoaXJkUGFydHlJbnRlZ3JhdGlvbkJhc2VcIjtcbmltcG9ydCAqIGFzIHV0aWwgZnJvbSBcIi4vdXRpbFwiO1xuaW1wb3J0IHtcbiAgQ2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uLFxuICBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wc1R5cGUsXG59IGZyb20gXCIuLi8uLi9pbmRleFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1pY3Jvc29mdFRlYW1zSW50ZWdyYXRpb25Qcm9wc1xuICBleHRlbmRzIFRoaXJkUGFydHlJbnRlZ3JhdGlvblByb3BzIHtcbiAgLyoqXG4gICAqIEVuZHBvaW50IHdlYiBhZGRyZXNzIG9mIHRoZSBNaWNyb3NvZnQgVGVhbXMgd2ViaG9vayB0byB3aGljaCBNb25nb0RCIENsb3VkIHNlbmRzIG5vdGlmaWNhdGlvbnMuXG4gICAqL1xuICByZWFkb25seSBtaWNyb3NvZnRUZWFtc1dlYmhvb2tVcmw6IHN0cmluZztcbn1cblxuY29uc3QgdmFsaWRhdGUgPSAocHJvcHM6IE1pY3Jvc29mdFRlYW1zSW50ZWdyYXRpb25Qcm9wcykgPT4ge1xuICB1dGlsLnZhbGlkYXRlKHByb3BzKTtcbiAgaWYgKCFwcm9wcy5taWNyb3NvZnRUZWFtc1dlYmhvb2tVcmwpIHtcbiAgICB0aHJvdyBFcnJvcih1dGlsLmdldFByb3BVbmRlZmluZWRNc2coXCJtaWNyb3NvZnRUZWFtc1dlYmhvb2tVcmxcIikpO1xuICB9XG59O1xuXG5leHBvcnQgY2xhc3MgTWljcm9zb2Z0VGVhbXNJbnRlZ3JhdGlvbiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHJlYWRvbmx5IGNmblRoaXJkUGFydHlJbnRlZ3JhdGlvbjogQ2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHNjb3BlOiBDb25zdHJ1Y3QsXG4gICAgaWQ6IHN0cmluZyxcbiAgICBwcm9wczogTWljcm9zb2Z0VGVhbXNJbnRlZ3JhdGlvblByb3BzXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgdmFsaWRhdGUocHJvcHMpO1xuXG4gICAgdGhpcy5jZm5UaGlyZFBhcnR5SW50ZWdyYXRpb24gPSBuZXcgQ2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uKFxuICAgICAgdGhpcyxcbiAgICAgIFwiTUlDUk9TT0ZUX1RFQU1TX0ludGVncmF0aW9uXCIsXG4gICAgICB7XG4gICAgICAgIC4uLnByb3BzLFxuICAgICAgICB0eXBlOiBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wc1R5cGUuTUlDUk9TT0ZUX1RFQU1TLFxuICAgICAgfVxuICAgICk7XG4gIH1cbn1cbiJdfQ==

@@ -48,3 +48,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
PagerDutyIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.PagerDutyIntegration", version: "3.7.2" };
PagerDutyIntegration[_a] = { fqn: "awscdk-resources-mongodbatlas.PagerDutyIntegration", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZXJEdXR5SW50ZWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbDItcmVzb3VyY2VzL3RoaXJkLXBhcnR5LWludGVncmF0aW9uL3BhZ2VyRHV0eUludGVncmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsNkJBQTZCO0FBQzdCLEVBQUU7QUFDRixrRUFBa0U7QUFDbEUsbUVBQW1FO0FBQ25FLDBDQUEwQztBQUMxQyxFQUFFO0FBQ0Ysa0RBQWtEO0FBQ2xELEVBQUU7QUFDRixzRUFBc0U7QUFDdEUsb0VBQW9FO0FBQ3BFLDJFQUEyRTtBQUMzRSxzRUFBc0U7QUFDdEUsaUNBQWlDO0FBRWpDLDJDQUF1QztBQUV2QywrQkFBK0I7QUFDL0IsdUNBR3FCO0FBRXJCLElBQVksZUFHWDtBQUhELFdBQVksZUFBZTtJQUN6Qiw0QkFBUyxDQUFBO0lBQ1QsNEJBQVMsQ0FBQTtBQUNYLENBQUMsRUFIVyxlQUFlLEdBQWYsdUJBQWUsS0FBZix1QkFBZSxRQUcxQjtBQWNELE1BQU0sUUFBUSxHQUFHLENBQUMsS0FBZ0MsRUFBRSxFQUFFO0lBQ3BELElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckIsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUU7UUFDckIsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7S0FDckQ7SUFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRTtRQUNqQixNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztLQUNqRDtBQUNILENBQUMsQ0FBQztBQUVGLE1BQWEsb0JBQXFCLFNBQVEsc0JBQVM7SUFHakQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFnQztRQUN4RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVoQixJQUFJLENBQUMsd0JBQXdCLEdBQUcsSUFBSSxnQ0FBd0IsQ0FDMUQsSUFBSSxFQUNKLHdCQUF3QixFQUN4QjtZQUNFLEdBQUcsS0FBSztZQUNSLElBQUksRUFBRSx5Q0FBaUMsQ0FBQyxVQUFVO1NBQ25ELENBQ0YsQ0FBQztJQUNKLENBQUM7O0FBZkgsb0RBZ0JDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IDIwMjMgTW9uZ29EQiBJbmNcbi8vXG4vLyBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuLy8geW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuLy8gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4vLyBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4vLyBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbi8vIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbi8vIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuXG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgVGhpcmRQYXJ0eUludGVncmF0aW9uUHJvcHMgfSBmcm9tIFwiLi90aGlyZFBhcnR5SW50ZWdyYXRpb25CYXNlXCI7XG5pbXBvcnQgKiBhcyB1dGlsIGZyb20gXCIuL3V0aWxcIjtcbmltcG9ydCB7XG4gIENmblRoaXJkUGFydHlJbnRlZ3JhdGlvbixcbiAgQ2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uUHJvcHNUeXBlLFxufSBmcm9tIFwiLi4vLi4vaW5kZXhcIjtcblxuZXhwb3J0IGVudW0gUGFnZXJEdXR5UmVnaW9uIHtcbiAgVVMgPSBcIlVTXCIsXG4gIEVVID0gXCJFVVwiLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2VyRHV0eUludGVncmF0aW9uUHJvcHMgZXh0ZW5kcyBUaGlyZFBhcnR5SW50ZWdyYXRpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBTZXJ2aWNlIGtleSBhc3NvY2lhdGVkIHdpdGggeW91ciBQYWdlckR1dHkgYWNjb3VudC5cbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VLZXk6IHN0cmluZztcblxuICAvKipcbiAgICogUGFnZXJEdXR5IHJlZ2lvbiB0aGF0IGluZGljYXRlcyB0aGUgQVBJIFVuaWZvcm0gUmVzb3VyY2UgTG9jYXRvciAoVVJMKSB0byB1c2UuXG4gICAqL1xuICByZWFkb25seSByZWdpb246IFBhZ2VyRHV0eVJlZ2lvbjtcbn1cblxuY29uc3QgdmFsaWRhdGUgPSAocHJvcHM6IFBhZ2VyRHV0eUludGVncmF0aW9uUHJvcHMpID0+IHtcbiAgdXRpbC52YWxpZGF0ZShwcm9wcyk7XG4gIGlmICghcHJvcHMuc2VydmljZUtleSkge1xuICAgIHRocm93IEVycm9yKHV0aWwuZ2V0UHJvcFVuZGVmaW5lZE1zZyhcInNlcnZpY2VLZXlcIikpO1xuICB9XG4gIGlmICghcHJvcHMucmVnaW9uKSB7XG4gICAgdGhyb3cgRXJyb3IodXRpbC5nZXRQcm9wVW5kZWZpbmVkTXNnKFwicmVnaW9uXCIpKTtcbiAgfVxufTtcblxuZXhwb3J0IGNsYXNzIFBhZ2VyRHV0eUludGVncmF0aW9uIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcmVhZG9ubHkgY2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uOiBDZm5UaGlyZFBhcnR5SW50ZWdyYXRpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFBhZ2VyRHV0eUludGVncmF0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIHZhbGlkYXRlKHByb3BzKTtcblxuICAgIHRoaXMuY2ZuVGhpcmRQYXJ0eUludGVncmF0aW9uID0gbmV3IENmblRoaXJkUGFydHlJbnRlZ3JhdGlvbihcbiAgICAgIHRoaXMsXG4gICAgICBcIlBBR0VSX0RVVFlfSW50ZWdyYXRpb25cIixcbiAgICAgIHtcbiAgICAgICAgLi4ucHJvcHMsXG4gICAgICAgIHR5cGU6IENmblRoaXJkUGFydHlJbnRlZ3JhdGlvblByb3BzVHlwZS5QQUdFUl9EVVRZLFxuICAgICAgfVxuICAgICk7XG4gIH1cbn1cbiJdfQ==

@@ -73,3 +73,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
AtlasBasicPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasBasicPrivateEndpoint", version: "3.7.2" };
AtlasBasicPrivateEndpoint[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasBasicPrivateEndpoint", version: "3.8.0" };
const validate = (props) => {

@@ -76,0 +76,0 @@ if (!props.atlasBasicProps.projectProps.orgId) {

@@ -94,3 +94,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
AtlasBasic[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasBasic", version: "3.7.2" };
AtlasBasic[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasBasic", version: "3.8.0" };
function randomNumber() {

@@ -97,0 +97,0 @@ const min = 10;

@@ -18,3 +18,3 @@ "use strict";

_a = JSII_RTTI_SYMBOL_1;
MongoAtlasBootstrapProps[_a] = { fqn: "awscdk-resources-mongodbatlas.MongoAtlasBootstrapProps", version: "3.7.2" };
MongoAtlasBootstrapProps[_a] = { fqn: "awscdk-resources-mongodbatlas.MongoAtlasBootstrapProps", version: "3.8.0" };
/**

@@ -79,3 +79,3 @@ * Generate the CFN extension execution role.

_b = JSII_RTTI_SYMBOL_1;
MongoAtlasBootstrap[_b] = { fqn: "awscdk-resources-mongodbatlas.MongoAtlasBootstrap", version: "3.7.2" };
MongoAtlasBootstrap[_b] = { fqn: "awscdk-resources-mongodbatlas.MongoAtlasBootstrap", version: "3.8.0" };
class MongoSecretProfile extends constructs_1.Construct {

@@ -99,3 +99,3 @@ constructor(scope, id, profileName) {

_c = JSII_RTTI_SYMBOL_1;
MongoSecretProfile[_c] = { fqn: "awscdk-resources-mongodbatlas.MongoSecretProfile", version: "3.7.2" };
MongoSecretProfile[_c] = { fqn: "awscdk-resources-mongodbatlas.MongoSecretProfile", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/atlas-bootstrap/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CfnOutput,\n  aws_iam as iam,\n  aws_secretsmanager as secretsmanager,\n  aws_cloudformation as cloudformation,\n  SecretValue,\n  Duration,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\n\nexport const AtlasBasicResources: string[] = [\n  \"Cluster\",\n  \"Project\",\n  \"DatabaseUser\",\n  \"ProjectIpAccessList\",\n];\n\nexport class MongoAtlasBootstrapProps {\n  /**\n   * The IAM role name for CloudFormation Extension Execution.\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-public.html\n   * @default auto generat the name.\n   */\n  readonly roleName!: string;\n  /**\n   * The secret profile name for MongoDB Atlas.\n   * @default generate a dummy secret.\n   * @see https://github.com/mongodb/mongodbatlas-cloudformation-resources/tree/master#2-configure-your-profile\n   */\n  readonly secretProfile!: string;\n  /**\n   * List of strings representing mongoDB atlas types to activate.\n   * the exported AtlasBasicResources can be used for AtlasBasic resources\n   * if not provided non resources will be activated\n   * @example typesToActivate=[\"Cluster\",\"Project\"] this will actiate MongoDB::Atlas::Project && MongoDB::Atlas::Cluster\n   */\n  readonly typesToActivate?: string[];\n}\n\n/**\n * Generate the CFN extension execution role.\n * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-public.html\n */\nexport class MongoAtlasBootstrap extends Construct {\n  readonly role: iam.IRole;\n  constructor(scope: Construct, id: string, props?: MongoAtlasBootstrapProps) {\n    super(scope, id);\n\n    this.role = new iam.Role(this, \"mongoDBAtlasCFNExecutionRole\", {\n      maxSessionDuration: Duration.seconds(8400),\n      assumedBy: new iam.CompositePrincipal(\n        new iam.ServicePrincipal(\"cloudformation.amazonaws.com\"),\n        new iam.ServicePrincipal(\"resources.cloudformation.amazonaws.com\"),\n        new iam.ServicePrincipal(\"lambda.amazonaws.com\")\n      ),\n      path: \"/\",\n      roleName: props?.roleName,\n    });\n\n    const policyStatement = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: [\n        \"secretsmanager:DescribeSecret\",\n        \"secretsmanager:GetSecretValue\",\n        \"ec2:CreateVpcEndpoint\",\n        \"ec2:DeleteVpcEndpoints\",\n        \"cloudformation:CreateResource\",\n        \"cloudformation:DeleteResource\",\n        \"cloudformation:GetResource\",\n        \"cloudformation:GetResourceRequestStatus\",\n        \"cloudformation:ListResources\",\n        \"cloudformation:UpdateResource\",\n        \"iam:AttachRolePolicy\",\n        \"iam:CreateRole\",\n        \"iam:DeleteRole\",\n        \"iam:GetRole\",\n        \"iam:GetRolePolicy\",\n        \"iam:ListAttachedRolePolicies\",\n        \"iam:ListRolePolicies\",\n        \"iam:PutRolePolicy\",\n      ],\n      resources: [\"*\"],\n    });\n\n    const atlasCdkPolicy = new iam.Policy(this, \"AtlasCDKExecutionPolicy\", {\n      policyName: \"AtlasCDKExecution\", // Custom Policy Name\n      statements: [policyStatement],\n    });\n\n    this.role.attachInlinePolicy(atlasCdkPolicy);\n\n    if (props?.secretProfile) {\n      new MongoSecretProfile(this, \"MongoSecretProfile\", props?.secretProfile);\n    }\n\n    if (props?.typesToActivate) {\n      for (let type of props?.typesToActivate) {\n        new cloudformation.CfnTypeActivation(this, `${type}TypeActivation`, {\n          executionRoleArn: this.role.roleArn,\n          type: `RESOURCE`,\n          typeName: `MongoDB::Atlas::${type}`,\n          publisherId: \"bb989456c78c398a858fef18f2ca1bfc1fbba082\",\n        });\n      }\n    }\n  }\n}\n\nexport class MongoSecretProfile extends Construct {\n  constructor(scope: Construct, id: string, profileName: string) {\n    super(scope, id);\n\n    // create a secret\n    const secret = new secretsmanager.Secret(this, profileName, {\n      secretName: `cfn/atlas/profile/${profileName}`,\n      description: \"Secret used for MongoDB Atlas Cloud Formation api keys\",\n      secretStringValue: SecretValue.unsafePlainText(\n        '{\"PublicKey\":\"yourAtlasPublicKey\", \"PrivateKey\": \"yourAtlasPrivateKey\"}'\n      ),\n    });\n\n    new CfnOutput(this, \"SecretName\", { value: secret.secretName });\n    new CfnOutput(this, \"UpdateSecretCommand\", {\n      value:\n        `aws secretsmanager update-secret --secret-id ${secret.secretName}` +\n        ' --secret-string \"{\\\\\"PublicKey\\\\\":\\\\\"${MONGO_ATLAS_PUBLIC_KEY}\\\\\",\\\\\"PrivateKey\\\\\":\\\\\"${MONGO_ATLAS_PRIVATE_KEY}\\\\\"}\"',\n    });\n  }\n}\n"]}

@@ -80,3 +80,3 @@ "use strict";

projectId: this.mProject.attrId,
accessList: props.ipAccessListProps?.accessList,
accessList: props.ipAccessListProps?.accessList || [],
...props.ipAccessListProps,

@@ -89,3 +89,3 @@ });

_a = JSII_RTTI_SYMBOL_1;
AtlasServerlessBasic[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasServerlessBasic", version: "3.7.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/atlas-serverless-basic/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport { Construct } from \"constructs\";\nimport * as atlas from \"../../index\";\nimport { AtlasServerlessBasicProps } from \"../common/props\";\n\n/** @type {*} */\nconst dbDefaults = {\n  dbName: \"admin\",\n  username: \"atlas-user\",\n  password: \"atlas-pwd\",\n  roles: [\n    {\n      roleName: \"atlasAdmin\",\n      databaseName: \"admin\",\n    },\n  ],\n};\n\n/**\n * @description\n * @export\n * @class AtlasBasic\n * @extends {Construct}\n */\nexport class AtlasServerlessBasic extends Construct {\n  /**\n   * @description\n   * @type {project.CfnProject}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mProject: atlas.CfnProject;\n  /**\n   * @description\n   * @type {atlas.CfnCluster}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mserverless: atlas.CfnServerlessInstance;\n  /**\n   * @description\n   * @type {user.CfnDatabaseUser}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mDBUser: atlas.CfnDatabaseUser;\n  /**\n   * @description\n   * @type {ipAccessList.CfnProjectIpAccessList}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly ipAccessList: atlas.CfnProjectIpAccessList;\n\n  /**\n   * Creates an instance of AtlasServerlessBasic.\n   * @param {Construct} scope\n   * @param {string} id\n   * @param {AtlasServerlessBasicProps} props\n   * @memberof AtlasServerlessBasic\n   */\n  constructor(scope: Construct, id: string, props: AtlasServerlessBasicProps) {\n    super(scope, id);\n    //Create a new MongoDB Atlas Project\n    this.mProject = new atlas.CfnProject(this, \"project-\".concat(id), {\n      profile: props.profile,\n      name: props.projectProps.name ?? `project-${id}`,\n      ...props.projectProps,\n    });\n    // Create a new serverless Instance and pass project ID\n    this.mserverless = new atlas.CfnServerlessInstance(\n      this,\n      \"serverless-\".concat(id),\n      {\n        projectId: this.mProject.attrId,\n        name: props.serverlessProps.name ?? `serverless-${id}`,\n        providerSettings: props.serverlessProps.providerSettings,\n        profile: props.profile,\n        continuousBackupEnabled: props.serverlessProps.continuousBackupEnabled,\n        ...props.serverlessProps,\n      }\n    );\n    this.mserverless.addDependency(this.mProject);\n    // Create a new MongoDB Atlas Database User\n    this.mDBUser = new atlas.CfnDatabaseUser(this, \"db-user-\".concat(id), {\n      profile: props.profile,\n      databaseName: props.dbUserProps?.databaseName || dbDefaults.dbName,\n      projectId: this.mProject.attrId,\n      username: props.dbUserProps?.username || dbDefaults.username,\n      roles: props.dbUserProps?.roles || dbDefaults.roles,\n      password: props.dbUserProps?.password || dbDefaults.password,\n      ...props.dbUserProps,\n    });\n    this.mDBUser.addDependency(this.mProject);\n    // Create a new MongoDB Atlas Project IP Access List\n    this.ipAccessList = new atlas.CfnProjectIpAccessList(\n      this,\n      \"ip-access-list-\".concat(id),\n      {\n        profile: props.profile,\n        projectId: this.mProject.attrId,\n        accessList: props.ipAccessListProps?.accessList,\n        ...props.ipAccessListProps,\n      }\n    );\n    this.ipAccessList.addDependency(this.mProject);\n  }\n}\n"]}
AtlasServerlessBasic[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasServerlessBasic", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/atlas-serverless-basic/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport { Construct } from \"constructs\";\nimport * as atlas from \"../../index\";\nimport { AtlasServerlessBasicProps } from \"../common/props\";\n\n/** @type {*} */\nconst dbDefaults = {\n  dbName: \"admin\",\n  username: \"atlas-user\",\n  password: \"atlas-pwd\",\n  roles: [\n    {\n      roleName: \"atlasAdmin\",\n      databaseName: \"admin\",\n    },\n  ],\n};\n\n/**\n * @description\n * @export\n * @class AtlasBasic\n * @extends {Construct}\n */\nexport class AtlasServerlessBasic extends Construct {\n  /**\n   * @description\n   * @type {project.CfnProject}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mProject: atlas.CfnProject;\n  /**\n   * @description\n   * @type {atlas.CfnCluster}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mserverless: atlas.CfnServerlessInstance;\n  /**\n   * @description\n   * @type {user.CfnDatabaseUser}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly mDBUser: atlas.CfnDatabaseUser;\n  /**\n   * @description\n   * @type {ipAccessList.CfnProjectIpAccessList}\n   * @memberof AtlasServerlessBasic\n   */\n  readonly ipAccessList: atlas.CfnProjectIpAccessList;\n\n  /**\n   * Creates an instance of AtlasServerlessBasic.\n   * @param {Construct} scope\n   * @param {string} id\n   * @param {AtlasServerlessBasicProps} props\n   * @memberof AtlasServerlessBasic\n   */\n  constructor(scope: Construct, id: string, props: AtlasServerlessBasicProps) {\n    super(scope, id);\n    //Create a new MongoDB Atlas Project\n    this.mProject = new atlas.CfnProject(this, \"project-\".concat(id), {\n      profile: props.profile,\n      name: props.projectProps.name ?? `project-${id}`,\n      ...props.projectProps,\n    });\n    // Create a new serverless Instance and pass project ID\n    this.mserverless = new atlas.CfnServerlessInstance(\n      this,\n      \"serverless-\".concat(id),\n      {\n        projectId: this.mProject.attrId,\n        name: props.serverlessProps.name ?? `serverless-${id}`,\n        providerSettings: props.serverlessProps.providerSettings,\n        profile: props.profile,\n        continuousBackupEnabled: props.serverlessProps.continuousBackupEnabled,\n        ...props.serverlessProps,\n      }\n    );\n    this.mserverless.addDependency(this.mProject);\n    // Create a new MongoDB Atlas Database User\n    this.mDBUser = new atlas.CfnDatabaseUser(this, \"db-user-\".concat(id), {\n      profile: props.profile,\n      databaseName: props.dbUserProps?.databaseName || dbDefaults.dbName,\n      projectId: this.mProject.attrId,\n      username: props.dbUserProps?.username || dbDefaults.username,\n      roles: props.dbUserProps?.roles || dbDefaults.roles,\n      password: props.dbUserProps?.password || dbDefaults.password,\n      ...props.dbUserProps,\n    });\n    this.mDBUser.addDependency(this.mProject);\n    // Create a new MongoDB Atlas Project IP Access List\n    this.ipAccessList = new atlas.CfnProjectIpAccessList(\n      this,\n      \"ip-access-list-\".concat(id),\n      {\n        profile: props.profile,\n        projectId: this.mProject.attrId,\n        accessList: props.ipAccessListProps?.accessList || [],\n        ...props.ipAccessListProps,\n      }\n    );\n    this.ipAccessList.addDependency(this.mProject);\n  }\n}\n"]}

@@ -91,3 +91,3 @@ "use strict";

this.encryptionAtRest = new atlas.CfnEncryptionAtRest(this, "encryption-at-rest-".concat(id), {
awsKms: {
awsKmsConfig: {
customerMasterKeyId: props.encryptionAtRest.customerMasterKeyId,

@@ -135,3 +135,3 @@ roleId: props.encryptionAtRest.roleId,

_a = JSII_RTTI_SYMBOL_1;
AtlasEncryptionAtRestExpress[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasEncryptionAtRestExpress", version: "3.7.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/encryption-at-rest-express/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport { Construct } from \"constructs\";\nimport * as atlas from \"../../index\";\nimport {\n  ClusterProps,\n  DatabaseUserProps,\n  IpAccessListProps,\n} from \"../common/props\";\n\nconst NODE_COUNT = 3;\nconst NODE_COUNT_ANALYTICS = 1;\nconst BACKUP_ENABLED = true;\nconst INSTANCE_SIZE = \"M30\";\nconst MONGODB_VERSION = \"5.0\";\nconst ENCRYPTION_AT_REST_PROVIDER =\n  atlas.CfnClusterPropsEncryptionAtRestProvider.AWS;\nconst REGION = \"US_EAST_1\";\nconst EBS_VOLUME_TYPE = \"STANDARD\";\nconst ENABLE_ENCRYPTION_AT_REST = true;\nconst CLUSTER_TYPE = \"REPLICASET\";\nconst DB_NAME = \"admin\";\nconst USERNAME = \"cdkUser\";\nconst ROLE = [\n  {\n    roleName: \"atlasAdmin\",\n    databaseName: \"admin\",\n  },\n];\n\nfunction randomNumber() {\n  const min = 10;\n  const max = 9999999;\n  return Math.floor(Math.random() * (max - min + 1) + min);\n}\n\nfunction getClusterProps(\n  inputClusterProps: ClusterProps\n): atlas.CfnClusterProps {\n  return {\n    name:\n      inputClusterProps.name || \"atlas-cluster-\".concat(String(randomNumber())),\n    mongoDbMajorVersion:\n      inputClusterProps.mongoDbMajorVersion || MONGODB_VERSION,\n    backupEnabled: inputClusterProps.backupEnabled ?? BACKUP_ENABLED,\n    diskSizeGb: inputClusterProps.diskSizeGb,\n    clusterType: inputClusterProps.clusterType || CLUSTER_TYPE,\n    biConnector: inputClusterProps.biConnector,\n    encryptionAtRestProvider:\n      inputClusterProps.encryptionAtRestProvider || ENCRYPTION_AT_REST_PROVIDER,\n    labels: inputClusterProps.labels,\n    paused: inputClusterProps.paused,\n    pitEnabled: inputClusterProps.pitEnabled,\n    rootCertType: inputClusterProps.rootCertType,\n    terminationProtectionEnabled:\n      inputClusterProps.terminationProtectionEnabled,\n    versionReleaseSystem: inputClusterProps.versionReleaseSystem,\n    advancedSettings: inputClusterProps.advancedSettings,\n    replicationSpecs:\n      inputClusterProps.replicationSpecs || getDefaultClusterReplicationSpec(),\n    projectId: \"\",\n  };\n}\n\nfunction getDefaultClusterReplicationSpec(): atlas.AdvancedReplicationSpec[] {\n  return [\n    {\n      numShards: 1,\n      advancedRegionConfigs: [\n        {\n          analyticsSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT_ANALYTICS,\n          },\n          electableSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT,\n          },\n          priority: 7,\n          regionName: REGION,\n        },\n      ],\n    },\n  ];\n}\n\nexport interface EncryptionAtRestProps {\n  /**\n   * ID of an AWS IAM role authorized to manage an AWS customer master key.\n   *\n   * @schema AwsKms#RoleID\n   */\n  readonly roleId: string;\n  /**\n   * The AWS customer master key used to encrypt and decrypt the MongoDB master keys.\n   *\n   * @schema AwsKms#CustomerMasterKeyID\n   */\n  readonly customerMasterKeyId: string;\n  /**\n   * Specifies whether Encryption at Rest is enabled for an Atlas project. To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.\n   * Default Value: true\n   * @schema AwsKms#Enabled\n   */\n  readonly enabledEncryptionAtRest?: boolean;\n\n  /**\n   * The AWS region in which the AWS customer master key exists.\n   *\n   * @schema AwsKms#Region\n   */\n  readonly region?: string;\n}\n\nexport interface AtlasEncryptionAtRestExpressProps {\n  readonly cluster?: ClusterProps;\n  readonly accessList?: IpAccessListProps;\n  readonly encryptionAtRest: EncryptionAtRestProps;\n  readonly databaseUser?: DatabaseUserProps;\n  readonly profile?: string;\n  readonly projectId: string;\n}\n\nexport class AtlasEncryptionAtRestExpress extends Construct {\n  readonly encryptionAtRest: atlas.CfnEncryptionAtRest;\n  readonly cluster?: atlas.CfnCluster;\n  readonly accessList?: atlas.CfnProjectIpAccessList;\n  readonly databaseUser?: atlas.CfnDatabaseUser;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: AtlasEncryptionAtRestExpressProps\n  ) {\n    super(scope, id);\n\n    this.encryptionAtRest = new atlas.CfnEncryptionAtRest(\n      this,\n      \"encryption-at-rest-\".concat(id),\n      {\n        awsKms: {\n          customerMasterKeyId: props.encryptionAtRest.customerMasterKeyId,\n          roleId: props.encryptionAtRest.roleId,\n          enabled:\n            props.encryptionAtRest.enabledEncryptionAtRest ||\n            ENABLE_ENCRYPTION_AT_REST,\n          region: props.encryptionAtRest.region || REGION,\n        },\n        projectId: props.projectId,\n        profile: props.profile,\n      }\n    );\n\n    if (props.cluster) {\n      // Create a new MongoDB Atlas Cluster and pass project ID\n      const clusterProps = getClusterProps(props.cluster);\n      this.cluster = new atlas.CfnCluster(this, \"cluster-\".concat(id), {\n        ...clusterProps,\n        profile: props.profile,\n        projectId: props.projectId,\n      });\n    }\n\n    if (props.databaseUser) {\n      // Create a new MongoDB Atlas Database User\n      this.databaseUser = new atlas.CfnDatabaseUser(\n        this,\n        \"db-user-\".concat(id),\n        {\n          ...props.databaseUser,\n          profile: props.profile,\n          databaseName: props.databaseUser?.databaseName || DB_NAME,\n          projectId: props.projectId,\n          username: props.databaseUser?.username || USERNAME,\n          roles: props.databaseUser?.roles || ROLE,\n          password: props.databaseUser.password,\n        }\n      );\n    }\n\n    if (props.accessList) {\n      // Create a new MongoDB Atlas Project IP Access List\n      this.accessList = new atlas.CfnProjectIpAccessList(\n        this,\n        \"access-list-\".concat(id),\n        {\n          ...props.accessList,\n          profile: props.profile,\n          projectId: props.projectId,\n        }\n      );\n    }\n  }\n}\n"]}
AtlasEncryptionAtRestExpress[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasEncryptionAtRestExpress", version: "3.8.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/encryption-at-rest-express/index.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AAC7B,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,kDAAkD;AAClD,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,2CAAuC;AACvC,qCAAqC;AAOrC,MAAM,UAAU,GAAG,CAAC,CAAC;AACrB,MAAM,oBAAoB,GAAG,CAAC,CAAC;AAC/B,MAAM,cAAc,GAAG,IAAI,CAAC;AAC5B,MAAM,aAAa,GAAG,KAAK,CAAC;AAC5B,MAAM,eAAe,GAAG,KAAK,CAAC;AAC9B,MAAM,2BAA2B,GAC/B,KAAK,CAAC,uCAAuC,CAAC,GAAG,CAAC;AACpD,MAAM,MAAM,GAAG,WAAW,CAAC;AAC3B,MAAM,eAAe,GAAG,UAAU,CAAC;AACnC,MAAM,yBAAyB,GAAG,IAAI,CAAC;AACvC,MAAM,YAAY,GAAG,YAAY,CAAC;AAClC,MAAM,OAAO,GAAG,OAAO,CAAC;AACxB,MAAM,QAAQ,GAAG,SAAS,CAAC;AAC3B,MAAM,IAAI,GAAG;IACX;QACE,QAAQ,EAAE,YAAY;QACtB,YAAY,EAAE,OAAO;KACtB;CACF,CAAC;AAEF,SAAS,YAAY;IACnB,MAAM,GAAG,GAAG,EAAE,CAAC;IACf,MAAM,GAAG,GAAG,OAAO,CAAC;IACpB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AAC3D,CAAC;AAED,SAAS,eAAe,CACtB,iBAA+B;IAE/B,OAAO;QACL,IAAI,EACF,iBAAiB,CAAC,IAAI,IAAI,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QAC3E,mBAAmB,EACjB,iBAAiB,CAAC,mBAAmB,IAAI,eAAe;QAC1D,aAAa,EAAE,iBAAiB,CAAC,aAAa,IAAI,cAAc;QAChE,UAAU,EAAE,iBAAiB,CAAC,UAAU;QACxC,WAAW,EAAE,iBAAiB,CAAC,WAAW,IAAI,YAAY;QAC1D,WAAW,EAAE,iBAAiB,CAAC,WAAW;QAC1C,wBAAwB,EACtB,iBAAiB,CAAC,wBAAwB,IAAI,2BAA2B;QAC3E,MAAM,EAAE,iBAAiB,CAAC,MAAM;QAChC,MAAM,EAAE,iBAAiB,CAAC,MAAM;QAChC,UAAU,EAAE,iBAAiB,CAAC,UAAU;QACxC,YAAY,EAAE,iBAAiB,CAAC,YAAY;QAC5C,4BAA4B,EAC1B,iBAAiB,CAAC,4BAA4B;QAChD,oBAAoB,EAAE,iBAAiB,CAAC,oBAAoB;QAC5D,gBAAgB,EAAE,iBAAiB,CAAC,gBAAgB;QACpD,gBAAgB,EACd,iBAAiB,CAAC,gBAAgB,IAAI,gCAAgC,EAAE;QAC1E,SAAS,EAAE,EAAE;KACd,CAAC;AACJ,CAAC;AAED,SAAS,gCAAgC;IACvC,OAAO;QACL;YACE,SAAS,EAAE,CAAC;YACZ,qBAAqB,EAAE;gBACrB;oBACE,cAAc,EAAE;wBACd,aAAa,EAAE,eAAe;wBAC9B,YAAY,EAAE,aAAa;wBAC3B,SAAS,EAAE,oBAAoB;qBAChC;oBACD,cAAc,EAAE;wBACd,aAAa,EAAE,eAAe;wBAC9B,YAAY,EAAE,aAAa;wBAC3B,SAAS,EAAE,UAAU;qBACtB;oBACD,QAAQ,EAAE,CAAC;oBACX,UAAU,EAAE,MAAM;iBACnB;aACF;SACF;KACF,CAAC;AACJ,CAAC;AAuCD,MAAa,4BAA6B,SAAQ,sBAAS;IAMzD,YACE,KAAgB,EAChB,EAAU,EACV,KAAwC;QAExC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,gBAAgB,GAAG,IAAI,KAAK,CAAC,mBAAmB,CACnD,IAAI,EACJ,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC,EAChC;YACE,YAAY,EAAE;gBACZ,mBAAmB,EAAE,KAAK,CAAC,gBAAgB,CAAC,mBAAmB;gBAC/D,MAAM,EAAE,KAAK,CAAC,gBAAgB,CAAC,MAAM;gBACrC,OAAO,EACL,KAAK,CAAC,gBAAgB,CAAC,uBAAuB;oBAC9C,yBAAyB;gBAC3B,MAAM,EAAE,KAAK,CAAC,gBAAgB,CAAC,MAAM,IAAI,MAAM;aAChD;YACD,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;SACvB,CACF,CAAC;QAEF,IAAI,KAAK,CAAC,OAAO,EAAE;YACjB,yDAAyD;YACzD,MAAM,YAAY,GAAG,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACpD,IAAI,CAAC,OAAO,GAAG,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE;gBAC/D,GAAG,YAAY;gBACf,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;aAC3B,CAAC,CAAC;SACJ;QAED,IAAI,KAAK,CAAC,YAAY,EAAE;YACtB,2CAA2C;YAC3C,IAAI,CAAC,YAAY,GAAG,IAAI,KAAK,CAAC,eAAe,CAC3C,IAAI,EACJ,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EACrB;gBACE,GAAG,KAAK,CAAC,YAAY;gBACrB,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,YAAY,EAAE,KAAK,CAAC,YAAY,EAAE,YAAY,IAAI,OAAO;gBACzD,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,QAAQ,EAAE,KAAK,CAAC,YAAY,EAAE,QAAQ,IAAI,QAAQ;gBAClD,KAAK,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,IAAI,IAAI;gBACxC,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAC,QAAQ;aACtC,CACF,CAAC;SACH;QAED,IAAI,KAAK,CAAC,UAAU,EAAE;YACpB,oDAAoD;YACpD,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,sBAAsB,CAChD,IAAI,EACJ,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,EACzB;gBACE,GAAG,KAAK,CAAC,UAAU;gBACnB,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;aAC3B,CACF,CAAC;SACH;IACH,CAAC;;AArEH,oEAsEC","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport { Construct } from \"constructs\";\nimport * as atlas from \"../../index\";\nimport {\n  ClusterProps,\n  DatabaseUserProps,\n  IpAccessListProps,\n} from \"../common/props\";\n\nconst NODE_COUNT = 3;\nconst NODE_COUNT_ANALYTICS = 1;\nconst BACKUP_ENABLED = true;\nconst INSTANCE_SIZE = \"M30\";\nconst MONGODB_VERSION = \"5.0\";\nconst ENCRYPTION_AT_REST_PROVIDER =\n  atlas.CfnClusterPropsEncryptionAtRestProvider.AWS;\nconst REGION = \"US_EAST_1\";\nconst EBS_VOLUME_TYPE = \"STANDARD\";\nconst ENABLE_ENCRYPTION_AT_REST = true;\nconst CLUSTER_TYPE = \"REPLICASET\";\nconst DB_NAME = \"admin\";\nconst USERNAME = \"cdkUser\";\nconst ROLE = [\n  {\n    roleName: \"atlasAdmin\",\n    databaseName: \"admin\",\n  },\n];\n\nfunction randomNumber() {\n  const min = 10;\n  const max = 9999999;\n  return Math.floor(Math.random() * (max - min + 1) + min);\n}\n\nfunction getClusterProps(\n  inputClusterProps: ClusterProps\n): atlas.CfnClusterProps {\n  return {\n    name:\n      inputClusterProps.name || \"atlas-cluster-\".concat(String(randomNumber())),\n    mongoDbMajorVersion:\n      inputClusterProps.mongoDbMajorVersion || MONGODB_VERSION,\n    backupEnabled: inputClusterProps.backupEnabled ?? BACKUP_ENABLED,\n    diskSizeGb: inputClusterProps.diskSizeGb,\n    clusterType: inputClusterProps.clusterType || CLUSTER_TYPE,\n    biConnector: inputClusterProps.biConnector,\n    encryptionAtRestProvider:\n      inputClusterProps.encryptionAtRestProvider || ENCRYPTION_AT_REST_PROVIDER,\n    labels: inputClusterProps.labels,\n    paused: inputClusterProps.paused,\n    pitEnabled: inputClusterProps.pitEnabled,\n    rootCertType: inputClusterProps.rootCertType,\n    terminationProtectionEnabled:\n      inputClusterProps.terminationProtectionEnabled,\n    versionReleaseSystem: inputClusterProps.versionReleaseSystem,\n    advancedSettings: inputClusterProps.advancedSettings,\n    replicationSpecs:\n      inputClusterProps.replicationSpecs || getDefaultClusterReplicationSpec(),\n    projectId: \"\",\n  };\n}\n\nfunction getDefaultClusterReplicationSpec(): atlas.AdvancedReplicationSpec[] {\n  return [\n    {\n      numShards: 1,\n      advancedRegionConfigs: [\n        {\n          analyticsSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT_ANALYTICS,\n          },\n          electableSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT,\n          },\n          priority: 7,\n          regionName: REGION,\n        },\n      ],\n    },\n  ];\n}\n\nexport interface EncryptionAtRestProps {\n  /**\n   * ID of an AWS IAM role authorized to manage an AWS customer master key.\n   *\n   * @schema AwsKms#RoleID\n   */\n  readonly roleId: string;\n  /**\n   * The AWS customer master key used to encrypt and decrypt the MongoDB master keys.\n   *\n   * @schema AwsKms#CustomerMasterKeyID\n   */\n  readonly customerMasterKeyId: string;\n  /**\n   * Specifies whether Encryption at Rest is enabled for an Atlas project. To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.\n   * Default Value: true\n   * @schema AwsKms#Enabled\n   */\n  readonly enabledEncryptionAtRest?: boolean;\n\n  /**\n   * The AWS region in which the AWS customer master key exists.\n   *\n   * @schema AwsKms#Region\n   */\n  readonly region?: string;\n}\n\nexport interface AtlasEncryptionAtRestExpressProps {\n  readonly cluster?: ClusterProps;\n  readonly accessList?: IpAccessListProps;\n  readonly encryptionAtRest: EncryptionAtRestProps;\n  readonly databaseUser?: DatabaseUserProps;\n  readonly profile?: string;\n  readonly projectId: string;\n}\n\nexport class AtlasEncryptionAtRestExpress extends Construct {\n  readonly encryptionAtRest: atlas.CfnEncryptionAtRest;\n  readonly cluster?: atlas.CfnCluster;\n  readonly accessList?: atlas.CfnProjectIpAccessList;\n  readonly databaseUser?: atlas.CfnDatabaseUser;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: AtlasEncryptionAtRestExpressProps\n  ) {\n    super(scope, id);\n\n    this.encryptionAtRest = new atlas.CfnEncryptionAtRest(\n      this,\n      \"encryption-at-rest-\".concat(id),\n      {\n        awsKmsConfig: {\n          customerMasterKeyId: props.encryptionAtRest.customerMasterKeyId,\n          roleId: props.encryptionAtRest.roleId,\n          enabled:\n            props.encryptionAtRest.enabledEncryptionAtRest ||\n            ENABLE_ENCRYPTION_AT_REST,\n          region: props.encryptionAtRest.region || REGION,\n        },\n        projectId: props.projectId,\n        profile: props.profile,\n      }\n    );\n\n    if (props.cluster) {\n      // Create a new MongoDB Atlas Cluster and pass project ID\n      const clusterProps = getClusterProps(props.cluster);\n      this.cluster = new atlas.CfnCluster(this, \"cluster-\".concat(id), {\n        ...clusterProps,\n        profile: props.profile,\n        projectId: props.projectId,\n      });\n    }\n\n    if (props.databaseUser) {\n      // Create a new MongoDB Atlas Database User\n      this.databaseUser = new atlas.CfnDatabaseUser(\n        this,\n        \"db-user-\".concat(id),\n        {\n          ...props.databaseUser,\n          profile: props.profile,\n          databaseName: props.databaseUser?.databaseName || DB_NAME,\n          projectId: props.projectId,\n          username: props.databaseUser?.username || USERNAME,\n          roles: props.databaseUser?.roles || ROLE,\n          password: props.databaseUser.password,\n        }\n      );\n    }\n\n    if (props.accessList) {\n      // Create a new MongoDB Atlas Project IP Access List\n      this.accessList = new atlas.CfnProjectIpAccessList(\n        this,\n        \"access-list-\".concat(id),\n        {\n          ...props.accessList,\n          profile: props.profile,\n          projectId: props.projectId,\n        }\n      );\n    }\n  }\n}\n"]}

@@ -61,6 +61,6 @@ {

"prettier": "^2.8.8",
"projen": "^0.84.4",
"projen": "^0.84.6",
"standard-version": "^9",
"ts-jest": "^27",
"typescript": "^5.5.3"
"typescript": "^5.5.4"
},

@@ -96,7 +96,7 @@ "peerDependencies": {

},
"version": "3.7.2",
"version": "3.8.0",
"jest": {
"coverageProvider": "v8",
"testMatch": [
"<rootDir>/@(src|test)/**/?(*.)+(spec|test).ts?(x)",
"<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)",
"<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)"

@@ -103,0 +103,0 @@ ],

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display