awscdk-resources-mongodbatlas
Version:
MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources
139 lines • 21.3 kB
JavaScript
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnStreamConnection = exports.DbRoleToExecuteType = exports.CfnStreamConnectionPropsType = void 0;
exports.toJson_CfnStreamConnectionProps = toJson_CfnStreamConnectionProps;
exports.toJson_DbRoleToExecute = toJson_DbRoleToExecute;
exports.toJson_StreamsKafkaAuthentication = toJson_StreamsKafkaAuthentication;
exports.toJson_StreamsKafkaSecurity = toJson_StreamsKafkaSecurity;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Generated by cdk-import
const cdk = require("aws-cdk-lib");
/**
* Converts an object of type 'CfnStreamConnectionProps' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CfnStreamConnectionProps(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
ProjectId: obj.projectId,
Profile: obj.profile,
ConnectionName: obj.connectionName,
InstanceName: obj.instanceName,
Type: obj.type,
ClusterName: obj.clusterName,
DbRoleToExecute: toJson_DbRoleToExecute(obj.dbRoleToExecute),
Authentication: toJson_StreamsKafkaAuthentication(obj.authentication),
BootstrapServers: obj.bootstrapServers,
Security: toJson_StreamsKafkaSecurity(obj.security),
Config: obj.config,
};
// 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 connection. Can be either Cluster, Kafka, or Sample.
*
* @schema CfnStreamConnectionPropsType
*/
var CfnStreamConnectionPropsType;
(function (CfnStreamConnectionPropsType) {
/** Kafka */
CfnStreamConnectionPropsType["KAFKA"] = "Kafka";
/** Cluster */
CfnStreamConnectionPropsType["CLUSTER"] = "Cluster";
/** Sample */
CfnStreamConnectionPropsType["SAMPLE"] = "Sample";
})(CfnStreamConnectionPropsType || (exports.CfnStreamConnectionPropsType = CfnStreamConnectionPropsType = {}));
/**
* 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] }), {});
}
/**
* 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,
Password: obj.password,
};
// 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] }), {});
}
/* 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::StreamConnection`
*
* @cloudformationResource MongoDB::Atlas::StreamConnection
* @stability external
*/
class CfnStreamConnection extends cdk.CfnResource {
/**
* Create a new `MongoDB::Atlas::StreamConnection`.
*
* @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: CfnStreamConnection.CFN_RESOURCE_TYPE_NAME,
properties: toJson_CfnStreamConnectionProps(props),
});
this.props = props;
}
}
exports.CfnStreamConnection = CfnStreamConnection;
_a = JSII_RTTI_SYMBOL_1;
CfnStreamConnection[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnStreamConnection", version: "3.13.0" };
/**
* The CloudFormation resource type name for this resource class.
*/
CfnStreamConnection.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::StreamConnection";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/stream-connection/index.ts"],"names":[],"mappings":";;;;AAsFA,0EAwBC;AA0CD,wDAeC;AAmCD,8EAgBC;AA4BD,kEAeC;;AArQD,0BAA0B;AAC1B,mCAAmC;AAiFnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,+BAA+B,CAC7C,GAAyC;IAEzC,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,eAAe,EAAE,sBAAsB,CAAC,GAAG,CAAC,eAAe,CAAC;QAC5D,cAAc,EAAE,iCAAiC,CAAC,GAAG,CAAC,cAAc,CAAC;QACrE,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;QACtC,QAAQ,EAAE,2BAA2B,CAAC,GAAG,CAAC,QAAQ,CAAC;QACnD,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;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,YAAY;IACZ,+CAAe,CAAA;IACf,cAAc;IACd,mDAAmB,CAAA;IACnB,aAAa;IACb,iDAAiB,CAAA;AACnB,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAuBD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,sBAAsB,CACpC,GAAgC;IAEhC,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,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;AA+BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,iCAAiC,CAC/C,GAA2C;IAE3C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,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;AAwBD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,2BAA2B,CACzC,GAAqC;IAErC,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,uBAAuB,EAAE,GAAG,CAAC,uBAAuB;QACpD,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;AACD,wCAAwC;AAExC;;;;GAIG;AACH,IAAY,mBAKX;AALD,WAAY,mBAAmB;IAC7B,eAAe;IACf,4CAAqB,CAAA;IACrB,aAAa;IACb,wCAAiB,CAAA;AACnB,CAAC,EALW,mBAAmB,mCAAnB,mBAAmB,QAK9B;AAED;;;;;GAKG;AACH,MAAa,mBAAoB,SAAQ,GAAG,CAAC,WAAW;IAYtD;;;;;;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;IACrB,CAAC;;AA9BH,kDA+BC;;;AA9BC;;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, adds, edits, and removes one connection for a stream instance in the specified project. To use this resource, the requesting API Key must have the Project Owner roles.\n *\n * @schema CfnStreamConnectionProps\n */\nexport interface CfnStreamConnectionProps {\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project. Use the [/groups](#tag/Projects/operation/listProjects) endpoint to retrieve all projects to which the authenticated user has access.\n   *\n   * **NOTE**: Groups and projects are synonymous terms. Your group id is the same as your project id. For existing groups, your group/project id remains the same. The resource and corresponding endpoints use the term groups.\n   *\n   * @schema CfnStreamConnectionProps#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 CfnStreamConnectionProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Human-readable label that identifies the stream connection. In the case of the Sample type, this is the name of the sample source.\n   *\n   * @schema CfnStreamConnectionProps#ConnectionName\n   */\n  readonly connectionName: string;\n\n  /**\n   * Human-readable label that identifies the stream instance.\n   *\n   * @schema CfnStreamConnectionProps#InstanceName\n   */\n  readonly instanceName: string;\n\n  /**\n   * Type of the connection. Can be either Cluster, Kafka, or Sample.\n   *\n   * @schema CfnStreamConnectionProps#Type\n   */\n  readonly type: CfnStreamConnectionPropsType;\n\n  /**\n   * Name of the cluster configured for this connection.\n   *\n   * @schema CfnStreamConnectionProps#ClusterName\n   */\n  readonly clusterName?: string;\n\n  /**\n   * @schema CfnStreamConnectionProps#DbRoleToExecute\n   */\n  readonly dbRoleToExecute?: DbRoleToExecute;\n\n  /**\n   * @schema CfnStreamConnectionProps#Authentication\n   */\n  readonly authentication?: StreamsKafkaAuthentication;\n\n  /**\n   * Comma separated list of server addresses.\n   *\n   * @schema CfnStreamConnectionProps#BootstrapServers\n   */\n  readonly bootstrapServers?: string;\n\n  /**\n   * @schema CfnStreamConnectionProps#Security\n   */\n  readonly security?: StreamsKafkaSecurity;\n\n  /**\n   * @schema CfnStreamConnectionProps#Config\n   */\n  readonly config?: any;\n}\n\n/**\n * Converts an object of type 'CfnStreamConnectionProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnStreamConnectionProps(\n  obj: CfnStreamConnectionProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    ProjectId: obj.projectId,\n    Profile: obj.profile,\n    ConnectionName: obj.connectionName,\n    InstanceName: obj.instanceName,\n    Type: obj.type,\n    ClusterName: obj.clusterName,\n    DbRoleToExecute: toJson_DbRoleToExecute(obj.dbRoleToExecute),\n    Authentication: toJson_StreamsKafkaAuthentication(obj.authentication),\n    BootstrapServers: obj.bootstrapServers,\n    Security: toJson_StreamsKafkaSecurity(obj.security),\n    Config: obj.config,\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 connection. Can be either Cluster, Kafka, or Sample.\n *\n * @schema CfnStreamConnectionPropsType\n */\nexport enum CfnStreamConnectionPropsType {\n  /** Kafka */\n  KAFKA = \"Kafka\",\n  /** Cluster */\n  CLUSTER = \"Cluster\",\n  /** Sample */\n  SAMPLE = \"Sample\",\n}\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 * 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   * Password of the account to connect to the Kafka cluster. Review [AWS security best practices for CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/security-best-practices.html#creds) to manage credentials.\n   *\n   * @schema StreamsKafkaAuthentication#Password\n   */\n  readonly password?: 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    Password: obj.password,\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 * 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::StreamConnection`\n *\n * @cloudformationResource MongoDB::Atlas::StreamConnection\n * @stability external\n */\nexport class CfnStreamConnection 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::StreamConnection\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnStreamConnectionProps;\n\n  /**\n   * Create a new `MongoDB::Atlas::StreamConnection`.\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: CfnStreamConnectionProps\n  ) {\n    super(scope, id, {\n      type: CfnStreamConnection.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnStreamConnectionProps(props)!,\n    });\n\n    this.props = props;\n  }\n}\n"]}
;