awscdk-resources-mongodbatlas
Version:
MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources
81 lines • 16 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CfnLdapConfiguration = void 0;
exports.toJson_CfnLdapConfigurationProps = toJson_CfnLdapConfigurationProps;
exports.toJson_ApiAtlasNdsUserToDnMappingView = toJson_ApiAtlasNdsUserToDnMappingView;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Generated by cdk-import
const cdk = require("aws-cdk-lib");
/**
* Converts an object of type 'CfnLdapConfigurationProps' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_CfnLdapConfigurationProps(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
Profile: obj.profile,
BindUsername: obj.bindUsername,
Status: obj.status,
Hostname: obj.hostname,
AuthenticationEnabled: obj.authenticationEnabled,
AuthorizationEnabled: obj.authorizationEnabled,
CaCertificate: obj.caCertificate,
AuthzQueryTemplate: obj.authzQueryTemplate,
BindPassword: obj.bindPassword,
ProjectId: obj.projectId,
Port: obj.port,
UserToDNMapping: obj.userToDnMapping?.map((y) => toJson_ApiAtlasNdsUserToDnMappingView(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 'ApiAtlasNdsUserToDnMappingView' to JSON representation.
*/
/* eslint-disable max-len, quote-props */
function toJson_ApiAtlasNdsUserToDnMappingView(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
LdapQuery: obj.ldapQuery,
Match: obj.match,
Substitution: obj.substitution,
};
// 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::LDAPConfiguration`
*
* @cloudformationResource MongoDB::Atlas::LDAPConfiguration
* @stability external
*/
class CfnLdapConfiguration extends cdk.CfnResource {
/**
* Create a new `MongoDB::Atlas::LDAPConfiguration`.
*
* @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: CfnLdapConfiguration.CFN_RESOURCE_TYPE_NAME,
properties: toJson_CfnLdapConfigurationProps(props),
});
this.props = props;
}
}
exports.CfnLdapConfiguration = CfnLdapConfiguration;
_a = JSII_RTTI_SYMBOL_1;
CfnLdapConfiguration[_a] = { fqn: "awscdk-resources-mongodbatlas.CfnLdapConfiguration", version: "3.13.1" };
/**
* The CloudFormation resource type name for this resource class.
*/
CfnLdapConfiguration.CFN_RESOURCE_TYPE_NAME = "MongoDB::Atlas::LDAPConfiguration";
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l1-resources/ldap-configuration/index.ts"],"names":[],"mappings":";;;;AAmGA,4EA2BC;AAiCD,sFAgBC;;AA/KD,0BAA0B;AAC1B,mCAAmC;AA8FnC;;GAEG;AACH,yCAAyC;AACzC,SAAgB,gCAAgC,CAC9C,GAA0C;IAE1C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,qBAAqB,EAAE,GAAG,CAAC,qBAAqB;QAChD,oBAAoB,EAAE,GAAG,CAAC,oBAAoB;QAC9C,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,kBAAkB,EAAE,GAAG,CAAC,kBAAkB;QAC1C,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,eAAe,EAAE,GAAG,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC9C,qCAAqC,CAAC,CAAC,CAAC,CACzC;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;AA6BD;;GAEG;AACH,yCAAyC;AACzC,SAAgB,qCAAqC,CACnD,GAA+C;IAE/C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,GAAG,CAAC,SAAS;QACxB,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,YAAY,EAAE,GAAG,CAAC,YAAY;KAC/B,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;;;;;GAKG;AACH,MAAa,oBAAqB,SAAQ,GAAG,CAAC,WAAW;IAYvD;;;;;;OAMG;IACH,YACE,KAA2B,EAC3B,EAAU,EACV,KAAgC;QAEhC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,IAAI,EAAE,oBAAoB,CAAC,sBAAsB;YACjD,UAAU,EAAE,gCAAgC,CAAC,KAAK,CAAE;SACrD,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;AA9BH,oDA+BC;;;AA9BC;;GAEG;AACoB,2CAAsB,GAC3C,mCAAmC,CAAC","sourcesContent":["// Generated by cdk-import\nimport * as cdk from \"aws-cdk-lib\";\nimport * as constructs from \"constructs\";\n\n/**\n * Returns, edits, verifies, and removes LDAP configurations.\n *\n * @schema CfnLdapConfigurationProps\n */\nexport interface CfnLdapConfigurationProps {\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 CfnLdapConfigurationProps#Profile\n   */\n  readonly profile?: string;\n\n  /**\n   * Full Distinguished Name (DN) of the Lightweight Directory Access Protocol (LDAP) user that MongoDB Cloud uses to connect to the LDAP host. LDAP distinguished names must be formatted according to RFC 2253.\n   *\n   * @schema CfnLdapConfigurationProps#BindUsername\n   */\n  readonly bindUsername: string;\n\n  /**\n   * The current status of the LDAP over TLS/SSL configuration.\n   *\n   * @schema CfnLdapConfigurationProps#Status\n   */\n  readonly status?: string;\n\n  /**\n   * Human-readable label that identifies the hostname or Internet Protocol (IP) address of the Lightweight Directory Access Protocol (LDAP) host. This host must have access to the internet or have a Virtual Private Cloud (VPC) peering connection to your cluster.\n   *\n   * @schema CfnLdapConfigurationProps#Hostname\n   */\n  readonly hostname: string;\n\n  /**\n   * Flag that indicates whether users can authenticate using an Lightweight Directory Access Protocol (LDAP) host.\n   *\n   * @schema CfnLdapConfigurationProps#AuthenticationEnabled\n   */\n  readonly authenticationEnabled?: boolean;\n\n  /**\n   * Flag that indicates whether users can authorize access to MongoDB Cloud resources using an Lightweight Directory Access Protocol (LDAP) host.\n   *\n   * @schema CfnLdapConfigurationProps#AuthorizationEnabled\n   */\n  readonly authorizationEnabled?: boolean;\n\n  /**\n   * Certificate Authority (CA) certificate that MongoDB Cloud uses to verify the identity of the Lightweight Directory Access Protocol (LDAP) host. MongoDB Cloud allows self-signed certificates. To delete an assigned value, pass an empty string: `\"caCertificate\": \"\"`\n   *\n   * @schema CfnLdapConfigurationProps#CaCertificate\n   */\n  readonly caCertificate?: string;\n\n  /**\n   * Lightweight Directory Access Protocol (LDAP) query template that MongoDB Cloud runs to obtain the LDAP groups associated with the authenticated user. MongoDB Cloud uses this parameter only for user authorization. Use the `{USER}` placeholder in the Uniform Resource Locator (URL) to substitute the authenticated username. The query relates to the host specified with the hostname. Format this query according to [RFC 4515](https://tools.ietf.org/search/rfc4515) and [RFC 4516](https://datatracker.ietf.org/doc/html/rfc4516).\n   *\n   * @schema CfnLdapConfigurationProps#AuthzQueryTemplate\n   */\n  readonly authzQueryTemplate?: string;\n\n  /**\n   * Password that MongoDB Cloud uses to authenticate the **bindUsername**.\n   *\n   * @schema CfnLdapConfigurationProps#BindPassword\n   */\n  readonly bindPassword: string;\n\n  /**\n   * Unique 24-hexadecimal digit string that identifies your project.\n   *\n   * @schema CfnLdapConfigurationProps#ProjectId\n   */\n  readonly projectId: string;\n\n  /**\n   * Port to which the Lightweight Directory Access Protocol (LDAP) host listens for client connections.\n   *\n   * @schema CfnLdapConfigurationProps#Port\n   */\n  readonly port: number;\n\n  /**\n   * User-to-Distinguished Name (DN) map that MongoDB Cloud uses to transform a Lightweight Directory Access Protocol (LDAP) username into an LDAP DN.\n   *\n   * @schema CfnLdapConfigurationProps#UserToDNMapping\n   */\n  readonly userToDnMapping?: ApiAtlasNdsUserToDnMappingView[];\n}\n\n/**\n * Converts an object of type 'CfnLdapConfigurationProps' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_CfnLdapConfigurationProps(\n  obj: CfnLdapConfigurationProps | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    Profile: obj.profile,\n    BindUsername: obj.bindUsername,\n    Status: obj.status,\n    Hostname: obj.hostname,\n    AuthenticationEnabled: obj.authenticationEnabled,\n    AuthorizationEnabled: obj.authorizationEnabled,\n    CaCertificate: obj.caCertificate,\n    AuthzQueryTemplate: obj.authzQueryTemplate,\n    BindPassword: obj.bindPassword,\n    ProjectId: obj.projectId,\n    Port: obj.port,\n    UserToDNMapping: obj.userToDnMapping?.map((y) =>\n      toJson_ApiAtlasNdsUserToDnMappingView(y)\n    ),\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 ApiAtlasNDSUserToDNMappingView\n */\nexport interface ApiAtlasNdsUserToDnMappingView {\n  /**\n   * Lightweight Directory Access Protocol (LDAP) query template that inserts the LDAP name that the regular expression matches into an LDAP query Uniform Resource Identifier (URI). The formatting for the query must conform to [RFC 4515](https://datatracker.ietf.org/doc/html/rfc4515) and [RFC 4516](https://datatracker.ietf.org/doc/html/rfc4516).\n   *\n   * @schema ApiAtlasNDSUserToDNMappingView#LdapQuery\n   */\n  readonly ldapQuery?: string;\n\n  /**\n   * Regular expression that MongoDB Cloud uses to match against the provided Lightweight Directory Access Protocol (LDAP) username. Each parenthesis-enclosed section represents a regular expression capture group that the substitution or `ldapQuery` template uses.\n   *\n   * @schema ApiAtlasNDSUserToDNMappingView#Match\n   */\n  readonly match?: string;\n\n  /**\n   * Lightweight Directory Access Protocol (LDAP) Distinguished Name (DN) template that converts the LDAP username that matches regular expression in the *match* parameter into an LDAP Distinguished Name (DN).\n   *\n   * @schema ApiAtlasNDSUserToDNMappingView#Substitution\n   */\n  readonly substitution?: string;\n}\n\n/**\n * Converts an object of type 'ApiAtlasNdsUserToDnMappingView' to JSON representation.\n */\n/* eslint-disable max-len, quote-props */\nexport function toJson_ApiAtlasNdsUserToDnMappingView(\n  obj: ApiAtlasNdsUserToDnMappingView | undefined\n): Record<string, any> | undefined {\n  if (obj === undefined) {\n    return undefined;\n  }\n  const result = {\n    LdapQuery: obj.ldapQuery,\n    Match: obj.match,\n    Substitution: obj.substitution,\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::LDAPConfiguration`\n *\n * @cloudformationResource MongoDB::Atlas::LDAPConfiguration\n * @stability external\n */\nexport class CfnLdapConfiguration 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::LDAPConfiguration\";\n\n  /**\n   * Resource props.\n   */\n  public readonly props: CfnLdapConfigurationProps;\n\n  /**\n   * Create a new `MongoDB::Atlas::LDAPConfiguration`.\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: CfnLdapConfigurationProps\n  ) {\n    super(scope, id, {\n      type: CfnLdapConfiguration.CFN_RESOURCE_TYPE_NAME,\n      properties: toJson_CfnLdapConfigurationProps(props)!,\n    });\n\n    this.props = props;\n  }\n}\n"]}