truemark-cdk-lib 1.2.4-alpha.13 → 1.2.4-alpha.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,6 +3,7 @@ import * as tmroute53 from "../../aws-route53";
3
3
  import { ICertificate } from "aws-cdk-lib/aws-certificatemanager";
4
4
  import { DomainName, SecurityPolicy } from "@aws-cdk/aws-apigatewayv2-alpha";
5
5
  import { ARecord, RecordTarget } from "aws-cdk-lib/aws-route53";
6
+ import { ARecordOptions } from "../../aws-route53";
6
7
  export interface StandardDomainNameProps extends tmroute53.DomainNameProps {
7
8
  /**
8
9
  * The optional ACM certificate for this domain name.
@@ -35,21 +36,26 @@ export declare class StandardDomainName extends Construct {
35
36
  toRecordTarget(evaluateTargetHealth?: boolean): RecordTarget;
36
37
  /**
37
38
  * Creates a route53 ARecord pointing to this domain name.
39
+ *
40
+ * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
41
+ * @param options additional options for creating the record
38
42
  */
39
- createARecord(evaluateTargetHealth?: boolean): ARecord;
43
+ createARecord(evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord;
40
44
  /**
41
45
  * Creates a route53 weighted record pointing to this domain name.
42
46
  *
43
47
  * @param weight the initial weight; defaults to 0
44
48
  * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
49
+ * @param options additional options for creating the record
45
50
  */
46
- createWeightedARecord(weight?: number, evaluateTargetHealth?: boolean): ARecord;
51
+ createWeightedARecord(weight: number, evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord;
47
52
  /**
48
53
  * Creates a route53 latency record pointing to this domain name.
49
54
  *
50
55
  * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
56
+ * @param options additional options for creating the record
51
57
  */
52
- createLatencyARecord(evaluateTargetHealth?: boolean): ARecord;
58
+ createLatencyARecord(evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord;
53
59
  /**
54
60
  * Returns the FQDN of this domain name.
55
61
  */
@@ -38,26 +38,31 @@ class StandardDomainName extends constructs_1.Construct {
38
38
  }
39
39
  /**
40
40
  * Creates a route53 ARecord pointing to this domain name.
41
+ *
42
+ * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
43
+ * @param options additional options for creating the record
41
44
  */
42
- createARecord(evaluateTargetHealth) {
43
- return this.domainName.createARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true));
45
+ createARecord(evaluateTargetHealth, options) {
46
+ return this.domainName.createARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true), options);
44
47
  }
45
48
  /**
46
49
  * Creates a route53 weighted record pointing to this domain name.
47
50
  *
48
51
  * @param weight the initial weight; defaults to 0
49
52
  * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
53
+ * @param options additional options for creating the record
50
54
  */
51
- createWeightedARecord(weight, evaluateTargetHealth) {
52
- return this.domainName.createWeightedARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true), weight);
55
+ createWeightedARecord(weight, evaluateTargetHealth, options) {
56
+ return this.domainName.createWeightedARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true), weight, options);
53
57
  }
54
58
  /**
55
59
  * Creates a route53 latency record pointing to this domain name.
56
60
  *
57
61
  * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.
62
+ * @param options additional options for creating the record
58
63
  */
59
- createLatencyARecord(evaluateTargetHealth) {
60
- return this.domainName.createLatencyARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true));
64
+ createLatencyARecord(evaluateTargetHealth, options) {
65
+ return this.domainName.createLatencyARecord(this, this.toRecordTarget(evaluateTargetHealth !== null && evaluateTargetHealth !== void 0 ? evaluateTargetHealth : true), options);
61
66
  }
62
67
  /**
63
68
  * Returns the FQDN of this domain name.
@@ -67,4 +72,4 @@ class StandardDomainName extends constructs_1.Construct {
67
72
  }
68
73
  }
69
74
  exports.StandardDomainName = StandardDomainName;
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhbmRhcmQtZG9tYWluLW5hbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzdGFuZGFyZC1kb21haW4tbmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBcUM7QUFDckMsK0NBQStDO0FBQy9DLDJEQUEyRDtBQUUzRCw0RUFBMkU7QUFDM0UseURBQThEO0FBQzlELDJDQUF3RDtBQUN4RCwyQ0FBMkM7QUFDM0MsbURBQXVEO0FBMkJ2RDs7R0FFRztBQUNILE1BQWEsa0JBQW1CLFNBQVEsc0JBQVM7SUFNL0MsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUE4Qjs7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksU0FBUyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsV0FBVyxTQUFHLEtBQUssQ0FBQyxXQUFXLG1DQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakYsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksbUNBQVUsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQ3ZELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRTtZQUN0QyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1NBQ3JDLENBQUMsQ0FBQztRQUVILElBQUksc0JBQVksQ0FBQyxJQUFJLEVBQUU7WUFDckIsUUFBUSxFQUFFLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxlQUFlO1NBQ2pDLENBQUMsQ0FBQywwQkFBMEIsQ0FBQztZQUM1QixHQUFHLEVBQUUsdUJBQWE7WUFDbEIsTUFBTSxFQUFFLG9CQUFVO1NBQ25CLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxjQUFjLENBQUMsb0JBQThCO1FBQzNDLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxPQUFPLENBQUMsNEJBQTRCLENBQy9ELElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsRUFBRSxJQUFJLENBQUMsaUJBQWlCLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUMxRixPQUFPLG9CQUFvQjtZQUN6QixDQUFDLENBQUMsa0NBQW9CLENBQUMsU0FBUyxDQUFDLGdCQUFnQixFQUFFLG9CQUFvQixDQUFDO1lBQ3hFLENBQUMsQ0FBQywwQkFBWSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWEsQ0FBQyxvQkFBOEI7UUFDMUMsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxvQkFBb0IsYUFBcEIsb0JBQW9CLGNBQXBCLG9CQUFvQixHQUFJLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDaEcsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gscUJBQXFCLENBQUMsTUFBZSxFQUFFLG9CQUE4QjtRQUNuRSxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMscUJBQXFCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsb0JBQW9CLGFBQXBCLG9CQUFvQixjQUFwQixvQkFBb0IsR0FBSSxJQUFJLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNoSCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILG9CQUFvQixDQUFDLG9CQUE4QjtRQUNqRCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsb0JBQW9CLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsb0JBQW9CLGFBQXBCLG9CQUFvQixjQUFwQixvQkFBb0IsR0FBSSxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3ZHLENBQUM7SUFFRDs7T0FFRztJQUNILFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDcEMsQ0FBQztDQUNGO0FBaEVELGdEQWdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29uc3RydWN0fSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0ICogYXMgdG1yb3V0ZTUzIGZyb20gXCIuLi8uLi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0ICogYXMgdGFyZ2V0cyBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXJvdXRlNTMtdGFyZ2V0c1wiO1xuaW1wb3J0IHtJQ2VydGlmaWNhdGV9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY2VydGlmaWNhdGVtYW5hZ2VyXCI7XG5pbXBvcnQge0RvbWFpbk5hbWUsIFNlY3VyaXR5UG9saWN5fSBmcm9tIFwiQGF3cy1jZGsvYXdzLWFwaWdhdGV3YXl2Mi1hbHBoYVwiO1xuaW1wb3J0IHtBUmVjb3JkLCBSZWNvcmRUYXJnZXR9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHtDREtfTlBNSlNfVVJMLCBDREtfVkVORE9SfSBmcm9tIFwiLi4vLi4vaGVscGVyc1wiO1xuaW1wb3J0IHtTdGFuZGFyZFRhZ3N9IGZyb20gXCIuLi8uLi9hd3MtY2RrXCI7XG5pbXBvcnQge0V4dGVuZGVkUmVjb3JkVGFyZ2V0fSBmcm9tIFwiLi4vLi4vYXdzLXJvdXRlNTNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTdGFuZGFyZERvbWFpbk5hbWVQcm9wcyBleHRlbmRzIHRtcm91dGU1My5Eb21haW5OYW1lUHJvcHMge1xuXG4gIC8qKlxuICAgKiBUaGUgb3B0aW9uYWwgQUNNIGNlcnRpZmljYXRlIGZvciB0aGlzIGRvbWFpbiBuYW1lLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG9uZSBpcyBnZW5lcmF0ZWRcbiAgICovXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlPzogSUNlcnRpZmljYXRlO1xuXG4gIC8qKlxuICAgKiBUaGUgVHJhbnNwb3J0IExheWVyIFNlY3VyaXR5IChUTFMpIHZlcnNpb24gKyBjaXBoZXIgc3VpdGUgZm9yIHRoaXMgZG9tYWluIG5hbWUuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gU2VjdXJpdHlQb2xpY3kuVExTXzFfMlxuICAgKi9cbiAgcmVhZG9ubHkgc2VjdXJpdHlQb2xpY3k/OiBTZWN1cml0eVBvbGljeTtcblxuICAvKipcbiAgICogU2V0dGluZyB0aGlzIHRvIHRydWUgd2lsbCBzdXBwcmVzcyB0aGUgY3JlYXRpb24gb2YgZGVmYXVsdCB0YWdzIG9uIHJlc291cmNlc1xuICAgKiBjcmVhdGVkIGJ5IHRoaXMgY29uc3RydWN0LiBEZWZhdWx0IGlzIGZhbHNlLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGZhbHNlXG4gICAqL1xuICByZWFkb25seSBzdXBwcmVzc1RhZ2dpbmc/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIFN0YW5kYXJkIGNvbnN0cnVjdCB1c2VkIHRvIGNyZWF0ZSBhbiBBUEkgR2F0ZXdheSBWMiBEb21haW4gTmFtZS5cbiAqL1xuZXhwb3J0IGNsYXNzIFN0YW5kYXJkRG9tYWluTmFtZSBleHRlbmRzIENvbnN0cnVjdCB7XG5cbiAgcmVhZG9ubHkgZG9tYWluTmFtZTogdG1yb3V0ZTUzLkRvbWFpbk5hbWU7XG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlOiBJQ2VydGlmaWNhdGU7XG4gIHJlYWRvbmx5IGdhdGV3YXlEb21haW5OYW1lOiBEb21haW5OYW1lO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTdGFuZGFyZERvbWFpbk5hbWVQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgdGhpcy5kb21haW5OYW1lID0gbmV3IHRtcm91dGU1My5Eb21haW5OYW1lKHByb3BzKTtcbiAgICB0aGlzLmNlcnRpZmljYXRlID0gcHJvcHMuY2VydGlmaWNhdGUgPz8gdGhpcy5kb21haW5OYW1lLmNyZWF0ZUNlcnRpZmljYXRlKHNjb3BlKTtcbiAgICB0aGlzLmdhdGV3YXlEb21haW5OYW1lID0gbmV3IERvbWFpbk5hbWUodGhpcywgXCJEZWZhdWx0XCIsIHtcbiAgICAgIGRvbWFpbk5hbWU6IHRoaXMuZG9tYWluTmFtZS50b1N0cmluZygpLFxuICAgICAgY2VydGlmaWNhdGU6IHRoaXMuY2VydGlmaWNhdGUsXG4gICAgICBzZWN1cml0eVBvbGljeTogcHJvcHMuc2VjdXJpdHlQb2xpY3lcbiAgICB9KTtcblxuICAgIG5ldyBTdGFuZGFyZFRhZ3ModGhpcywge1xuICAgICAgc3VwcHJlc3M6IHByb3BzPy5zdXBwcmVzc1RhZ2dpbmdcbiAgICB9KS5hZGRBdXRvbWF0aW9uQ29tcG9uZW50VGFncyh7XG4gICAgICB1cmw6IENES19OUE1KU19VUkwsXG4gICAgICB2ZW5kb3I6IENES19WRU5ET1JcbiAgICB9KTtcbiAgfVxuXG4gIHRvUmVjb3JkVGFyZ2V0KGV2YWx1YXRlVGFyZ2V0SGVhbHRoPzogYm9vbGVhbik6IFJlY29yZFRhcmdldCB7XG4gICAgY29uc3QgZG9tYWluUHJvcGVydGllcyA9IG5ldyB0YXJnZXRzLkFwaUdhdGV3YXl2MkRvbWFpblByb3BlcnRpZXMoXG4gICAgICB0aGlzLmdhdGV3YXlEb21haW5OYW1lLnJlZ2lvbmFsRG9tYWluTmFtZSwgdGhpcy5nYXRld2F5RG9tYWluTmFtZS5yZWdpb25hbEhvc3RlZFpvbmVJZCk7XG4gICAgcmV0dXJuIGV2YWx1YXRlVGFyZ2V0SGVhbHRoXG4gICAgICA/IEV4dGVuZGVkUmVjb3JkVGFyZ2V0LmZyb21BbGlhcyhkb21haW5Qcm9wZXJ0aWVzLCBldmFsdWF0ZVRhcmdldEhlYWx0aClcbiAgICAgIDogUmVjb3JkVGFyZ2V0LmZyb21BbGlhcyhkb21haW5Qcm9wZXJ0aWVzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgcm91dGU1MyBBUmVjb3JkIHBvaW50aW5nIHRvIHRoaXMgZG9tYWluIG5hbWUuXG4gICAqL1xuICBjcmVhdGVBUmVjb3JkKGV2YWx1YXRlVGFyZ2V0SGVhbHRoPzogYm9vbGVhbik6IEFSZWNvcmQge1xuICAgIHJldHVybiB0aGlzLmRvbWFpbk5hbWUuY3JlYXRlQVJlY29yZCh0aGlzLCB0aGlzLnRvUmVjb3JkVGFyZ2V0KGV2YWx1YXRlVGFyZ2V0SGVhbHRoID8/IHRydWUpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgcm91dGU1MyB3ZWlnaHRlZCByZWNvcmQgcG9pbnRpbmcgdG8gdGhpcyBkb21haW4gbmFtZS5cbiAgICpcbiAgICogQHBhcmFtIHdlaWdodCB0aGUgaW5pdGlhbCB3ZWlnaHQ7IGRlZmF1bHRzIHRvIDBcbiAgICogQHBhcmFtIGV2YWx1YXRlVGFyZ2V0SGVhbHRoIERldGVybWluZXMgaWYgcm91dGU1MyBldmFsdWF0ZXMgdGhlIHRhcmdldCdzIGhlYWx0aC4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAgICovXG4gIGNyZWF0ZVdlaWdodGVkQVJlY29yZCh3ZWlnaHQ/OiBudW1iZXIsIGV2YWx1YXRlVGFyZ2V0SGVhbHRoPzogYm9vbGVhbik6IEFSZWNvcmQge1xuICAgIHJldHVybiB0aGlzLmRvbWFpbk5hbWUuY3JlYXRlV2VpZ2h0ZWRBUmVjb3JkKHRoaXMsIHRoaXMudG9SZWNvcmRUYXJnZXQoZXZhbHVhdGVUYXJnZXRIZWFsdGggPz8gdHJ1ZSksIHdlaWdodCk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIHJvdXRlNTMgbGF0ZW5jeSByZWNvcmQgcG9pbnRpbmcgdG8gdGhpcyBkb21haW4gbmFtZS5cbiAgICpcbiAgICogQHBhcmFtIGV2YWx1YXRlVGFyZ2V0SGVhbHRoIERldGVybWluZXMgaWYgcm91dGU1MyBldmFsdWF0ZXMgdGhlIHRhcmdldCdzIGhlYWx0aC4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAgICovXG4gIGNyZWF0ZUxhdGVuY3lBUmVjb3JkKGV2YWx1YXRlVGFyZ2V0SGVhbHRoPzogYm9vbGVhbik6IEFSZWNvcmQge1xuICAgIHJldHVybiB0aGlzLmRvbWFpbk5hbWUuY3JlYXRlTGF0ZW5jeUFSZWNvcmQodGhpcywgdGhpcy50b1JlY29yZFRhcmdldChldmFsdWF0ZVRhcmdldEhlYWx0aCA/PyB0cnVlKSk7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgRlFETiBvZiB0aGlzIGRvbWFpbiBuYW1lLlxuICAgKi9cbiAgdG9TdHJpbmcoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5kb21haW5OYW1lLnRvU3RyaW5nKCk7XG4gIH1cbn1cbiJdfQ==
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-domain-name.js","sourceRoot":"","sources":["standard-domain-name.ts"],"names":[],"mappings":";;;AAAA,2CAAqC;AACrC,+CAA+C;AAC/C,2DAA2D;AAE3D,4EAA2E;AAC3E,yDAA8D;AAC9D,2CAAwD;AACxD,2CAA2C;AAC3C,mDAAuE;AA2BvE;;GAEG;AACH,MAAa,kBAAmB,SAAQ,sBAAS;IAM/C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA8B;;QACtE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,IAAI,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,WAAW,SAAG,KAAK,CAAC,WAAW,mCAAI,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QACjF,IAAI,CAAC,iBAAiB,GAAG,IAAI,mCAAU,CAAC,IAAI,EAAE,SAAS,EAAE;YACvD,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACtC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,cAAc,EAAE,KAAK,CAAC,cAAc;SACrC,CAAC,CAAC;QAEH,IAAI,sBAAY,CAAC,IAAI,EAAE;YACrB,QAAQ,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,eAAe;SACjC,CAAC,CAAC,0BAA0B,CAAC;YAC5B,GAAG,EAAE,uBAAa;YAClB,MAAM,EAAE,oBAAU;SACnB,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,oBAA8B;QAC3C,MAAM,gBAAgB,GAAG,IAAI,OAAO,CAAC,4BAA4B,CAC/D,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,EAAE,IAAI,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,CAAC;QAC1F,OAAO,oBAAoB;YACzB,CAAC,CAAC,kCAAoB,CAAC,SAAS,CAAC,gBAAgB,EAAE,oBAAoB,CAAC;YACxE,CAAC,CAAC,0BAAY,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,oBAA8B,EAAE,OAAwB;QACpE,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,oBAAoB,aAApB,oBAAoB,cAApB,oBAAoB,GAAI,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IACzG,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,MAAc,EAAE,oBAA8B,EAAE,OAAwB;QAC5F,OAAO,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,oBAAoB,aAApB,oBAAoB,cAApB,oBAAoB,GAAI,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACzH,CAAC;IAED;;;;;OAKG;IACH,oBAAoB,CAAC,oBAA8B,EAAE,OAAwB;QAC3E,OAAO,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,oBAAoB,aAApB,oBAAoB,cAApB,oBAAoB,GAAI,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IAChH,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;CACF;AArED,gDAqEC","sourcesContent":["import {Construct} from \"constructs\";\nimport * as tmroute53 from \"../../aws-route53\";\nimport * as targets from \"aws-cdk-lib/aws-route53-targets\";\nimport {ICertificate} from \"aws-cdk-lib/aws-certificatemanager\";\nimport {DomainName, SecurityPolicy} from \"@aws-cdk/aws-apigatewayv2-alpha\";\nimport {ARecord, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {CDK_NPMJS_URL, CDK_VENDOR} from \"../../helpers\";\nimport {StandardTags} from \"../../aws-cdk\";\nimport {ARecordOptions, ExtendedRecordTarget} from \"../../aws-route53\";\n\nexport interface StandardDomainNameProps extends tmroute53.DomainNameProps {\n\n  /**\n   * The optional ACM certificate for this domain name.\n   *\n   * @default - one is generated\n   */\n  readonly certificate?: ICertificate;\n\n  /**\n   * The Transport Layer Security (TLS) version + cipher suite for this domain name.\n   *\n   * @default - SecurityPolicy.TLS_1_2\n   */\n  readonly securityPolicy?: SecurityPolicy;\n\n  /**\n   * Setting this to true will suppress the creation of default tags on resources\n   * created by this construct. Default is false.\n   *\n   * @default - false\n   */\n  readonly suppressTagging?: boolean;\n}\n\n/**\n * Standard construct used to create an API Gateway V2 Domain Name.\n */\nexport class StandardDomainName extends Construct {\n\n  readonly domainName: tmroute53.DomainName;\n  readonly certificate: ICertificate;\n  readonly gatewayDomainName: DomainName;\n\n  constructor(scope: Construct, id: string, props: StandardDomainNameProps) {\n    super(scope, id);\n    this.domainName = new tmroute53.DomainName(props);\n    this.certificate = props.certificate ?? this.domainName.createCertificate(scope);\n    this.gatewayDomainName = new DomainName(this, \"Default\", {\n      domainName: this.domainName.toString(),\n      certificate: this.certificate,\n      securityPolicy: props.securityPolicy\n    });\n\n    new StandardTags(this, {\n      suppress: props?.suppressTagging\n    }).addAutomationComponentTags({\n      url: CDK_NPMJS_URL,\n      vendor: CDK_VENDOR\n    });\n  }\n\n  toRecordTarget(evaluateTargetHealth?: boolean): RecordTarget {\n    const domainProperties = new targets.ApiGatewayv2DomainProperties(\n      this.gatewayDomainName.regionalDomainName, this.gatewayDomainName.regionalHostedZoneId);\n    return evaluateTargetHealth\n      ? ExtendedRecordTarget.fromAlias(domainProperties, evaluateTargetHealth)\n      : RecordTarget.fromAlias(domainProperties);\n  }\n\n  /**\n   * Creates a route53 ARecord pointing to this domain name.\n   *\n   * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.\n   * @param options additional options for creating the record\n   */\n  createARecord(evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord {\n    return this.domainName.createARecord(this, this.toRecordTarget(evaluateTargetHealth ?? true), options);\n  }\n\n  /**\n   * Creates a route53 weighted record pointing to this domain name.\n   *\n   * @param weight the initial weight; defaults to 0\n   * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.\n   * @param options additional options for creating the record\n   */\n  createWeightedARecord(weight: number, evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord {\n    return this.domainName.createWeightedARecord(this, this.toRecordTarget(evaluateTargetHealth ?? true), weight, options);\n  }\n\n  /**\n   * Creates a route53 latency record pointing to this domain name.\n   *\n   * @param evaluateTargetHealth Determines if route53 evaluates the target's health. Defaults to true.\n   * @param options additional options for creating the record\n   */\n  createLatencyARecord(evaluateTargetHealth?: boolean, options?: ARecordOptions): ARecord {\n    return this.domainName.createLatencyARecord(this, this.toRecordTarget(evaluateTargetHealth ?? true), options);\n  }\n\n  /**\n   * Returns the FQDN of this domain name.\n   */\n  toString(): string {\n    return this.domainName.toString();\n  }\n}\n"]}
@@ -103,7 +103,7 @@ export declare class DomainName {
103
103
  */
104
104
  toString(): string;
105
105
  /**
106
- * Returns a friendly identifier for this domain name.
106
+ * Returns a friendly identifier for this domain name. This function replaces wildcards with _ and periods with -
107
107
  */
108
108
  toIdentifier(): string;
109
109
  /**
@@ -131,16 +131,18 @@ export declare class DomainName {
131
131
  *
132
132
  * @param scope the scope to create the record in
133
133
  * @param target the target of the record
134
- * @param weight the initial weight; defaults to 0
134
+ * @param weight the initial weight
135
+ * @param options additional options for creating the record
135
136
  */
136
- createWeightedARecord(scope: Construct, target: RecordTarget, weight?: number): WeightedARecord;
137
+ createWeightedARecord(scope: Construct, target: RecordTarget, weight: number, options?: ARecordOptions): WeightedARecord;
137
138
  /**
138
139
  * Creates a latency Route53 record for this domain name.
139
140
  *
140
141
  * @param scope the scope to create the record in
141
142
  * @param target the target of the record
143
+ * @param options additional options for creating the record
142
144
  */
143
- createLatencyARecord(scope: Construct, target: RecordTarget): LatencyARecord;
145
+ createLatencyARecord(scope: Construct, target: RecordTarget, options?: ARecordOptions): LatencyARecord;
144
146
  /**
145
147
  * Creates an ACM certificate for the domain name.
146
148
  *
@@ -5,6 +5,7 @@ const aws_route53_1 = require("aws-cdk-lib/aws-route53");
5
5
  const weighted_a_record_1 = require("./weighted-a-record");
6
6
  const latency_a_record_1 = require("./latency-a-record");
7
7
  const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
8
+ const helpers_1 = require("../../helpers");
8
9
  /**
9
10
  * Utility class for holding domain name information and
10
11
  * doing useful things with it.
@@ -66,10 +67,12 @@ class DomainName {
66
67
  return (this.prefix == "" ? "" : this.prefix + ".") + this.zone;
67
68
  }
68
69
  /**
69
- * Returns a friendly identifier for this domain name.
70
+ * Returns a friendly identifier for this domain name. This function replaces wildcards with _ and periods with -
70
71
  */
71
72
  toIdentifier() {
72
- return this.toString().replace(/\./, "-").replace(/\*/, "wildcard");
73
+ return helpers_1.StringHelper.toPascalCase(this.toString().toLowerCase()
74
+ .replace(/\*/g, "wildcard")
75
+ .replace(/\./g, "-"));
73
76
  }
74
77
  /**
75
78
  * Returns the zone associated with this domain name.
@@ -106,8 +109,10 @@ class DomainName {
106
109
  return new aws_route53_1.ARecord(scope, (_a = options === null || options === void 0 ? void 0 : options.id) !== null && _a !== void 0 ? _a : `${this.toIdentifier()}-arecord`, {
107
110
  zone: this.getHostedZone(scope),
108
111
  recordName: this.toString(),
112
+ target,
109
113
  ttl: options === null || options === void 0 ? void 0 : options.ttl,
110
- target
114
+ comment: options === null || options === void 0 ? void 0 : options.comment,
115
+ deleteExisting: options === null || options === void 0 ? void 0 : options.deleteExisting
111
116
  });
112
117
  }
113
118
  /**
@@ -115,14 +120,19 @@ class DomainName {
115
120
  *
116
121
  * @param scope the scope to create the record in
117
122
  * @param target the target of the record
118
- * @param weight the initial weight; defaults to 0
123
+ * @param weight the initial weight
124
+ * @param options additional options for creating the record
119
125
  */
120
- createWeightedARecord(scope, target, weight) {
121
- return new weighted_a_record_1.WeightedARecord(scope, `${this.toIdentifier()}-arecord`, {
126
+ createWeightedARecord(scope, target, weight, options) {
127
+ var _a;
128
+ return new weighted_a_record_1.WeightedARecord(scope, (_a = options === null || options === void 0 ? void 0 : options.id) !== null && _a !== void 0 ? _a : `${this.toIdentifier()}-arecord`, {
122
129
  zone: this.getHostedZone(scope),
123
130
  recordName: this.toString(),
124
131
  target,
125
- weight
132
+ weight,
133
+ ttl: options === null || options === void 0 ? void 0 : options.ttl,
134
+ comment: options === null || options === void 0 ? void 0 : options.comment,
135
+ deleteExisting: options === null || options === void 0 ? void 0 : options.deleteExisting
126
136
  });
127
137
  }
128
138
  /**
@@ -130,12 +140,17 @@ class DomainName {
130
140
  *
131
141
  * @param scope the scope to create the record in
132
142
  * @param target the target of the record
143
+ * @param options additional options for creating the record
133
144
  */
134
- createLatencyARecord(scope, target) {
135
- return new latency_a_record_1.LatencyARecord(scope, `${this.toIdentifier()}-arecord`, {
145
+ createLatencyARecord(scope, target, options) {
146
+ var _a;
147
+ return new latency_a_record_1.LatencyARecord(scope, (_a = options === null || options === void 0 ? void 0 : options.id) !== null && _a !== void 0 ? _a : `${this.toIdentifier()}-arecord`, {
136
148
  zone: this.getHostedZone(scope),
137
149
  recordName: this.toString(),
138
- target
150
+ target,
151
+ ttl: options === null || options === void 0 ? void 0 : options.ttl,
152
+ comment: options === null || options === void 0 ? void 0 : options.comment,
153
+ deleteExisting: options === null || options === void 0 ? void 0 : options.deleteExisting
139
154
  });
140
155
  }
141
156
  /**
@@ -251,4 +266,4 @@ class DomainName {
251
266
  }
252
267
  }
253
268
  exports.DomainName = DomainName;
254
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain-name.js","sourceRoot":"","sources":["domain-name.ts"],"names":[],"mappings":"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","sourcesContent":["import {ARecord, HostedZone, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {Construct} from \"constructs\";\nimport {WeightedARecord} from \"./weighted-a-record\";\nimport {LatencyARecord} from \"./latency-a-record\";\nimport {Certificate, CertificateValidation} from \"aws-cdk-lib/aws-certificatemanager\";\nimport {Duration} from \"aws-cdk-lib\";\n\n/**\n * Properties for DomainName\n */\nexport interface DomainNameProps {\n\n  /**\n   * Domain name prefix.\n   *\n   * @default empty string\n   */\n  readonly prefix?: string;\n\n  /**\n   * Zone for the domain nane.\n   */\n  readonly zone: string | IHostedZone;\n\n  /**\n   * Flag to mark zone as private.\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * VPC the zone belongs to.\n   *\n   * @default undefined\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * ACM certificate options\n */\nexport interface CertificateOptions {\n\n  /**\n   * The identifier to use.\n   *\n   * @default ${this.toIdentifier()}-cert\n   */\n  readonly id?: string;\n\n  /**\n   * Alternative domain names on the certificate.\n   */\n  readonly subjectAlternativeNames?: string[];\n}\n\nexport interface ARecordOptions {\n\n  /**\n   * The identifier to use. One is generated if not provided.\n   */\n  readonly id?: string;\n\n  /**\n   * The resource record cache time to live (TTL).\n   */\n  readonly ttl?: Duration;\n\n  /**\n   * A comment to add on the record.\n   */\n  readonly comment?: string;\n\n  /**\n   * Whether to delete the same record set in the hosted zone if it already exists.\n   */\n  readonly deleteExisting?: boolean;\n}\n\n/**\n * Utility class for holding domain name information and\n * doing useful things with it.\n */\nexport class DomainName {\n\n  protected readonly prefix: string;\n  protected readonly zone: string;\n  protected hostedZone?: IHostedZone;\n  protected readonly privateZone: boolean;\n  protected readonly vpcId?: string;\n\n  /**\n   * Creates a new DomainName.\n   *\n   * @param props the properties of the domain name\n   */\n  constructor(props: DomainNameProps) {\n    this.prefix = props.prefix ?? \"\";\n    if (typeof props.zone === \"string\") {\n      this.zone = props.zone;\n    } else {\n      this.hostedZone = props.zone;\n      this.zone = this.hostedZone.zoneName;\n    }\n    this.privateZone = props.privateZone ?? false;\n    this.vpcId = props.vpcId;\n  }\n\n  /**\n   * Returns the prefix for this domain name.\n   */\n  getPrefix(): string {\n    return this.prefix;\n  }\n\n  /**\n   * Returns true if the zone is private. False if otherwise.\n   */\n  inPrivateZone(): boolean {\n    return this.privateZone;\n  }\n\n  /**\n   * Returns the vpc ID for this zone or undefined if one does not exist\n   */\n  getVpcId(): string | undefined {\n    return this.vpcId;\n  }\n\n  /**\n   * Returns true if the props match the domain name. False if otherwise.\n   *\n   * @param props the props to compare\n   */\n  propsMatch(props: DomainNameProps): boolean {\n    let propZoneStr = typeof props.zone === \"string\" ? props.zone : props.zone.zoneName;\n    return this.prefix === (props.prefix ?? \"\")\n      && this.zone === propZoneStr\n      && this.privateZone === (props.privateZone ?? false)\n      && this.vpcId === props.vpcId\n  }\n\n  /**\n   * Returns the string version of this domain name.\n   */\n  toString(): string {\n    return (this.prefix == \"\" ? \"\" : this.prefix + \".\") + this.zone;\n  }\n\n  /**\n   * Returns a friendly identifier for this domain name.\n   */\n  toIdentifier(): string {\n    return this.toString().replace(/\\./, \"-\").replace(/\\*/, \"wildcard\");\n  }\n\n  /**\n   * Returns the zone associated with this domain name.\n   */\n  getZone(): string {\n    return this.zone;\n  }\n\n  /**\n   * Returns the route53 hosted zone associated with this domain name.\n   * This method is safe to call repeatedly, the lookup will only be done once.\n   *\n   * @param scope the scope to use if a lookup is required\n   * @param id an optional ID if a lookup is required; one is generated if not provided\n   */\n  getHostedZone(scope: Construct, id?: string) : IHostedZone {\n    if (this.hostedZone === undefined) {\n      this.hostedZone = HostedZone.fromLookup(scope, id ?? `${this.toIdentifier()}-zone`, {\n        domainName: this.zone,\n        privateZone: this.privateZone,\n        vpcId: this.vpcId\n      });\n    }\n    return this.hostedZone;\n  }\n\n  /**\n   * Creates a Route53 ARecord for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   * @param options additional options for creating the record\n   */\n  createARecord(scope: Construct, target: RecordTarget, options?: ARecordOptions): ARecord {\n    return new ARecord(scope, options?.id ?? `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      ttl: options?.ttl,\n      target\n    });\n  }\n\n  /**\n   * Creates a weighted Route53 record for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   * @param weight the initial weight; defaults to 0\n   */\n  createWeightedARecord(scope: Construct, target: RecordTarget, weight?: number): WeightedARecord {\n    return new WeightedARecord(scope, `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      target,\n      weight\n    });\n  }\n\n  /**\n   * Creates a latency Route53 record for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   */\n  createLatencyARecord(scope: Construct, target: RecordTarget): LatencyARecord {\n    return new LatencyARecord(scope, `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      target\n    });\n  }\n\n  /**\n   * Creates an ACM certificate for the domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param opts additional options\n   */\n  createCertificate(scope: Construct, opts?: CertificateOptions): Certificate {\n    return new Certificate(scope, opts?.id ?? `${this.toIdentifier()}-cert`, {\n      domainName: this.toString(),\n      validation: CertificateValidation.fromDns(this.getHostedZone(scope)),\n      subjectAlternativeNames: opts?.subjectAlternativeNames\n    });\n  }\n\n  /**\n   * Converts an array of DomainNameProps to DomainName. This function will return an empty array\n   * if domainNameProps is undefined.\n   *\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static fromProps(domainNameProps?: DomainNameProps[]) : DomainName[] {\n    return domainNameProps === undefined ? [] : domainNameProps.map(p => new DomainName(p));\n  }\n\n  /**\n   * Creates an instance of DomainName from a fully qualified domain name and a zone.\n   *\n   * @param fqdn the fully qualified domain name\n   * @param zone the zone\n   */\n  static fromFqdn(fqdn: string, zone: IHostedZone | string, privateZone?: boolean, vpcId?: string): DomainName {\n    const prefix = fqdn.replace(typeof zone === \"string\" ? zone : zone.zoneName, \"\")\n      .replace(/\\.$/, \"\");\n    return new DomainName({\n      prefix, zone, privateZone, vpcId\n    });\n  }\n\n  /**\n   * Converts an array of DomainName objects to an array of strings. This function will return an\n   * empty array if domainNames is undefined.\n   *\n   * @param domainNames the DomainName objects to convert\n   */\n  static toStrings(domainNames?: DomainName[]) : string[] {\n    return domainNames === undefined ? [] : domainNames.map(d => d.toString());\n  }\n\n  /**\n   * Converts an array of DomainNameProps to an array of strings. This function will\n   * return an empty array if domainNameProps is undefined.\n   *\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static toStringsFromProps(domainNameProps?: DomainNameProps[]) : string[] {\n    return domainNameProps === undefined ? [] : DomainName.toStrings(DomainName.fromProps(domainNameProps));\n  }\n\n  /**\n   * Converts an array of DomainName objects to a map where the key is the domain name string and the value\n   * is an IHostedZone. This method will return an empty map if domainNames is undefined. This function\n   * is useful when used in conjunction with functions like CertificateValidation.fromDnsMultiZone.\n   *\n   * @param scope the scope used if a zone lookup is required\n   * @param domainNames the DomainName objects to convert\n   */\n  static toZoneMap(scope: Construct, domainNames?: DomainName[]) : { [domainName: string]: IHostedZone } {\n    const map: {[key: string]: IHostedZone} = {}\n    if (domainNames !== undefined) {\n      domainNames.forEach(d => {\n        map[d.toString()] = d.getHostedZone(scope)\n      });\n    }\n    return map;\n  }\n\n  /**\n   * Converts an array of DomainNameProps objects to a map where the key is the domain name string and the\n   * value is an IHostedZone. This method will return an empty map if domainNameProps is undefined. This\n   * function is useful when used in conjunction with functions like CertificateValidation.fromDnsMultiZone.\n   *\n   * @param scope the scope used if a zone lookup is required\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static toZoneMapFromProps(scope: Construct, domainNameProps: DomainNameProps[]) : { [domainName: string]: IHostedZone } {\n    return DomainName.toZoneMap(scope, DomainName.fromProps(domainNameProps));\n  }\n\n  /**\n   * Finds the domain name matching the given properties in an array of DomainName objects.\n   *\n   * @param props the properties to compare\n   * @param domainNames the domain names to search\n   * @return the matching domain name or undefined\n   */\n  static findDomainName(props: DomainNameProps, domainNames?: DomainName[]): DomainName | undefined {\n    for (let domainName of domainNames ?? []) {\n      if (domainName.propsMatch(props)) {\n        return domainName;\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Create a certificate from an array of DomainName objects.\n   *\n   * @param scope the scope to use\n   * @param id the identifier to use in the scope for the certificate\n   * @param domainNames the domain names to use in the certificate\n   */\n  static createCertificate(scope: Construct, id: string, domainNames: DomainName[]): Certificate {\n    return new Certificate(scope, id, {\n      domainName: domainNames[0].toString(),\n      subjectAlternativeNames: domainNames.slice(1).map(name => name.toString()),\n      validation: CertificateValidation.fromDnsMultiZone(DomainName.toZoneMap(scope, domainNames))\n    });\n  }\n}\n"]}
269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain-name.js","sourceRoot":"","sources":["domain-name.ts"],"names":[],"mappings":"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","sourcesContent":["import {ARecord, HostedZone, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {Construct} from \"constructs\";\nimport {WeightedARecord} from \"./weighted-a-record\";\nimport {LatencyARecord} from \"./latency-a-record\";\nimport {Certificate, CertificateValidation} from \"aws-cdk-lib/aws-certificatemanager\";\nimport {Duration} from \"aws-cdk-lib\";\nimport {StringHelper} from \"../../helpers\";\n\n/**\n * Properties for DomainName\n */\nexport interface DomainNameProps {\n\n  /**\n   * Domain name prefix.\n   *\n   * @default empty string\n   */\n  readonly prefix?: string;\n\n  /**\n   * Zone for the domain nane.\n   */\n  readonly zone: string | IHostedZone;\n\n  /**\n   * Flag to mark zone as private.\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * VPC the zone belongs to.\n   *\n   * @default undefined\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * ACM certificate options\n */\nexport interface CertificateOptions {\n\n  /**\n   * The identifier to use.\n   *\n   * @default ${this.toIdentifier()}-cert\n   */\n  readonly id?: string;\n\n  /**\n   * Alternative domain names on the certificate.\n   */\n  readonly subjectAlternativeNames?: string[];\n}\n\nexport interface ARecordOptions {\n\n  /**\n   * The identifier to use. One is generated if not provided.\n   */\n  readonly id?: string;\n\n  /**\n   * The resource record cache time to live (TTL).\n   */\n  readonly ttl?: Duration;\n\n  /**\n   * A comment to add on the record.\n   */\n  readonly comment?: string;\n\n  /**\n   * Whether to delete the same record set in the hosted zone if it already exists.\n   */\n  readonly deleteExisting?: boolean;\n}\n\n/**\n * Utility class for holding domain name information and\n * doing useful things with it.\n */\nexport class DomainName {\n\n  protected readonly prefix: string;\n  protected readonly zone: string;\n  protected hostedZone?: IHostedZone;\n  protected readonly privateZone: boolean;\n  protected readonly vpcId?: string;\n\n  /**\n   * Creates a new DomainName.\n   *\n   * @param props the properties of the domain name\n   */\n  constructor(props: DomainNameProps) {\n    this.prefix = props.prefix ?? \"\";\n    if (typeof props.zone === \"string\") {\n      this.zone = props.zone;\n    } else {\n      this.hostedZone = props.zone;\n      this.zone = this.hostedZone.zoneName;\n    }\n    this.privateZone = props.privateZone ?? false;\n    this.vpcId = props.vpcId;\n  }\n\n  /**\n   * Returns the prefix for this domain name.\n   */\n  getPrefix(): string {\n    return this.prefix;\n  }\n\n  /**\n   * Returns true if the zone is private. False if otherwise.\n   */\n  inPrivateZone(): boolean {\n    return this.privateZone;\n  }\n\n  /**\n   * Returns the vpc ID for this zone or undefined if one does not exist\n   */\n  getVpcId(): string | undefined {\n    return this.vpcId;\n  }\n\n  /**\n   * Returns true if the props match the domain name. False if otherwise.\n   *\n   * @param props the props to compare\n   */\n  propsMatch(props: DomainNameProps): boolean {\n    let propZoneStr = typeof props.zone === \"string\" ? props.zone : props.zone.zoneName;\n    return this.prefix === (props.prefix ?? \"\")\n      && this.zone === propZoneStr\n      && this.privateZone === (props.privateZone ?? false)\n      && this.vpcId === props.vpcId\n  }\n\n  /**\n   * Returns the string version of this domain name.\n   */\n  toString(): string {\n    return (this.prefix == \"\" ? \"\" : this.prefix + \".\") + this.zone;\n  }\n\n  /**\n   * Returns a friendly identifier for this domain name. This function replaces wildcards with _ and periods with -\n   */\n  toIdentifier(): string {\n    return StringHelper.toPascalCase(this.toString().toLowerCase()\n      .replace(/\\*/g, \"wildcard\")\n      .replace(/\\./g, \"-\"));\n  }\n\n  /**\n   * Returns the zone associated with this domain name.\n   */\n  getZone(): string {\n    return this.zone;\n  }\n\n  /**\n   * Returns the route53 hosted zone associated with this domain name.\n   * This method is safe to call repeatedly, the lookup will only be done once.\n   *\n   * @param scope the scope to use if a lookup is required\n   * @param id an optional ID if a lookup is required; one is generated if not provided\n   */\n  getHostedZone(scope: Construct, id?: string) : IHostedZone {\n    if (this.hostedZone === undefined) {\n      this.hostedZone = HostedZone.fromLookup(scope, id ?? `${this.toIdentifier()}-zone`, {\n        domainName: this.zone,\n        privateZone: this.privateZone,\n        vpcId: this.vpcId\n      });\n    }\n    return this.hostedZone;\n  }\n\n  /**\n   * Creates a Route53 ARecord for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   * @param options additional options for creating the record\n   */\n  createARecord(scope: Construct, target: RecordTarget, options?: ARecordOptions): ARecord {\n    return new ARecord(scope, options?.id ?? `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      target,\n      ttl: options?.ttl,\n      comment: options?.comment,\n      deleteExisting: options?.deleteExisting\n    });\n  }\n\n  /**\n   * Creates a weighted Route53 record for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   * @param weight the initial weight\n   * @param options additional options for creating the record\n   */\n  createWeightedARecord(scope: Construct, target: RecordTarget, weight: number, options?: ARecordOptions): WeightedARecord {\n    return new WeightedARecord(scope, options?.id ?? `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      target,\n      weight,\n      ttl: options?.ttl,\n      comment: options?.comment,\n      deleteExisting: options?.deleteExisting\n    });\n  }\n\n  /**\n   * Creates a latency Route53 record for this domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param target the target of the record\n   * @param options additional options for creating the record\n   */\n  createLatencyARecord(scope: Construct, target: RecordTarget, options?: ARecordOptions): LatencyARecord {\n    return new LatencyARecord(scope, options?.id ?? `${this.toIdentifier()}-arecord`, {\n      zone: this.getHostedZone(scope),\n      recordName: this.toString(),\n      target,\n      ttl: options?.ttl,\n      comment: options?.comment,\n      deleteExisting: options?.deleteExisting\n    });\n  }\n\n  /**\n   * Creates an ACM certificate for the domain name.\n   *\n   * @param scope the scope to create the record in\n   * @param opts additional options\n   */\n  createCertificate(scope: Construct, opts?: CertificateOptions): Certificate {\n    return new Certificate(scope, opts?.id ?? `${this.toIdentifier()}-cert`, {\n      domainName: this.toString(),\n      validation: CertificateValidation.fromDns(this.getHostedZone(scope)),\n      subjectAlternativeNames: opts?.subjectAlternativeNames\n    });\n  }\n\n  /**\n   * Converts an array of DomainNameProps to DomainName. This function will return an empty array\n   * if domainNameProps is undefined.\n   *\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static fromProps(domainNameProps?: DomainNameProps[]) : DomainName[] {\n    return domainNameProps === undefined ? [] : domainNameProps.map(p => new DomainName(p));\n  }\n\n  /**\n   * Creates an instance of DomainName from a fully qualified domain name and a zone.\n   *\n   * @param fqdn the fully qualified domain name\n   * @param zone the zone\n   */\n  static fromFqdn(fqdn: string, zone: IHostedZone | string, privateZone?: boolean, vpcId?: string): DomainName {\n    const prefix = fqdn.replace(typeof zone === \"string\" ? zone : zone.zoneName, \"\")\n      .replace(/\\.$/, \"\");\n    return new DomainName({\n      prefix, zone, privateZone, vpcId\n    });\n  }\n\n  /**\n   * Converts an array of DomainName objects to an array of strings. This function will return an\n   * empty array if domainNames is undefined.\n   *\n   * @param domainNames the DomainName objects to convert\n   */\n  static toStrings(domainNames?: DomainName[]) : string[] {\n    return domainNames === undefined ? [] : domainNames.map(d => d.toString());\n  }\n\n  /**\n   * Converts an array of DomainNameProps to an array of strings. This function will\n   * return an empty array if domainNameProps is undefined.\n   *\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static toStringsFromProps(domainNameProps?: DomainNameProps[]) : string[] {\n    return domainNameProps === undefined ? [] : DomainName.toStrings(DomainName.fromProps(domainNameProps));\n  }\n\n  /**\n   * Converts an array of DomainName objects to a map where the key is the domain name string and the value\n   * is an IHostedZone. This method will return an empty map if domainNames is undefined. This function\n   * is useful when used in conjunction with functions like CertificateValidation.fromDnsMultiZone.\n   *\n   * @param scope the scope used if a zone lookup is required\n   * @param domainNames the DomainName objects to convert\n   */\n  static toZoneMap(scope: Construct, domainNames?: DomainName[]) : { [domainName: string]: IHostedZone } {\n    const map: {[key: string]: IHostedZone} = {}\n    if (domainNames !== undefined) {\n      domainNames.forEach(d => {\n        map[d.toString()] = d.getHostedZone(scope)\n      });\n    }\n    return map;\n  }\n\n  /**\n   * Converts an array of DomainNameProps objects to a map where the key is the domain name string and the\n   * value is an IHostedZone. This method will return an empty map if domainNameProps is undefined. This\n   * function is useful when used in conjunction with functions like CertificateValidation.fromDnsMultiZone.\n   *\n   * @param scope the scope used if a zone lookup is required\n   * @param domainNameProps the DomainNameProps objects to convert\n   */\n  static toZoneMapFromProps(scope: Construct, domainNameProps: DomainNameProps[]) : { [domainName: string]: IHostedZone } {\n    return DomainName.toZoneMap(scope, DomainName.fromProps(domainNameProps));\n  }\n\n  /**\n   * Finds the domain name matching the given properties in an array of DomainName objects.\n   *\n   * @param props the properties to compare\n   * @param domainNames the domain names to search\n   * @return the matching domain name or undefined\n   */\n  static findDomainName(props: DomainNameProps, domainNames?: DomainName[]): DomainName | undefined {\n    for (let domainName of domainNames ?? []) {\n      if (domainName.propsMatch(props)) {\n        return domainName;\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Create a certificate from an array of DomainName objects.\n   *\n   * @param scope the scope to use\n   * @param id the identifier to use in the scope for the certificate\n   * @param domainNames the domain names to use in the certificate\n   */\n  static createCertificate(scope: Construct, id: string, domainNames: DomainName[]): Certificate {\n    return new Certificate(scope, id, {\n      domainName: domainNames[0].toString(),\n      subjectAlternativeNames: domainNames.slice(1).map(name => name.toString()),\n      validation: CertificateValidation.fromDnsMultiZone(DomainName.toZoneMap(scope, domainNames))\n    });\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "truemark-cdk-lib",
3
- "version": "1.2.4-alpha.13+15eb9ce",
3
+ "version": "1.2.4-alpha.15+46ba827",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "scripts": {
@@ -62,5 +62,5 @@
62
62
  "publishConfig": {
63
63
  "access": "public"
64
64
  },
65
- "gitHead": "15eb9ce057468ed06f2d81b2726ffb0dd6d28d06"
65
+ "gitHead": "46ba827ba09609e02aa3965d08e124a16be72c34"
66
66
  }