UNPKG

@cdklabs/cdk-amazonmq

Version:
81 lines 13 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.RabbitMqBrokerCluster = 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 RabbitMQ cluster deployment is a logical grouping of three RabbitMQ broker nodes behind a Network Load Balancer, each sharing users, queues, and a distributed state across multiple Availability Zones (AZ). */ class RabbitMqBrokerCluster extends rabbitmq_broker_deployment_1.RabbitMqBrokerDeploymentBase { /** * Reference an existing RabbitMQ Broker Cluster, 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 Cluster 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 Cluster */ static fromRabbitMqBrokerClusterArn(scope, logicalId, arn, securityGroups, urlSuffix) { return RabbitMqBrokerCluster._fromRabbitMqBrokerDeploymentBase(scope, logicalId, arn, undefined, undefined, securityGroups, urlSuffix); } /** * Reference an existing RabbitMQ Broker Cluster, defined outside of the CDK code, by name and id. * * @param scope * @param logicalId the construct's logical ID * @param name the name of the existing RabbitMQ Broker Cluster to be imported * @param id the ID of the existing RabbitMQ Broker Cluster to be imported * @param securityGroups optionally pass security groups for working with network connections * @param urlSuffix (optional) pass urlSuffix for the broker endpoints * @returns a representation of the RabbitMQ Broker Cluster */ static fromRabbitMqBrokerClusterNameAndId(scope, logicalId, name, id, securityGroups, urlSuffix) { return RabbitMqBrokerCluster._fromRabbitMqBrokerDeploymentBase(scope, logicalId, undefined, name, id, securityGroups, urlSuffix); } constructor(scope, id, props) { let subnetSelection = props.vpcSubnets; // This place holder for annotation errors const annotationErrors = []; /* START - Validate subnets and select two with different AZ if more then 2 where found */ // check if subnet selection has been specified if (props.vpcSubnets && props.vpc) { let subnets = props.vpc?.selectSubnets(props.vpcSubnets); if (subnets) { // Get subnets from different AZ. CFN does not have requirement for the number but they need to be in different AZ const selected = subnets?.subnets.reduce((acc, curr) => { if (!acc.find((a) => a.availabilityZone === curr.availabilityZone)) { acc.push(curr); } return acc; }, []); if (selected.length < 1) { annotationErrors.push(`Need at leasts 1 subnet. '${JSON.stringify(props.vpcSubnets)}', please use a different selection.`); } subnetSelection = { subnets: selected }; } } /* END - Validate subnets and select two with different AZ if more then 2 where found */ super(scope, id, { ...props, vpcSubnets: subnetSelection, deploymentMode: broker_deployment_mode_1.BrokerDeploymentMode.CLUSTER_MULTI_AZ, }); // Provide Annotation to the resource. if (annotationErrors.length > 0) { annotationErrors.forEach((msg) => aws_cdk_lib_1.Annotations.of(this).addError(msg)); } } } exports.RabbitMqBrokerCluster = RabbitMqBrokerCluster; _a = JSII_RTTI_SYMBOL_1; RabbitMqBrokerCluster[_a] = { fqn: "@cdklabs/cdk-amazonmq.RabbitMqBrokerCluster", version: "0.1.8" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rabbitmq-broker-cluster.js","sourceRoot":"","sources":["../../src/rabbitmq/rabbitmq-broker-cluster.ts"],"names":[],"mappings":";;;;;AAAA;;;EAGE;AACF,6CAA0C;AAI1C,6EAIsC;AACtC,sEAAiE;AASjE;;GAEG;AACH,MAAa,qBACX,SAAQ,yDAA4B;IAGpC;;;;;;;;;OASG;IACI,MAAM,CAAC,4BAA4B,CACxC,KAAgB,EAChB,SAAiB,EACjB,GAAW,EACX,cAAiC,EACjC,SAAkB;QAElB,OAAO,qBAAqB,CAAC,iCAAiC,CAC5D,KAAK,EACL,SAAS,EACT,GAAG,EACH,SAAS,EACT,SAAS,EACT,cAAc,EACd,SAAS,CACgB,CAAC;IAC9B,CAAC;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,kCAAkC,CAC9C,KAAgB,EAChB,SAAiB,EACjB,IAAY,EACZ,EAAU,EACV,cAAiC,EACjC,SAAkB;QAElB,OAAO,qBAAqB,CAAC,iCAAiC,CAC5D,KAAK,EACL,SAAS,EACT,SAAS,EACT,IAAI,EACJ,EAAE,EACF,cAAc,EACd,SAAS,CACgB,CAAC;IAC9B,CAAC;IAED,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAiC;QACzE,IAAI,eAAe,GAAG,KAAK,CAAC,UAAU,CAAC;QAEvC,0CAA0C;QAC1C,MAAM,gBAAgB,GAAG,EAAE,CAAC;QAE5B,0FAA0F;QAE1F,+CAA+C;QAC/C,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;YAClC,IAAI,OAAO,GAAG,KAAK,CAAC,GAAG,EAAE,aAAa,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YAEzD,IAAI,OAAO,EAAE,CAAC;gBACZ,kHAAkH;gBAClH,MAAM,QAAQ,GAAG,OAAO,EAAE,OAAO,CAAC,MAAM,CAAY,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;oBAChE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,gBAAgB,KAAK,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;wBACnE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACjB,CAAC;oBACD,OAAO,GAAG,CAAC;gBACb,CAAC,EAAE,EAAE,CAAC,CAAC;gBAEP,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACxB,gBAAgB,CAAC,IAAI,CACnB,6BAA6B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,sCAAsC,CACpG,CAAC;gBACJ,CAAC;gBAED,eAAe,GAAG,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;YAC1C,CAAC;QACH,CAAC;QAED,wFAAwF;QAExF,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,KAAK;YACR,UAAU,EAAE,eAAe;YAC3B,cAAc,EAAE,6CAAoB,CAAC,gBAAgB;SACtD,CAAC,CAAC;QAEH,sCAAsC;QACtC,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,yBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;;AAzGH,sDA0GC","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 { ISubnet, 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 IRabbitMqBrokerCluster\n  extends IRabbitMqBroker,\n    IRabbitMqBrokerDeployment {}\n\nexport interface RabbitMqBrokerClusterProps\n  extends RabbitMqBrokerDeploymentProps {}\n\n/**\n * A representation of a RabbitMQ cluster deployment is a logical grouping of three RabbitMQ broker nodes behind a Network Load Balancer, each sharing users, queues, and a distributed state across multiple Availability Zones (AZ).\n */\nexport class RabbitMqBrokerCluster\n  extends RabbitMqBrokerDeploymentBase\n  implements IRabbitMqBrokerCluster\n{\n  /**\n   * Reference an existing RabbitMQ Broker Cluster, 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 Cluster 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 Cluster\n   */\n  public static fromRabbitMqBrokerClusterArn(\n    scope: Construct,\n    logicalId: string,\n    arn: string,\n    securityGroups?: ISecurityGroup[],\n    urlSuffix?: string,\n  ) {\n    return RabbitMqBrokerCluster._fromRabbitMqBrokerDeploymentBase(\n      scope,\n      logicalId,\n      arn,\n      undefined,\n      undefined,\n      securityGroups,\n      urlSuffix,\n    ) as IRabbitMqBrokerCluster;\n  }\n\n  /**\n   * Reference an existing RabbitMQ Broker Cluster, defined outside of the CDK code, by name and id.\n   *\n   * @param scope\n   * @param logicalId the construct's logical ID\n   * @param name the name of the existing RabbitMQ Broker Cluster to be imported\n   * @param id the ID of the existing RabbitMQ Broker Cluster to be imported\n   * @param securityGroups optionally 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 Cluster\n   */\n  public static fromRabbitMqBrokerClusterNameAndId(\n    scope: Construct,\n    logicalId: string,\n    name: string,\n    id: string,\n    securityGroups?: ISecurityGroup[],\n    urlSuffix?: string,\n  ) {\n    return RabbitMqBrokerCluster._fromRabbitMqBrokerDeploymentBase(\n      scope,\n      logicalId,\n      undefined,\n      name,\n      id,\n      securityGroups,\n      urlSuffix,\n    ) as IRabbitMqBrokerCluster;\n  }\n\n  constructor(scope: Construct, id: string, props: RabbitMqBrokerClusterProps) {\n    let subnetSelection = props.vpcSubnets;\n\n    // This place holder for annotation errors\n    const annotationErrors = [];\n\n    /* START - Validate subnets and select two with different AZ if more then 2 where found */\n\n    // check if subnet selection has been specified\n    if (props.vpcSubnets && props.vpc) {\n      let subnets = props.vpc?.selectSubnets(props.vpcSubnets);\n\n      if (subnets) {\n        // Get subnets from different AZ. CFN does not have requirement for the number but they need to be in different AZ\n        const selected = subnets?.subnets.reduce<ISubnet[]>((acc, curr) => {\n          if (!acc.find((a) => a.availabilityZone === curr.availabilityZone)) {\n            acc.push(curr);\n          }\n          return acc;\n        }, []);\n\n        if (selected.length < 1) {\n          annotationErrors.push(\n            `Need at leasts 1 subnet. '${JSON.stringify(props.vpcSubnets)}', please use a different selection.`,\n          );\n        }\n\n        subnetSelection = { subnets: selected };\n      }\n    }\n\n    /* END - Validate subnets and select two with different AZ if more then 2 where found */\n\n    super(scope, id, {\n      ...props,\n      vpcSubnets: subnetSelection,\n      deploymentMode: BrokerDeploymentMode.CLUSTER_MULTI_AZ,\n    });\n\n    // Provide Annotation to the resource.\n    if (annotationErrors.length > 0) {\n      annotationErrors.forEach((msg) => Annotations.of(this).addError(msg));\n    }\n  }\n}\n"]}