UNPKG

@cdklabs/cdk-amazonmq

Version:
78 lines 12.1 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.RabbitMqBrokerInstance = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); /* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. SPDX-License-Identifier: Apache-2.0 */ const aws_cdk_lib_1 = require("aws-cdk-lib"); const rabbitmq_broker_deployment_1 = require("./rabbitmq-broker-deployment"); const broker_deployment_mode_1 = require("../broker-deployment-mode"); /** * A representation of a single-instance broker comprised of one broker in one Availability Zone behind a Network Load Balancer (NLB) * * Additional optimizations: * - When subnet selection returns more then 1 subnets. A first one is picked. Warning is annotated */ class RabbitMqBrokerInstance extends rabbitmq_broker_deployment_1.RabbitMqBrokerDeploymentBase { /** * Reference an existing RabbitMQ Broker Instance, defined outside of the CDK code, by ARN. * * @param scope * @param logicalId the construct's logical ID * @param arn the ARN of the existing RabbitMQ Broker Instance that is imported * @param securityGroups (optional) pass security groups for working with network connections * @param urlSuffix (optional) pass urlSuffix for the broker endpoints * @returns a representation of the RabbitMQ Broker Instance */ static fromRabbitMqBrokerInstanceArn(scope, logicalId, arn, securityGroups, urlSuffix) { return RabbitMqBrokerInstance._fromRabbitMqBrokerDeploymentBase(scope, logicalId, arn, undefined, undefined, securityGroups, urlSuffix); } /** * Reference an existing RabbitMQ Broker Instance, defined outside of the CDK code, by its name and id. * * @param scope * @param logicalId * @param name the name of the existing RabbitMQ Broker Instance to be imported * @param id the ID of the existing RabbitMQ Broker Instance to be imported * @param securityGroups (optional) pass security groups for working with network connections * @param urlSuffix (optional) pass urlSuffix for the broker endpoints * @returns a representation of the RabbitMQ Broker Instance */ static fromRabbitMqBrokerInstanceNameAndId(scope, logicalId, name, id, securityGroups, urlSuffix) { return RabbitMqBrokerInstance._fromRabbitMqBrokerDeploymentBase(scope, logicalId, undefined, name, id, securityGroups, urlSuffix); } constructor(scope, id, props) { let subnetSelection = props.vpcSubnets; // This flag is used to determine if a annotation needs to be done const annotationWarnings = []; // check if subnet selection has been specified if (props.vpcSubnets && props.vpc) { const subnets = props.vpc?.selectSubnets(props.vpcSubnets); // if selection is valid for a vpc if (subnets) { // single instance allows only one subnet take the first one subnetSelection = { subnets: [subnets.subnets[0]] }; if (subnets.subnets.length > 1) { // Annotate the fact of taking first one when more then one were selected annotationWarnings.push(`Exactly 1 subnet in [SINGLE_INSTANCE] deployment mode is needed. vpcSubnets selection returned ${subnets.subnets.length}. Taking first one from the selection`); } } } super(scope, id, { ...props, vpcSubnets: subnetSelection, deploymentMode: broker_deployment_mode_1.BrokerDeploymentMode.SINGLE_INSTANCE, }); // Provide Annotation to the resource. if (annotationWarnings.length > 0) { annotationWarnings.forEach((msg) => aws_cdk_lib_1.Annotations.of(this).addWarning(msg)); } } } exports.RabbitMqBrokerInstance = RabbitMqBrokerInstance; _a = JSII_RTTI_SYMBOL_1; RabbitMqBrokerInstance[_a] = { fqn: "@cdklabs/cdk-amazonmq.RabbitMqBrokerInstance", version: "0.1.8" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rabbitmq-broker-instance.js","sourceRoot":"","sources":["../../src/rabbitmq/rabbitmq-broker-instance.ts"],"names":[],"mappings":";;;;;AAAA;;;EAGE;AACF,6CAA0C;AAI1C,6EAIsC;AACtC,sEAAiE;AASjE;;;;;GAKG;AACH,MAAa,sBACX,SAAQ,yDAA4B;IAGpC;;;;;;;;;OASG;IACI,MAAM,CAAC,6BAA6B,CACzC,KAAgB,EAChB,SAAiB,EACjB,GAAW,EACX,cAAiC,EACjC,SAAkB;QAElB,OAAO,sBAAsB,CAAC,iCAAiC,CAC7D,KAAK,EACL,SAAS,EACT,GAAG,EACH,SAAS,EACT,SAAS,EACT,cAAc,EACd,SAAS,CACiB,CAAC;IAC/B,CAAC;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,mCAAmC,CAC/C,KAAgB,EAChB,SAAiB,EACjB,IAAY,EACZ,EAAU,EACV,cAAiC,EACjC,SAAkB;QAElB,OAAO,sBAAsB,CAAC,iCAAiC,CAC7D,KAAK,EACL,SAAS,EACT,SAAS,EACT,IAAI,EACJ,EAAE,EACF,cAAc,EACd,SAAS,CACiB,CAAC;IAC/B,CAAC;IAED,YACE,KAAgB,EAChB,EAAU,EACV,KAAkC;QAElC,IAAI,eAAe,GAAG,KAAK,CAAC,UAAU,CAAC;QAEvC,kEAAkE;QAClE,MAAM,kBAAkB,GAAG,EAAE,CAAC;QAE9B,+CAA+C;QAC/C,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,EAAE,aAAa,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YAE3D,kCAAkC;YAClC,IAAI,OAAO,EAAE,CAAC;gBACZ,4DAA4D;gBAC5D,eAAe,GAAG,EAAE,OAAO,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAEpD,IAAI,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC/B,yEAAyE;oBACzE,kBAAkB,CAAC,IAAI,CACrB,kGAAkG,OAAO,CAAC,OAAO,CAAC,MAAM,uCAAuC,CAChK,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;QAED,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,KAAK;YACR,UAAU,EAAE,eAAe;YAC3B,cAAc,EAAE,6CAAoB,CAAC,eAAe;SACrD,CAAC,CAAC;QAEH,sCAAsC;QACtC,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,kBAAkB,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,yBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;;AApGH,wDAqGC","sourcesContent":["/*\nCopyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\nSPDX-License-Identifier: Apache-2.0\n*/\nimport { Annotations } from \"aws-cdk-lib\";\nimport { ISecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport { Construct } from \"constructs\";\nimport { IRabbitMqBroker } from \"./rabbitmq-broker\";\nimport {\n  IRabbitMqBrokerDeployment,\n  RabbitMqBrokerDeploymentBase,\n  RabbitMqBrokerDeploymentProps,\n} from \"./rabbitmq-broker-deployment\";\nimport { BrokerDeploymentMode } from \"../broker-deployment-mode\";\n\nexport interface IRabbitMqBrokerInstance\n  extends IRabbitMqBrokerDeployment,\n    IRabbitMqBroker {}\n\nexport interface RabbitMqBrokerInstanceProps\n  extends RabbitMqBrokerDeploymentProps {}\n\n/**\n * A representation of a single-instance broker comprised of one broker in one Availability Zone behind a Network Load Balancer (NLB)\n *\n * Additional optimizations:\n * - When subnet selection returns more then 1 subnets. A first one is picked. Warning is annotated\n */\nexport class RabbitMqBrokerInstance\n  extends RabbitMqBrokerDeploymentBase\n  implements IRabbitMqBrokerInstance\n{\n  /**\n   * Reference an existing RabbitMQ Broker Instance, defined outside of the CDK code, by ARN.\n   *\n   * @param scope\n   * @param logicalId the construct's logical ID\n   * @param arn the ARN of the existing RabbitMQ Broker Instance that is imported\n   * @param securityGroups (optional) pass security groups for working with network connections\n   * @param urlSuffix (optional) pass urlSuffix for the broker endpoints\n   * @returns a representation of the RabbitMQ Broker Instance\n   */\n  public static fromRabbitMqBrokerInstanceArn(\n    scope: Construct,\n    logicalId: string,\n    arn: string,\n    securityGroups?: ISecurityGroup[],\n    urlSuffix?: string,\n  ) {\n    return RabbitMqBrokerInstance._fromRabbitMqBrokerDeploymentBase(\n      scope,\n      logicalId,\n      arn,\n      undefined,\n      undefined,\n      securityGroups,\n      urlSuffix,\n    ) as IRabbitMqBrokerInstance;\n  }\n\n  /**\n   * Reference an existing RabbitMQ Broker Instance, defined outside of the CDK code, by its name and id.\n   *\n   * @param scope\n   * @param logicalId\n   * @param name the name of the existing RabbitMQ Broker Instance to be imported\n   * @param id the ID of the existing RabbitMQ Broker Instance to be imported\n   * @param securityGroups (optional) pass security groups for working with network connections\n   * @param urlSuffix (optional) pass urlSuffix for the broker endpoints\n   * @returns a representation of the RabbitMQ Broker Instance\n   */\n  public static fromRabbitMqBrokerInstanceNameAndId(\n    scope: Construct,\n    logicalId: string,\n    name: string,\n    id: string,\n    securityGroups?: ISecurityGroup[],\n    urlSuffix?: string,\n  ) {\n    return RabbitMqBrokerInstance._fromRabbitMqBrokerDeploymentBase(\n      scope,\n      logicalId,\n      undefined,\n      name,\n      id,\n      securityGroups,\n      urlSuffix,\n    ) as IRabbitMqBrokerInstance;\n  }\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: RabbitMqBrokerInstanceProps,\n  ) {\n    let subnetSelection = props.vpcSubnets;\n\n    // This flag is used to determine if a annotation needs to be done\n    const annotationWarnings = [];\n\n    // check if subnet selection has been specified\n    if (props.vpcSubnets && props.vpc) {\n      const subnets = props.vpc?.selectSubnets(props.vpcSubnets);\n\n      // if selection is valid for a vpc\n      if (subnets) {\n        // single instance allows only one subnet take the first one\n        subnetSelection = { subnets: [subnets.subnets[0]] };\n\n        if (subnets.subnets.length > 1) {\n          // Annotate the fact of taking first one when more then one were selected\n          annotationWarnings.push(\n            `Exactly 1 subnet in [SINGLE_INSTANCE] deployment mode is needed. vpcSubnets selection returned ${subnets.subnets.length}. Taking first one from the selection`,\n          );\n        }\n      }\n    }\n\n    super(scope, id, {\n      ...props,\n      vpcSubnets: subnetSelection,\n      deploymentMode: BrokerDeploymentMode.SINGLE_INSTANCE,\n    });\n\n    // Provide Annotation to the resource.\n    if (annotationWarnings.length > 0) {\n      annotationWarnings.forEach((msg) => Annotations.of(this).addWarning(msg));\n    }\n  }\n}\n"]}