awscdk-resources-mongodbatlas
Version:
MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources
169 lines • 24.7 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnDatabaseUser = exports.ScopeDefinitionType = exports.CfnDatabaseUserPropsX509Type = exports.CfnDatabaseUserPropsLdapAuthType = exports.CfnDatabaseUserPropsAwsiamType = void 0;
exports.toJson_CfnDatabaseUserProps = toJson_CfnDatabaseUserProps;
exports.toJson_LabelDefinition = toJson_LabelDefinition;
exports.toJson_RoleDefinition = toJson_RoleDefinition;
exports.toJson_ScopeDefinition = toJson_ScopeDefinition;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Generated by cdk-import
const cdk = require("aws-cdk-lib");
/**
* Converts an object of type 'CfnDatabaseUserProps' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CfnDatabaseUserProps(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
DeleteAfterDate: obj.deleteAfterDate,
AWSIAMType: obj.awsiamType,
DatabaseName: obj.databaseName,
Description: obj.description,
Labels: obj.labels?.map((y) => toJson_LabelDefinition(y)),
LdapAuthType: obj.ldapAuthType,
X509Type: obj.x509Type,
Password: obj.password,
ProjectId: obj.projectId,
Roles: obj.roles?.map((y) => toJson_RoleDefinition(y)),
Scopes: obj.scopes?.map((y) => toJson_ScopeDefinition(y)),
Username: obj.username,
Profile: obj.profile,
};
// 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 */
/**
* 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`.
*
* @schema CfnDatabaseUserPropsAwsiamType
*/
var CfnDatabaseUserPropsAwsiamType;
(function (CfnDatabaseUserPropsAwsiamType) {
/** NONE */
CfnDatabaseUserPropsAwsiamType["NONE"] = "NONE";
/** USER */
CfnDatabaseUserPropsAwsiamType["USER"] = "USER";
/** ROLE */
CfnDatabaseUserPropsAwsiamType["ROLE"] = "ROLE";
})(CfnDatabaseUserPropsAwsiamType || (exports.CfnDatabaseUserPropsAwsiamType = CfnDatabaseUserPropsAwsiamType = {}));
/**
* Converts an object of type 'LabelDefinition' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_LabelDefinition(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Key: obj.key,
Value: obj.value,
};
// 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 */
/**
* Method by which the provided username is authenticated. Default value is `NONE`.
*
* @schema CfnDatabaseUserPropsLdapAuthType
*/
var CfnDatabaseUserPropsLdapAuthType;
(function (CfnDatabaseUserPropsLdapAuthType) {
/** NONE */
CfnDatabaseUserPropsLdapAuthType["NONE"] = "NONE";
/** USER */
CfnDatabaseUserPropsLdapAuthType["USER"] = "USER";
/** GROUP */
CfnDatabaseUserPropsLdapAuthType["GROUP"] = "GROUP";
})(CfnDatabaseUserPropsLdapAuthType || (exports.CfnDatabaseUserPropsLdapAuthType = CfnDatabaseUserPropsLdapAuthType = {}));
/**
* Method that briefs who owns the certificate provided. Default value is `NONE`.
*
* @schema CfnDatabaseUserPropsX509Type
*/
var CfnDatabaseUserPropsX509Type;
(function (CfnDatabaseUserPropsX509Type) {
/** NONE */
CfnDatabaseUserPropsX509Type["NONE"] = "NONE";
/** MANAGED */
CfnDatabaseUserPropsX509Type["MANAGED"] = "MANAGED";
/** CUSTOMER */
CfnDatabaseUserPropsX509Type["CUSTOMER"] = "CUSTOMER";
})(CfnDatabaseUserPropsX509Type || (exports.CfnDatabaseUserPropsX509Type = CfnDatabaseUserPropsX509Type = {}));
/**
* Converts an object of type 'RoleDefinition' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_RoleDefinition(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
CollectionName: obj.collectionName,
DatabaseName: obj.databaseName,
RoleName: obj.roleName,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined ? r : { ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'ScopeDefinition' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_ScopeDefinition(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Name: obj.name,
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 */
/**
* @schema ScopeDefinitionType
*/
var ScopeDefinitionType;
(function (ScopeDefinitionType) {
/** CLUSTER */
ScopeDefinitionType["CLUSTER"] = "CLUSTER";
/** DATA_LAKE */
ScopeDefinitionType["DATA_LAKE"] = "DATA_LAKE";
})(ScopeDefinitionType || (exports.ScopeDefinitionType = ScopeDefinitionType = {}));
/**
* A CloudFormation `MongoDB::Atlas::DatabaseUser`
*
* @cloudformationResource MongoDB::Atlas::DatabaseUser
* @stability external
*/
class CfnDatabaseUser extends cdk.CfnResource {
/**
* Create a new `MongoDB::Atlas::DatabaseUser`.
*
* @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: CfnDatabaseUser.CFN_RESOURCE_TYPE_NAME,
properties: toJson_CfnDatabaseUserProps(props),
});
this.props = props;
this.attrUserCFNIdentifier = cdk.Token.asString(this.getAtt("UserCFNIdentifier"));
}
}
exports.CfnDatabaseUser = CfnDatabaseUser;
_a = JSII_RTTI_SYMBOL_1;
CfnDatabaseUser[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnDatabaseUser", version: "3.13.1" };
/**
* 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   * Description of this database user.\n   *\n   * @schema CfnDatabaseUserProps#Description\n   */\n  readonly description?: 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 Federation that this database user can access. If omitted, MongoDB Cloud grants the database user access to all the clusters and MongoDB Atlas Data Federation 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    Description: obj.description,\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"]}