awscdk-resources-mongodbatlas
Version:
MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources
180 lines • 31.6 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnOnlineArchive = exports.ScheduleViewType = exports.CriteriaViewDateFormat = exports.CriteriaViewType = exports.CfnOnlineArchivePropsCollectionType = void 0;
exports.toJson_CfnOnlineArchiveProps = toJson_CfnOnlineArchiveProps;
exports.toJson_CriteriaView = toJson_CriteriaView;
exports.toJson_PartitionFieldView = toJson_PartitionFieldView;
exports.toJson_ScheduleView = toJson_ScheduleView;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Generated by cdk-import
const cdk = require("aws-cdk-lib");
/**
* Converts an object of type 'CfnOnlineArchiveProps' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CfnOnlineArchiveProps(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Profile: obj.profile,
ClusterName: obj.clusterName,
CollName: obj.collName,
CollectionType: obj.collectionType,
Criteria: toJson_CriteriaView(obj.criteria),
DbName: obj.dbName,
ProjectId: obj.projectId,
IncludeCount: obj.includeCount,
ItemsPerPage: obj.itemsPerPage,
PageNum: obj.pageNum,
PartitionFields: obj.partitionFields?.map((y) => toJson_PartitionFieldView(y)),
Schedule: toJson_ScheduleView(obj.schedule),
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
/* eslint-enable max-len, quote-props */
/**
* Classification of MongoDB database collection that you want to return.
*
* If you set this parameter to `TIMESERIES`, set `"criteria.type" : "date"` and `"criteria.dateFormat" : "ISODATE"`.
*
* @schema CfnOnlineArchivePropsCollectionType
*/
var CfnOnlineArchivePropsCollectionType;
(function (CfnOnlineArchivePropsCollectionType) {
/** STANDARD */
CfnOnlineArchivePropsCollectionType["STANDARD"] = "STANDARD";
/** TIMESERIES */
CfnOnlineArchivePropsCollectionType["TIMESERIES"] = "TIMESERIES";
})(CfnOnlineArchivePropsCollectionType || (exports.CfnOnlineArchivePropsCollectionType = CfnOnlineArchivePropsCollectionType = {}));
/**
* Converts an object of type 'CriteriaView' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CriteriaView(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Type: obj.type,
DateField: obj.dateField,
DateFormat: obj.dateFormat,
ExpireAfterDays: obj.expireAfterDays,
Query: obj.query,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'PartitionFieldView' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_PartitionFieldView(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
FieldName: obj.fieldName,
Order: obj.order,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'ScheduleView' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_ScheduleView(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Type: obj.type,
EndHour: obj.endHour,
EndMinute: obj.endMinute,
StartHour: obj.startHour,
StartMinute: obj.startMinute,
DayOfMonth: obj.dayOfMonth,
DayOfWeek: obj.dayOfWeek,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
/* eslint-enable max-len, quote-props */
/**
* 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`.
*
* @schema CriteriaViewType
*/
var CriteriaViewType;
(function (CriteriaViewType) {
/** DATE */
CriteriaViewType["DATE"] = "DATE";
/** CUSTOM */
CriteriaViewType["CUSTOM"] = "CUSTOM";
})(CriteriaViewType || (exports.CriteriaViewType = CriteriaViewType = {}));
/**
* 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".
*
* @schema CriteriaViewDateFormat
*/
var CriteriaViewDateFormat;
(function (CriteriaViewDateFormat) {
/** ISODATE */
CriteriaViewDateFormat["ISODATE"] = "ISODATE";
/** EPOCH_SECONDS */
CriteriaViewDateFormat["EPOCH_SECONDS"] = "EPOCH_SECONDS";
/** EPOCH_MILLIS */
CriteriaViewDateFormat["EPOCH_MILLIS"] = "EPOCH_MILLIS";
/** EPOCH_NANOSECONDS */
CriteriaViewDateFormat["EPOCH_NANOSECONDS"] = "EPOCH_NANOSECONDS";
})(CriteriaViewDateFormat || (exports.CriteriaViewDateFormat = CriteriaViewDateFormat = {}));
/**
* @schema ScheduleViewType
*/
var ScheduleViewType;
(function (ScheduleViewType) {
/** DAILY */
ScheduleViewType["DAILY"] = "DAILY";
/** MONTHLY */
ScheduleViewType["MONTHLY"] = "MONTHLY";
/** DEFAULT */
ScheduleViewType["DEFAULT"] = "DEFAULT";
/** WEEKLY */
ScheduleViewType["WEEKLY"] = "WEEKLY";
})(ScheduleViewType || (exports.ScheduleViewType = ScheduleViewType = {}));
/**
* A CloudFormation `MongoDB::Atlas::OnlineArchive`
*
* @cloudformationResource MongoDB::Atlas::OnlineArchive
* @stability external
*/
class CfnOnlineArchive extends cdk.CfnResource {
/**
* Create a new `MongoDB::Atlas::OnlineArchive`.
*
* @param scope - scope in which this resource is defined
* @param id - scoped id of the resource
* @param props - resource properties
*/
constructor(scope, id, props) {
super(scope, id, {
type: CfnOnlineArchive.CFN_RESOURCE_TYPE_NAME,
properties: toJson_CfnOnlineArchiveProps(props),
});
this.props = props;
this.attrState = cdk.Token.asString(this.getAtt("State"));
this.attrTotalCount = cdk.Token.asNumber(this.getAtt("TotalCount"));
this.attrArchiveId = cdk.Token.asString(this.getAtt("ArchiveId"));
}
}
exports.CfnOnlineArchive = CfnOnlineArchive;
_a = JSII_RTTI_SYMBOL_1;
CfnOnlineArchive[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnOnlineArchive", version: "3.13.1" };
/**
* 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. **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"]}