UNPKG

awscdk-resources-mongodbatlas

Version:

MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources

253 lines 42.7 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.CfnTrigger = exports.AuthConfigProviders = exports.AuthConfigOperationType = exports.DatabaseConfigOperationTypes = void 0; exports.toJson_CfnTriggerProps = toJson_CfnTriggerProps; exports.toJson_DatabaseConfig = toJson_DatabaseConfig; exports.toJson_AuthConfig = toJson_AuthConfig; exports.toJson_ScheduleConfig = toJson_ScheduleConfig; exports.toJson_Event = toJson_Event; exports.toJson_EventFunction = toJson_EventFunction; exports.toJson_EventAwseventbridge = toJson_EventAwseventbridge; exports.toJson_EventFunctionFuncConfig = toJson_EventFunctionFuncConfig; exports.toJson_EventAwseventbridgeAwsConfig = toJson_EventAwseventbridgeAwsConfig; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); // Generated by cdk-import const cdk = require("aws-cdk-lib"); /** * Converts an object of type 'CfnTriggerProps' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_CfnTriggerProps(obj) { if (obj === undefined) { return undefined; } const result = { Profile: obj.profile, DatabaseTrigger: toJson_DatabaseConfig(obj.databaseTrigger), AuthTrigger: toJson_AuthConfig(obj.authTrigger), ScheduleTrigger: toJson_ScheduleConfig(obj.scheduleTrigger), Name: obj.name, Type: obj.type, Disabled: obj.disabled, FunctionId: obj.functionId, FunctionName: obj.functionName, EventProcessors: toJson_Event(obj.eventProcessors), AppId: obj.appId, ProjectId: obj.projectId, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'DatabaseConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_DatabaseConfig(obj) { if (obj === undefined) { return undefined; } const result = { ServiceId: obj.serviceId, Database: obj.database, Collection: obj.collection, OperationTypes: obj.operationTypes?.map((y) => y), Match: obj.match, Project: obj.project, FullDocument: obj.fullDocument, FullDocumentBeforeChange: obj.fullDocumentBeforeChange, SkipCatchupEvents: obj.skipCatchupEvents, TolerateResumeErrors: obj.tolerateResumeErrors, MaximumThroughput: obj.maximumThroughput, Unordered: obj.unordered, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'AuthConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_AuthConfig(obj) { if (obj === undefined) { return undefined; } const result = { OperationType: obj.operationType, Providers: obj.providers?.map((y) => y), }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'ScheduleConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_ScheduleConfig(obj) { if (obj === undefined) { return undefined; } const result = { Schedule: obj.schedule, SkipcatchupEvents: obj.skipcatchupEvents, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'Event' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_Event(obj) { if (obj === undefined) { return undefined; } const result = { FUNCTION: toJson_EventFunction(obj.function), AWSEVENTBRIDGE: toJson_EventAwseventbridge(obj.awseventbridge), }; // 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 */ /** * @schema DatabaseConfigOperationTypes */ var DatabaseConfigOperationTypes; (function (DatabaseConfigOperationTypes) { /** INSERT */ DatabaseConfigOperationTypes["INSERT"] = "INSERT"; /** UPDATE */ DatabaseConfigOperationTypes["UPDATE"] = "UPDATE"; /** REPLACE */ DatabaseConfigOperationTypes["REPLACE"] = "REPLACE"; /** DELETE */ DatabaseConfigOperationTypes["DELETE"] = "DELETE"; })(DatabaseConfigOperationTypes || (exports.DatabaseConfigOperationTypes = DatabaseConfigOperationTypes = {})); /** * The type of authentication event that the trigger listens for. * * @schema AuthConfigOperationType */ var AuthConfigOperationType; (function (AuthConfigOperationType) { /** LOGIN */ AuthConfigOperationType["LOGIN"] = "LOGIN"; /** CREATE */ AuthConfigOperationType["CREATE"] = "CREATE"; /** DELETE */ AuthConfigOperationType["DELETE"] = "DELETE"; })(AuthConfigOperationType || (exports.AuthConfigOperationType = AuthConfigOperationType = {})); /** * @schema AuthConfigProviders */ var AuthConfigProviders; (function (AuthConfigProviders) { /** anon-user */ AuthConfigProviders["ANON_USER"] = "anon-user"; /** api-key */ AuthConfigProviders["API_KEY"] = "api-key"; /** custom-token */ AuthConfigProviders["CUSTOM_TOKEN"] = "custom-token"; /** custom-function */ AuthConfigProviders["CUSTOM_FUNCTION"] = "custom-function"; /** local-userpass */ AuthConfigProviders["LOCAL_USERPASS"] = "local-userpass"; /** oauth2-apple */ AuthConfigProviders["OAUTH2_APPLE"] = "oauth2-apple"; /** oauth2-facebook */ AuthConfigProviders["OAUTH2_FACEBOOK"] = "oauth2-facebook"; /** oauth2-google */ AuthConfigProviders["OAUTH2_GOOGLE"] = "oauth2-google"; })(AuthConfigProviders || (exports.AuthConfigProviders = AuthConfigProviders = {})); /** * Converts an object of type 'EventFunction' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_EventFunction(obj) { if (obj === undefined) { return undefined; } const result = { FuncConfig: toJson_EventFunctionFuncConfig(obj.funcConfig), }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'EventAwseventbridge' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_EventAwseventbridge(obj) { if (obj === undefined) { return undefined; } const result = { AWSConfig: toJson_EventAwseventbridgeAwsConfig(obj.awsConfig), }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'EventFunctionFuncConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_EventFunctionFuncConfig(obj) { if (obj === undefined) { return undefined; } const result = { FunctionId: obj.functionId, FunctionName: obj.functionName, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'EventAwseventbridgeAwsConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_EventAwseventbridgeAwsConfig(obj) { if (obj === undefined) { return undefined; } const result = { AccountId: obj.accountId, Region: obj.region, ExtendedJsonEnabled: obj.extendedJsonEnabled, }; // 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 */ /** * A CloudFormation `MongoDB::Atlas::Trigger` * * @cloudformationResource MongoDB::Atlas::Trigger * @stability external */ class CfnTrigger extends cdk.CfnResource { /** * Create a new `MongoDB::Atlas::Trigger`. * * @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: CfnTrigger.CFN_RESOURCE_TYPE_NAME, properties: toJson_CfnTriggerProps(props), }); this.props = props; this.attrId = cdk.Token.asString(this.getAtt("Id")); } } exports.CfnTrigger = CfnTrigger; _a = JSII_RTTI_SYMBOL_1; CfnTrigger[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnTrigger", version: "3.13.1" }; /** * 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/\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/atlas/app-services/triggers/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`, the trigger will use the maximize throughput option (https://www.mongodb.com/docs/atlas/app-services/triggers/database-triggers/#std-label-triggers-maximum-throughput).\n   *\n   * @schema DatabaseConfig#MaximumThroughput\n   */\n  readonly maximumThroughput?: 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    MaximumThroughput: obj.maximumThroughput,\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"]}