UNPKG

awscdk-resources-mongodbatlas

Version:

MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources

205 lines 30.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.CfnStreamInstance = exports.DbRoleToExecuteType = exports.StreamsConnectionType = exports.StreamsDataProcessRegionCloudProvider = void 0; exports.toJson_CfnStreamInstanceProps = toJson_CfnStreamInstanceProps; exports.toJson_StreamsDataProcessRegion = toJson_StreamsDataProcessRegion; exports.toJson_StreamConfig = toJson_StreamConfig; exports.toJson_StreamsConnection = toJson_StreamsConnection; exports.toJson_StreamsKafkaAuthentication = toJson_StreamsKafkaAuthentication; exports.toJson_StreamsKafkaSecurity = toJson_StreamsKafkaSecurity; exports.toJson_DbRoleToExecute = toJson_DbRoleToExecute; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); // Generated by cdk-import const cdk = require("aws-cdk-lib"); /** * Converts an object of type 'CfnStreamInstanceProps' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_CfnStreamInstanceProps(obj) { if (obj === undefined) { return undefined; } const result = { Profile: obj.profile, InstanceName: obj.instanceName, DataProcessRegion: toJson_StreamsDataProcessRegion(obj.dataProcessRegion), StreamConfig: toJson_StreamConfig(obj.streamConfig), Connections: obj.connections?.map((y) => toJson_StreamsConnection(y)), 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 'StreamsDataProcessRegion' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_StreamsDataProcessRegion(obj) { if (obj === undefined) { return undefined; } const result = { CloudProvider: obj.cloudProvider, Region: obj.region, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'StreamConfig' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_StreamConfig(obj) { if (obj === undefined) { return undefined; } const result = { Tier: obj.tier, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'StreamsConnection' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_StreamsConnection(obj) { if (obj === undefined) { return undefined; } const result = { Name: obj.name, Type: obj.type, Authentication: toJson_StreamsKafkaAuthentication(obj.authentication), BootstrapServers: obj.bootstrapServers, Security: toJson_StreamsKafkaSecurity(obj.security), ClusterName: obj.clusterName, DbRoleToExecute: toJson_DbRoleToExecute(obj.dbRoleToExecute), }; // 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 */ /** * Label that identifies the cloud service provider where MongoDB Cloud performs stream processing. Currently, this parameter supports AWS only. * * @schema StreamsDataProcessRegionCloudProvider */ var StreamsDataProcessRegionCloudProvider; (function (StreamsDataProcessRegionCloudProvider) { /** AWS */ StreamsDataProcessRegionCloudProvider["AWS"] = "AWS"; /** GCP */ StreamsDataProcessRegionCloudProvider["GCP"] = "GCP"; /** AZURE */ StreamsDataProcessRegionCloudProvider["AZURE"] = "AZURE"; /** TENANT */ StreamsDataProcessRegionCloudProvider["TENANT"] = "TENANT"; /** SERVERLESS */ StreamsDataProcessRegionCloudProvider["SERVERLESS"] = "SERVERLESS"; })(StreamsDataProcessRegionCloudProvider || (exports.StreamsDataProcessRegionCloudProvider = StreamsDataProcessRegionCloudProvider = {})); /** * Type of the connection. Can be either Cluster or Kafka. * * @schema StreamsConnectionType */ var StreamsConnectionType; (function (StreamsConnectionType) { /** Kafka */ StreamsConnectionType["KAFKA"] = "Kafka"; /** Cluster */ StreamsConnectionType["CLUSTER"] = "Cluster"; /** Sample */ StreamsConnectionType["SAMPLE"] = "Sample"; })(StreamsConnectionType || (exports.StreamsConnectionType = StreamsConnectionType = {})); /** * Converts an object of type 'StreamsKafkaAuthentication' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_StreamsKafkaAuthentication(obj) { if (obj === undefined) { return undefined; } const result = { Mechanism: obj.mechanism, Username: obj.username, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'StreamsKafkaSecurity' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_StreamsKafkaSecurity(obj) { if (obj === undefined) { return undefined; } const result = { BrokerPublicCertificate: obj.brokerPublicCertificate, Protocol: obj.protocol, }; // filter undefined values return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {}); } /** * Converts an object of type 'DbRoleToExecute' to JSON representation. */ /* eslint-disable max-len, quote-props */ function toJson_DbRoleToExecute(obj) { if (obj === undefined) { return undefined; } const result = { Role: obj.role, Type: obj.type, }; // 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 */ /** * Type of the DB role. Can be either BuiltIn or Custom. * * @schema DbRoleToExecuteType */ var DbRoleToExecuteType; (function (DbRoleToExecuteType) { /** BUILT_IN */ DbRoleToExecuteType["BUILT_IN"] = "BUILT_IN"; /** CUSTOM */ DbRoleToExecuteType["CUSTOM"] = "CUSTOM"; })(DbRoleToExecuteType || (exports.DbRoleToExecuteType = DbRoleToExecuteType = {})); /** * A CloudFormation `MongoDB::Atlas::StreamInstance` * * @cloudformationResource MongoDB::Atlas::StreamInstance * @stability external */ class CfnStreamInstance extends cdk.CfnResource { /** * Create a new `MongoDB::Atlas::StreamInstance`. * * @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: CfnStreamInstance.CFN_RESOURCE_TYPE_NAME, properties: toJson_CfnStreamInstanceProps(props), }); this.props = props; this.attrId = cdk.Token.asString(this.getAtt("Id")); this.attrHostnames = cdk.Token.asList(this.getAtt("Hostnames")); } } exports.CfnStreamInstance = CfnStreamInstance; _a = JSII_RTTI_SYMBOL_1; CfnStreamInstance[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamInstance", version: "3.13.0" }; /** * 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_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"]}