@cdktf/provider-acme 2.0.73 → 3.0.1
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.
- package/.jsii +529 -478
- package/API.md +0 -2511
- package/lib/{certificate.d.ts → certificate/index.d.ts} +0 -0
- package/lib/certificate/index.js +718 -0
- package/lib/index.d.ts +3 -3
- package/lib/index.js +4 -14
- package/lib/{acme-provider.d.ts → provider/index.d.ts} +0 -0
- package/lib/provider/index.js +74 -0
- package/lib/{registration.d.ts → registration/index.d.ts} +0 -0
- package/lib/registration/index.js +184 -0
- package/package.json +5 -5
- package/lib/acme-provider.js +0 -74
- package/lib/certificate.js +0 -718
- package/lib/registration.js +0 -184
| @@ -0,0 +1,718 @@ | |
| 1 | 
            +
            "use strict";
         | 
| 2 | 
            +
            var _a, _b, _c, _d, _e, _f, _g;
         | 
| 3 | 
            +
            Object.defineProperty(exports, "__esModule", { value: true });
         | 
| 4 | 
            +
            exports.Certificate = exports.CertificateTlsChallengeOutputReference = exports.certificateTlsChallengeToTerraform = exports.CertificateHttpWebrootChallengeOutputReference = exports.certificateHttpWebrootChallengeToTerraform = exports.CertificateHttpMemcachedChallengeOutputReference = exports.certificateHttpMemcachedChallengeToTerraform = exports.CertificateHttpChallengeOutputReference = exports.certificateHttpChallengeToTerraform = exports.CertificateDnsChallengeList = exports.CertificateDnsChallengeOutputReference = exports.certificateDnsChallengeToTerraform = void 0;
         | 
| 5 | 
            +
            const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
         | 
| 6 | 
            +
            const cdktf = require("cdktf");
         | 
| 7 | 
            +
            function certificateDnsChallengeToTerraform(struct) {
         | 
| 8 | 
            +
                if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
         | 
| 9 | 
            +
                    return struct;
         | 
| 10 | 
            +
                }
         | 
| 11 | 
            +
                if (cdktf.isComplexElement(struct)) {
         | 
| 12 | 
            +
                    throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
         | 
| 13 | 
            +
                }
         | 
| 14 | 
            +
                return {
         | 
| 15 | 
            +
                    config: cdktf.hashMapper(cdktf.stringToTerraform)(struct.config),
         | 
| 16 | 
            +
                    provider: cdktf.stringToTerraform(struct.provider),
         | 
| 17 | 
            +
                };
         | 
| 18 | 
            +
            }
         | 
| 19 | 
            +
            exports.certificateDnsChallengeToTerraform = certificateDnsChallengeToTerraform;
         | 
| 20 | 
            +
            class CertificateDnsChallengeOutputReference extends cdktf.ComplexObject {
         | 
| 21 | 
            +
                /**
         | 
| 22 | 
            +
                * @param terraformResource The parent resource
         | 
| 23 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 24 | 
            +
                * @param complexObjectIndex the index of this item in the list
         | 
| 25 | 
            +
                * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
         | 
| 26 | 
            +
                */
         | 
| 27 | 
            +
                constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
         | 
| 28 | 
            +
                    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
         | 
| 29 | 
            +
                    this.isEmptyObject = false;
         | 
| 30 | 
            +
                }
         | 
| 31 | 
            +
                get internalValue() {
         | 
| 32 | 
            +
                    if (this.resolvableValue) {
         | 
| 33 | 
            +
                        return this.resolvableValue;
         | 
| 34 | 
            +
                    }
         | 
| 35 | 
            +
                    let hasAnyValues = this.isEmptyObject;
         | 
| 36 | 
            +
                    const internalValueResult = {};
         | 
| 37 | 
            +
                    if (this._config !== undefined) {
         | 
| 38 | 
            +
                        hasAnyValues = true;
         | 
| 39 | 
            +
                        internalValueResult.config = this._config;
         | 
| 40 | 
            +
                    }
         | 
| 41 | 
            +
                    if (this._provider !== undefined) {
         | 
| 42 | 
            +
                        hasAnyValues = true;
         | 
| 43 | 
            +
                        internalValueResult.provider = this._provider;
         | 
| 44 | 
            +
                    }
         | 
| 45 | 
            +
                    return hasAnyValues ? internalValueResult : undefined;
         | 
| 46 | 
            +
                }
         | 
| 47 | 
            +
                set internalValue(value) {
         | 
| 48 | 
            +
                    if (value === undefined) {
         | 
| 49 | 
            +
                        this.isEmptyObject = false;
         | 
| 50 | 
            +
                        this.resolvableValue = undefined;
         | 
| 51 | 
            +
                        this._config = undefined;
         | 
| 52 | 
            +
                        this._provider = undefined;
         | 
| 53 | 
            +
                    }
         | 
| 54 | 
            +
                    else if (cdktf.Tokenization.isResolvable(value)) {
         | 
| 55 | 
            +
                        this.isEmptyObject = false;
         | 
| 56 | 
            +
                        this.resolvableValue = value;
         | 
| 57 | 
            +
                    }
         | 
| 58 | 
            +
                    else {
         | 
| 59 | 
            +
                        this.isEmptyObject = Object.keys(value).length === 0;
         | 
| 60 | 
            +
                        this.resolvableValue = undefined;
         | 
| 61 | 
            +
                        this._config = value.config;
         | 
| 62 | 
            +
                        this._provider = value.provider;
         | 
| 63 | 
            +
                    }
         | 
| 64 | 
            +
                }
         | 
| 65 | 
            +
                get config() {
         | 
| 66 | 
            +
                    return this.getStringMapAttribute('config');
         | 
| 67 | 
            +
                }
         | 
| 68 | 
            +
                set config(value) {
         | 
| 69 | 
            +
                    this._config = value;
         | 
| 70 | 
            +
                }
         | 
| 71 | 
            +
                resetConfig() {
         | 
| 72 | 
            +
                    this._config = undefined;
         | 
| 73 | 
            +
                }
         | 
| 74 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 75 | 
            +
                get configInput() {
         | 
| 76 | 
            +
                    return this._config;
         | 
| 77 | 
            +
                }
         | 
| 78 | 
            +
                get provider() {
         | 
| 79 | 
            +
                    return this.getStringAttribute('provider');
         | 
| 80 | 
            +
                }
         | 
| 81 | 
            +
                set provider(value) {
         | 
| 82 | 
            +
                    this._provider = value;
         | 
| 83 | 
            +
                }
         | 
| 84 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 85 | 
            +
                get providerInput() {
         | 
| 86 | 
            +
                    return this._provider;
         | 
| 87 | 
            +
                }
         | 
| 88 | 
            +
            }
         | 
| 89 | 
            +
            exports.CertificateDnsChallengeOutputReference = CertificateDnsChallengeOutputReference;
         | 
| 90 | 
            +
            _a = JSII_RTTI_SYMBOL_1;
         | 
| 91 | 
            +
            CertificateDnsChallengeOutputReference[_a] = { fqn: "@cdktf/provider-acme.certificate.CertificateDnsChallengeOutputReference", version: "3.0.1" };
         | 
| 92 | 
            +
            class CertificateDnsChallengeList extends cdktf.ComplexList {
         | 
| 93 | 
            +
                /**
         | 
| 94 | 
            +
                * @param terraformResource The parent resource
         | 
| 95 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 96 | 
            +
                * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
         | 
| 97 | 
            +
                */
         | 
| 98 | 
            +
                constructor(terraformResource, terraformAttribute, wrapsSet) {
         | 
| 99 | 
            +
                    super(terraformResource, terraformAttribute, wrapsSet);
         | 
| 100 | 
            +
                    this.terraformResource = terraformResource;
         | 
| 101 | 
            +
                    this.terraformAttribute = terraformAttribute;
         | 
| 102 | 
            +
                    this.wrapsSet = wrapsSet;
         | 
| 103 | 
            +
                }
         | 
| 104 | 
            +
                /**
         | 
| 105 | 
            +
                * @param index the index of the item to return
         | 
| 106 | 
            +
                */
         | 
| 107 | 
            +
                get(index) {
         | 
| 108 | 
            +
                    return new CertificateDnsChallengeOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
         | 
| 109 | 
            +
                }
         | 
| 110 | 
            +
            }
         | 
| 111 | 
            +
            exports.CertificateDnsChallengeList = CertificateDnsChallengeList;
         | 
| 112 | 
            +
            _b = JSII_RTTI_SYMBOL_1;
         | 
| 113 | 
            +
            CertificateDnsChallengeList[_b] = { fqn: "@cdktf/provider-acme.certificate.CertificateDnsChallengeList", version: "3.0.1" };
         | 
| 114 | 
            +
            function certificateHttpChallengeToTerraform(struct) {
         | 
| 115 | 
            +
                if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
         | 
| 116 | 
            +
                    return struct;
         | 
| 117 | 
            +
                }
         | 
| 118 | 
            +
                if (cdktf.isComplexElement(struct)) {
         | 
| 119 | 
            +
                    throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
         | 
| 120 | 
            +
                }
         | 
| 121 | 
            +
                return {
         | 
| 122 | 
            +
                    port: cdktf.numberToTerraform(struct.port),
         | 
| 123 | 
            +
                    proxy_header: cdktf.stringToTerraform(struct.proxyHeader),
         | 
| 124 | 
            +
                };
         | 
| 125 | 
            +
            }
         | 
| 126 | 
            +
            exports.certificateHttpChallengeToTerraform = certificateHttpChallengeToTerraform;
         | 
| 127 | 
            +
            class CertificateHttpChallengeOutputReference extends cdktf.ComplexObject {
         | 
| 128 | 
            +
                /**
         | 
| 129 | 
            +
                * @param terraformResource The parent resource
         | 
| 130 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 131 | 
            +
                */
         | 
| 132 | 
            +
                constructor(terraformResource, terraformAttribute) {
         | 
| 133 | 
            +
                    super(terraformResource, terraformAttribute, false, 0);
         | 
| 134 | 
            +
                    this.isEmptyObject = false;
         | 
| 135 | 
            +
                }
         | 
| 136 | 
            +
                get internalValue() {
         | 
| 137 | 
            +
                    let hasAnyValues = this.isEmptyObject;
         | 
| 138 | 
            +
                    const internalValueResult = {};
         | 
| 139 | 
            +
                    if (this._port !== undefined) {
         | 
| 140 | 
            +
                        hasAnyValues = true;
         | 
| 141 | 
            +
                        internalValueResult.port = this._port;
         | 
| 142 | 
            +
                    }
         | 
| 143 | 
            +
                    if (this._proxyHeader !== undefined) {
         | 
| 144 | 
            +
                        hasAnyValues = true;
         | 
| 145 | 
            +
                        internalValueResult.proxyHeader = this._proxyHeader;
         | 
| 146 | 
            +
                    }
         | 
| 147 | 
            +
                    return hasAnyValues ? internalValueResult : undefined;
         | 
| 148 | 
            +
                }
         | 
| 149 | 
            +
                set internalValue(value) {
         | 
| 150 | 
            +
                    if (value === undefined) {
         | 
| 151 | 
            +
                        this.isEmptyObject = false;
         | 
| 152 | 
            +
                        this._port = undefined;
         | 
| 153 | 
            +
                        this._proxyHeader = undefined;
         | 
| 154 | 
            +
                    }
         | 
| 155 | 
            +
                    else {
         | 
| 156 | 
            +
                        this.isEmptyObject = Object.keys(value).length === 0;
         | 
| 157 | 
            +
                        this._port = value.port;
         | 
| 158 | 
            +
                        this._proxyHeader = value.proxyHeader;
         | 
| 159 | 
            +
                    }
         | 
| 160 | 
            +
                }
         | 
| 161 | 
            +
                get port() {
         | 
| 162 | 
            +
                    return this.getNumberAttribute('port');
         | 
| 163 | 
            +
                }
         | 
| 164 | 
            +
                set port(value) {
         | 
| 165 | 
            +
                    this._port = value;
         | 
| 166 | 
            +
                }
         | 
| 167 | 
            +
                resetPort() {
         | 
| 168 | 
            +
                    this._port = undefined;
         | 
| 169 | 
            +
                }
         | 
| 170 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 171 | 
            +
                get portInput() {
         | 
| 172 | 
            +
                    return this._port;
         | 
| 173 | 
            +
                }
         | 
| 174 | 
            +
                get proxyHeader() {
         | 
| 175 | 
            +
                    return this.getStringAttribute('proxy_header');
         | 
| 176 | 
            +
                }
         | 
| 177 | 
            +
                set proxyHeader(value) {
         | 
| 178 | 
            +
                    this._proxyHeader = value;
         | 
| 179 | 
            +
                }
         | 
| 180 | 
            +
                resetProxyHeader() {
         | 
| 181 | 
            +
                    this._proxyHeader = undefined;
         | 
| 182 | 
            +
                }
         | 
| 183 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 184 | 
            +
                get proxyHeaderInput() {
         | 
| 185 | 
            +
                    return this._proxyHeader;
         | 
| 186 | 
            +
                }
         | 
| 187 | 
            +
            }
         | 
| 188 | 
            +
            exports.CertificateHttpChallengeOutputReference = CertificateHttpChallengeOutputReference;
         | 
| 189 | 
            +
            _c = JSII_RTTI_SYMBOL_1;
         | 
| 190 | 
            +
            CertificateHttpChallengeOutputReference[_c] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpChallengeOutputReference", version: "3.0.1" };
         | 
| 191 | 
            +
            function certificateHttpMemcachedChallengeToTerraform(struct) {
         | 
| 192 | 
            +
                if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
         | 
| 193 | 
            +
                    return struct;
         | 
| 194 | 
            +
                }
         | 
| 195 | 
            +
                if (cdktf.isComplexElement(struct)) {
         | 
| 196 | 
            +
                    throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
         | 
| 197 | 
            +
                }
         | 
| 198 | 
            +
                return {
         | 
| 199 | 
            +
                    hosts: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.hosts),
         | 
| 200 | 
            +
                };
         | 
| 201 | 
            +
            }
         | 
| 202 | 
            +
            exports.certificateHttpMemcachedChallengeToTerraform = certificateHttpMemcachedChallengeToTerraform;
         | 
| 203 | 
            +
            class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {
         | 
| 204 | 
            +
                /**
         | 
| 205 | 
            +
                * @param terraformResource The parent resource
         | 
| 206 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 207 | 
            +
                */
         | 
| 208 | 
            +
                constructor(terraformResource, terraformAttribute) {
         | 
| 209 | 
            +
                    super(terraformResource, terraformAttribute, false, 0);
         | 
| 210 | 
            +
                    this.isEmptyObject = false;
         | 
| 211 | 
            +
                }
         | 
| 212 | 
            +
                get internalValue() {
         | 
| 213 | 
            +
                    let hasAnyValues = this.isEmptyObject;
         | 
| 214 | 
            +
                    const internalValueResult = {};
         | 
| 215 | 
            +
                    if (this._hosts !== undefined) {
         | 
| 216 | 
            +
                        hasAnyValues = true;
         | 
| 217 | 
            +
                        internalValueResult.hosts = this._hosts;
         | 
| 218 | 
            +
                    }
         | 
| 219 | 
            +
                    return hasAnyValues ? internalValueResult : undefined;
         | 
| 220 | 
            +
                }
         | 
| 221 | 
            +
                set internalValue(value) {
         | 
| 222 | 
            +
                    if (value === undefined) {
         | 
| 223 | 
            +
                        this.isEmptyObject = false;
         | 
| 224 | 
            +
                        this._hosts = undefined;
         | 
| 225 | 
            +
                    }
         | 
| 226 | 
            +
                    else {
         | 
| 227 | 
            +
                        this.isEmptyObject = Object.keys(value).length === 0;
         | 
| 228 | 
            +
                        this._hosts = value.hosts;
         | 
| 229 | 
            +
                    }
         | 
| 230 | 
            +
                }
         | 
| 231 | 
            +
                get hosts() {
         | 
| 232 | 
            +
                    return cdktf.Fn.tolist(this.getListAttribute('hosts'));
         | 
| 233 | 
            +
                }
         | 
| 234 | 
            +
                set hosts(value) {
         | 
| 235 | 
            +
                    this._hosts = value;
         | 
| 236 | 
            +
                }
         | 
| 237 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 238 | 
            +
                get hostsInput() {
         | 
| 239 | 
            +
                    return this._hosts;
         | 
| 240 | 
            +
                }
         | 
| 241 | 
            +
            }
         | 
| 242 | 
            +
            exports.CertificateHttpMemcachedChallengeOutputReference = CertificateHttpMemcachedChallengeOutputReference;
         | 
| 243 | 
            +
            _d = JSII_RTTI_SYMBOL_1;
         | 
| 244 | 
            +
            CertificateHttpMemcachedChallengeOutputReference[_d] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpMemcachedChallengeOutputReference", version: "3.0.1" };
         | 
| 245 | 
            +
            function certificateHttpWebrootChallengeToTerraform(struct) {
         | 
| 246 | 
            +
                if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
         | 
| 247 | 
            +
                    return struct;
         | 
| 248 | 
            +
                }
         | 
| 249 | 
            +
                if (cdktf.isComplexElement(struct)) {
         | 
| 250 | 
            +
                    throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
         | 
| 251 | 
            +
                }
         | 
| 252 | 
            +
                return {
         | 
| 253 | 
            +
                    directory: cdktf.stringToTerraform(struct.directory),
         | 
| 254 | 
            +
                };
         | 
| 255 | 
            +
            }
         | 
| 256 | 
            +
            exports.certificateHttpWebrootChallengeToTerraform = certificateHttpWebrootChallengeToTerraform;
         | 
| 257 | 
            +
            class CertificateHttpWebrootChallengeOutputReference extends cdktf.ComplexObject {
         | 
| 258 | 
            +
                /**
         | 
| 259 | 
            +
                * @param terraformResource The parent resource
         | 
| 260 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 261 | 
            +
                */
         | 
| 262 | 
            +
                constructor(terraformResource, terraformAttribute) {
         | 
| 263 | 
            +
                    super(terraformResource, terraformAttribute, false, 0);
         | 
| 264 | 
            +
                    this.isEmptyObject = false;
         | 
| 265 | 
            +
                }
         | 
| 266 | 
            +
                get internalValue() {
         | 
| 267 | 
            +
                    let hasAnyValues = this.isEmptyObject;
         | 
| 268 | 
            +
                    const internalValueResult = {};
         | 
| 269 | 
            +
                    if (this._directory !== undefined) {
         | 
| 270 | 
            +
                        hasAnyValues = true;
         | 
| 271 | 
            +
                        internalValueResult.directory = this._directory;
         | 
| 272 | 
            +
                    }
         | 
| 273 | 
            +
                    return hasAnyValues ? internalValueResult : undefined;
         | 
| 274 | 
            +
                }
         | 
| 275 | 
            +
                set internalValue(value) {
         | 
| 276 | 
            +
                    if (value === undefined) {
         | 
| 277 | 
            +
                        this.isEmptyObject = false;
         | 
| 278 | 
            +
                        this._directory = undefined;
         | 
| 279 | 
            +
                    }
         | 
| 280 | 
            +
                    else {
         | 
| 281 | 
            +
                        this.isEmptyObject = Object.keys(value).length === 0;
         | 
| 282 | 
            +
                        this._directory = value.directory;
         | 
| 283 | 
            +
                    }
         | 
| 284 | 
            +
                }
         | 
| 285 | 
            +
                get directory() {
         | 
| 286 | 
            +
                    return this.getStringAttribute('directory');
         | 
| 287 | 
            +
                }
         | 
| 288 | 
            +
                set directory(value) {
         | 
| 289 | 
            +
                    this._directory = value;
         | 
| 290 | 
            +
                }
         | 
| 291 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 292 | 
            +
                get directoryInput() {
         | 
| 293 | 
            +
                    return this._directory;
         | 
| 294 | 
            +
                }
         | 
| 295 | 
            +
            }
         | 
| 296 | 
            +
            exports.CertificateHttpWebrootChallengeOutputReference = CertificateHttpWebrootChallengeOutputReference;
         | 
| 297 | 
            +
            _e = JSII_RTTI_SYMBOL_1;
         | 
| 298 | 
            +
            CertificateHttpWebrootChallengeOutputReference[_e] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpWebrootChallengeOutputReference", version: "3.0.1" };
         | 
| 299 | 
            +
            function certificateTlsChallengeToTerraform(struct) {
         | 
| 300 | 
            +
                if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
         | 
| 301 | 
            +
                    return struct;
         | 
| 302 | 
            +
                }
         | 
| 303 | 
            +
                if (cdktf.isComplexElement(struct)) {
         | 
| 304 | 
            +
                    throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
         | 
| 305 | 
            +
                }
         | 
| 306 | 
            +
                return {
         | 
| 307 | 
            +
                    port: cdktf.numberToTerraform(struct.port),
         | 
| 308 | 
            +
                };
         | 
| 309 | 
            +
            }
         | 
| 310 | 
            +
            exports.certificateTlsChallengeToTerraform = certificateTlsChallengeToTerraform;
         | 
| 311 | 
            +
            class CertificateTlsChallengeOutputReference extends cdktf.ComplexObject {
         | 
| 312 | 
            +
                /**
         | 
| 313 | 
            +
                * @param terraformResource The parent resource
         | 
| 314 | 
            +
                * @param terraformAttribute The attribute on the parent resource this class is referencing
         | 
| 315 | 
            +
                */
         | 
| 316 | 
            +
                constructor(terraformResource, terraformAttribute) {
         | 
| 317 | 
            +
                    super(terraformResource, terraformAttribute, false, 0);
         | 
| 318 | 
            +
                    this.isEmptyObject = false;
         | 
| 319 | 
            +
                }
         | 
| 320 | 
            +
                get internalValue() {
         | 
| 321 | 
            +
                    let hasAnyValues = this.isEmptyObject;
         | 
| 322 | 
            +
                    const internalValueResult = {};
         | 
| 323 | 
            +
                    if (this._port !== undefined) {
         | 
| 324 | 
            +
                        hasAnyValues = true;
         | 
| 325 | 
            +
                        internalValueResult.port = this._port;
         | 
| 326 | 
            +
                    }
         | 
| 327 | 
            +
                    return hasAnyValues ? internalValueResult : undefined;
         | 
| 328 | 
            +
                }
         | 
| 329 | 
            +
                set internalValue(value) {
         | 
| 330 | 
            +
                    if (value === undefined) {
         | 
| 331 | 
            +
                        this.isEmptyObject = false;
         | 
| 332 | 
            +
                        this._port = undefined;
         | 
| 333 | 
            +
                    }
         | 
| 334 | 
            +
                    else {
         | 
| 335 | 
            +
                        this.isEmptyObject = Object.keys(value).length === 0;
         | 
| 336 | 
            +
                        this._port = value.port;
         | 
| 337 | 
            +
                    }
         | 
| 338 | 
            +
                }
         | 
| 339 | 
            +
                get port() {
         | 
| 340 | 
            +
                    return this.getNumberAttribute('port');
         | 
| 341 | 
            +
                }
         | 
| 342 | 
            +
                set port(value) {
         | 
| 343 | 
            +
                    this._port = value;
         | 
| 344 | 
            +
                }
         | 
| 345 | 
            +
                resetPort() {
         | 
| 346 | 
            +
                    this._port = undefined;
         | 
| 347 | 
            +
                }
         | 
| 348 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 349 | 
            +
                get portInput() {
         | 
| 350 | 
            +
                    return this._port;
         | 
| 351 | 
            +
                }
         | 
| 352 | 
            +
            }
         | 
| 353 | 
            +
            exports.CertificateTlsChallengeOutputReference = CertificateTlsChallengeOutputReference;
         | 
| 354 | 
            +
            _f = JSII_RTTI_SYMBOL_1;
         | 
| 355 | 
            +
            CertificateTlsChallengeOutputReference[_f] = { fqn: "@cdktf/provider-acme.certificate.CertificateTlsChallengeOutputReference", version: "3.0.1" };
         | 
| 356 | 
            +
            /**
         | 
| 357 | 
            +
            * Represents a {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate}
         | 
| 358 | 
            +
            */
         | 
| 359 | 
            +
            class Certificate extends cdktf.TerraformResource {
         | 
| 360 | 
            +
                // ===========
         | 
| 361 | 
            +
                // INITIALIZER
         | 
| 362 | 
            +
                // ===========
         | 
| 363 | 
            +
                /**
         | 
| 364 | 
            +
                * Create a new {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate} Resource
         | 
| 365 | 
            +
                *
         | 
| 366 | 
            +
                * @param scope The scope in which to define this construct
         | 
| 367 | 
            +
                * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
         | 
| 368 | 
            +
                * @param options CertificateConfig
         | 
| 369 | 
            +
                */
         | 
| 370 | 
            +
                constructor(scope, id, config) {
         | 
| 371 | 
            +
                    super(scope, id, {
         | 
| 372 | 
            +
                        terraformResourceType: 'acme_certificate',
         | 
| 373 | 
            +
                        terraformGeneratorMetadata: {
         | 
| 374 | 
            +
                            providerName: 'acme',
         | 
| 375 | 
            +
                            providerVersion: '2.10.0',
         | 
| 376 | 
            +
                            providerVersionConstraint: '~> 2.10'
         | 
| 377 | 
            +
                        },
         | 
| 378 | 
            +
                        provider: config.provider,
         | 
| 379 | 
            +
                        dependsOn: config.dependsOn,
         | 
| 380 | 
            +
                        count: config.count,
         | 
| 381 | 
            +
                        lifecycle: config.lifecycle,
         | 
| 382 | 
            +
                        provisioners: config.provisioners,
         | 
| 383 | 
            +
                        connection: config.connection,
         | 
| 384 | 
            +
                        forEach: config.forEach
         | 
| 385 | 
            +
                    });
         | 
| 386 | 
            +
                    // dns_challenge - computed: false, optional: true, required: false
         | 
| 387 | 
            +
                    this._dnsChallenge = new CertificateDnsChallengeList(this, "dns_challenge", false);
         | 
| 388 | 
            +
                    // http_challenge - computed: false, optional: true, required: false
         | 
| 389 | 
            +
                    this._httpChallenge = new CertificateHttpChallengeOutputReference(this, "http_challenge");
         | 
| 390 | 
            +
                    // http_memcached_challenge - computed: false, optional: true, required: false
         | 
| 391 | 
            +
                    this._httpMemcachedChallenge = new CertificateHttpMemcachedChallengeOutputReference(this, "http_memcached_challenge");
         | 
| 392 | 
            +
                    // http_webroot_challenge - computed: false, optional: true, required: false
         | 
| 393 | 
            +
                    this._httpWebrootChallenge = new CertificateHttpWebrootChallengeOutputReference(this, "http_webroot_challenge");
         | 
| 394 | 
            +
                    // tls_challenge - computed: false, optional: true, required: false
         | 
| 395 | 
            +
                    this._tlsChallenge = new CertificateTlsChallengeOutputReference(this, "tls_challenge");
         | 
| 396 | 
            +
                    this._accountKeyPem = config.accountKeyPem;
         | 
| 397 | 
            +
                    this._certificateP12Password = config.certificateP12Password;
         | 
| 398 | 
            +
                    this._certificateRequestPem = config.certificateRequestPem;
         | 
| 399 | 
            +
                    this._commonName = config.commonName;
         | 
| 400 | 
            +
                    this._disableCompletePropagation = config.disableCompletePropagation;
         | 
| 401 | 
            +
                    this._id = config.id;
         | 
| 402 | 
            +
                    this._keyType = config.keyType;
         | 
| 403 | 
            +
                    this._minDaysRemaining = config.minDaysRemaining;
         | 
| 404 | 
            +
                    this._mustStaple = config.mustStaple;
         | 
| 405 | 
            +
                    this._preCheckDelay = config.preCheckDelay;
         | 
| 406 | 
            +
                    this._preferredChain = config.preferredChain;
         | 
| 407 | 
            +
                    this._recursiveNameservers = config.recursiveNameservers;
         | 
| 408 | 
            +
                    this._revokeCertificateOnDestroy = config.revokeCertificateOnDestroy;
         | 
| 409 | 
            +
                    this._subjectAlternativeNames = config.subjectAlternativeNames;
         | 
| 410 | 
            +
                    this._dnsChallenge.internalValue = config.dnsChallenge;
         | 
| 411 | 
            +
                    this._httpChallenge.internalValue = config.httpChallenge;
         | 
| 412 | 
            +
                    this._httpMemcachedChallenge.internalValue = config.httpMemcachedChallenge;
         | 
| 413 | 
            +
                    this._httpWebrootChallenge.internalValue = config.httpWebrootChallenge;
         | 
| 414 | 
            +
                    this._tlsChallenge.internalValue = config.tlsChallenge;
         | 
| 415 | 
            +
                }
         | 
| 416 | 
            +
                get accountKeyPem() {
         | 
| 417 | 
            +
                    return this.getStringAttribute('account_key_pem');
         | 
| 418 | 
            +
                }
         | 
| 419 | 
            +
                set accountKeyPem(value) {
         | 
| 420 | 
            +
                    this._accountKeyPem = value;
         | 
| 421 | 
            +
                }
         | 
| 422 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 423 | 
            +
                get accountKeyPemInput() {
         | 
| 424 | 
            +
                    return this._accountKeyPem;
         | 
| 425 | 
            +
                }
         | 
| 426 | 
            +
                // certificate_domain - computed: true, optional: false, required: false
         | 
| 427 | 
            +
                get certificateDomain() {
         | 
| 428 | 
            +
                    return this.getStringAttribute('certificate_domain');
         | 
| 429 | 
            +
                }
         | 
| 430 | 
            +
                // certificate_p12 - computed: true, optional: false, required: false
         | 
| 431 | 
            +
                get certificateP12() {
         | 
| 432 | 
            +
                    return this.getStringAttribute('certificate_p12');
         | 
| 433 | 
            +
                }
         | 
| 434 | 
            +
                get certificateP12Password() {
         | 
| 435 | 
            +
                    return this.getStringAttribute('certificate_p12_password');
         | 
| 436 | 
            +
                }
         | 
| 437 | 
            +
                set certificateP12Password(value) {
         | 
| 438 | 
            +
                    this._certificateP12Password = value;
         | 
| 439 | 
            +
                }
         | 
| 440 | 
            +
                resetCertificateP12Password() {
         | 
| 441 | 
            +
                    this._certificateP12Password = undefined;
         | 
| 442 | 
            +
                }
         | 
| 443 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 444 | 
            +
                get certificateP12PasswordInput() {
         | 
| 445 | 
            +
                    return this._certificateP12Password;
         | 
| 446 | 
            +
                }
         | 
| 447 | 
            +
                // certificate_pem - computed: true, optional: false, required: false
         | 
| 448 | 
            +
                get certificatePem() {
         | 
| 449 | 
            +
                    return this.getStringAttribute('certificate_pem');
         | 
| 450 | 
            +
                }
         | 
| 451 | 
            +
                get certificateRequestPem() {
         | 
| 452 | 
            +
                    return this.getStringAttribute('certificate_request_pem');
         | 
| 453 | 
            +
                }
         | 
| 454 | 
            +
                set certificateRequestPem(value) {
         | 
| 455 | 
            +
                    this._certificateRequestPem = value;
         | 
| 456 | 
            +
                }
         | 
| 457 | 
            +
                resetCertificateRequestPem() {
         | 
| 458 | 
            +
                    this._certificateRequestPem = undefined;
         | 
| 459 | 
            +
                }
         | 
| 460 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 461 | 
            +
                get certificateRequestPemInput() {
         | 
| 462 | 
            +
                    return this._certificateRequestPem;
         | 
| 463 | 
            +
                }
         | 
| 464 | 
            +
                // certificate_url - computed: true, optional: false, required: false
         | 
| 465 | 
            +
                get certificateUrl() {
         | 
| 466 | 
            +
                    return this.getStringAttribute('certificate_url');
         | 
| 467 | 
            +
                }
         | 
| 468 | 
            +
                get commonName() {
         | 
| 469 | 
            +
                    return this.getStringAttribute('common_name');
         | 
| 470 | 
            +
                }
         | 
| 471 | 
            +
                set commonName(value) {
         | 
| 472 | 
            +
                    this._commonName = value;
         | 
| 473 | 
            +
                }
         | 
| 474 | 
            +
                resetCommonName() {
         | 
| 475 | 
            +
                    this._commonName = undefined;
         | 
| 476 | 
            +
                }
         | 
| 477 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 478 | 
            +
                get commonNameInput() {
         | 
| 479 | 
            +
                    return this._commonName;
         | 
| 480 | 
            +
                }
         | 
| 481 | 
            +
                get disableCompletePropagation() {
         | 
| 482 | 
            +
                    return this.getBooleanAttribute('disable_complete_propagation');
         | 
| 483 | 
            +
                }
         | 
| 484 | 
            +
                set disableCompletePropagation(value) {
         | 
| 485 | 
            +
                    this._disableCompletePropagation = value;
         | 
| 486 | 
            +
                }
         | 
| 487 | 
            +
                resetDisableCompletePropagation() {
         | 
| 488 | 
            +
                    this._disableCompletePropagation = undefined;
         | 
| 489 | 
            +
                }
         | 
| 490 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 491 | 
            +
                get disableCompletePropagationInput() {
         | 
| 492 | 
            +
                    return this._disableCompletePropagation;
         | 
| 493 | 
            +
                }
         | 
| 494 | 
            +
                get id() {
         | 
| 495 | 
            +
                    return this.getStringAttribute('id');
         | 
| 496 | 
            +
                }
         | 
| 497 | 
            +
                set id(value) {
         | 
| 498 | 
            +
                    this._id = value;
         | 
| 499 | 
            +
                }
         | 
| 500 | 
            +
                resetId() {
         | 
| 501 | 
            +
                    this._id = undefined;
         | 
| 502 | 
            +
                }
         | 
| 503 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 504 | 
            +
                get idInput() {
         | 
| 505 | 
            +
                    return this._id;
         | 
| 506 | 
            +
                }
         | 
| 507 | 
            +
                // issuer_pem - computed: true, optional: false, required: false
         | 
| 508 | 
            +
                get issuerPem() {
         | 
| 509 | 
            +
                    return this.getStringAttribute('issuer_pem');
         | 
| 510 | 
            +
                }
         | 
| 511 | 
            +
                get keyType() {
         | 
| 512 | 
            +
                    return this.getStringAttribute('key_type');
         | 
| 513 | 
            +
                }
         | 
| 514 | 
            +
                set keyType(value) {
         | 
| 515 | 
            +
                    this._keyType = value;
         | 
| 516 | 
            +
                }
         | 
| 517 | 
            +
                resetKeyType() {
         | 
| 518 | 
            +
                    this._keyType = undefined;
         | 
| 519 | 
            +
                }
         | 
| 520 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 521 | 
            +
                get keyTypeInput() {
         | 
| 522 | 
            +
                    return this._keyType;
         | 
| 523 | 
            +
                }
         | 
| 524 | 
            +
                get minDaysRemaining() {
         | 
| 525 | 
            +
                    return this.getNumberAttribute('min_days_remaining');
         | 
| 526 | 
            +
                }
         | 
| 527 | 
            +
                set minDaysRemaining(value) {
         | 
| 528 | 
            +
                    this._minDaysRemaining = value;
         | 
| 529 | 
            +
                }
         | 
| 530 | 
            +
                resetMinDaysRemaining() {
         | 
| 531 | 
            +
                    this._minDaysRemaining = undefined;
         | 
| 532 | 
            +
                }
         | 
| 533 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 534 | 
            +
                get minDaysRemainingInput() {
         | 
| 535 | 
            +
                    return this._minDaysRemaining;
         | 
| 536 | 
            +
                }
         | 
| 537 | 
            +
                get mustStaple() {
         | 
| 538 | 
            +
                    return this.getBooleanAttribute('must_staple');
         | 
| 539 | 
            +
                }
         | 
| 540 | 
            +
                set mustStaple(value) {
         | 
| 541 | 
            +
                    this._mustStaple = value;
         | 
| 542 | 
            +
                }
         | 
| 543 | 
            +
                resetMustStaple() {
         | 
| 544 | 
            +
                    this._mustStaple = undefined;
         | 
| 545 | 
            +
                }
         | 
| 546 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 547 | 
            +
                get mustStapleInput() {
         | 
| 548 | 
            +
                    return this._mustStaple;
         | 
| 549 | 
            +
                }
         | 
| 550 | 
            +
                get preCheckDelay() {
         | 
| 551 | 
            +
                    return this.getNumberAttribute('pre_check_delay');
         | 
| 552 | 
            +
                }
         | 
| 553 | 
            +
                set preCheckDelay(value) {
         | 
| 554 | 
            +
                    this._preCheckDelay = value;
         | 
| 555 | 
            +
                }
         | 
| 556 | 
            +
                resetPreCheckDelay() {
         | 
| 557 | 
            +
                    this._preCheckDelay = undefined;
         | 
| 558 | 
            +
                }
         | 
| 559 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 560 | 
            +
                get preCheckDelayInput() {
         | 
| 561 | 
            +
                    return this._preCheckDelay;
         | 
| 562 | 
            +
                }
         | 
| 563 | 
            +
                get preferredChain() {
         | 
| 564 | 
            +
                    return this.getStringAttribute('preferred_chain');
         | 
| 565 | 
            +
                }
         | 
| 566 | 
            +
                set preferredChain(value) {
         | 
| 567 | 
            +
                    this._preferredChain = value;
         | 
| 568 | 
            +
                }
         | 
| 569 | 
            +
                resetPreferredChain() {
         | 
| 570 | 
            +
                    this._preferredChain = undefined;
         | 
| 571 | 
            +
                }
         | 
| 572 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 573 | 
            +
                get preferredChainInput() {
         | 
| 574 | 
            +
                    return this._preferredChain;
         | 
| 575 | 
            +
                }
         | 
| 576 | 
            +
                // private_key_pem - computed: true, optional: false, required: false
         | 
| 577 | 
            +
                get privateKeyPem() {
         | 
| 578 | 
            +
                    return this.getStringAttribute('private_key_pem');
         | 
| 579 | 
            +
                }
         | 
| 580 | 
            +
                get recursiveNameservers() {
         | 
| 581 | 
            +
                    return this.getListAttribute('recursive_nameservers');
         | 
| 582 | 
            +
                }
         | 
| 583 | 
            +
                set recursiveNameservers(value) {
         | 
| 584 | 
            +
                    this._recursiveNameservers = value;
         | 
| 585 | 
            +
                }
         | 
| 586 | 
            +
                resetRecursiveNameservers() {
         | 
| 587 | 
            +
                    this._recursiveNameservers = undefined;
         | 
| 588 | 
            +
                }
         | 
| 589 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 590 | 
            +
                get recursiveNameserversInput() {
         | 
| 591 | 
            +
                    return this._recursiveNameservers;
         | 
| 592 | 
            +
                }
         | 
| 593 | 
            +
                get revokeCertificateOnDestroy() {
         | 
| 594 | 
            +
                    return this.getBooleanAttribute('revoke_certificate_on_destroy');
         | 
| 595 | 
            +
                }
         | 
| 596 | 
            +
                set revokeCertificateOnDestroy(value) {
         | 
| 597 | 
            +
                    this._revokeCertificateOnDestroy = value;
         | 
| 598 | 
            +
                }
         | 
| 599 | 
            +
                resetRevokeCertificateOnDestroy() {
         | 
| 600 | 
            +
                    this._revokeCertificateOnDestroy = undefined;
         | 
| 601 | 
            +
                }
         | 
| 602 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 603 | 
            +
                get revokeCertificateOnDestroyInput() {
         | 
| 604 | 
            +
                    return this._revokeCertificateOnDestroy;
         | 
| 605 | 
            +
                }
         | 
| 606 | 
            +
                get subjectAlternativeNames() {
         | 
| 607 | 
            +
                    return cdktf.Fn.tolist(this.getListAttribute('subject_alternative_names'));
         | 
| 608 | 
            +
                }
         | 
| 609 | 
            +
                set subjectAlternativeNames(value) {
         | 
| 610 | 
            +
                    this._subjectAlternativeNames = value;
         | 
| 611 | 
            +
                }
         | 
| 612 | 
            +
                resetSubjectAlternativeNames() {
         | 
| 613 | 
            +
                    this._subjectAlternativeNames = undefined;
         | 
| 614 | 
            +
                }
         | 
| 615 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 616 | 
            +
                get subjectAlternativeNamesInput() {
         | 
| 617 | 
            +
                    return this._subjectAlternativeNames;
         | 
| 618 | 
            +
                }
         | 
| 619 | 
            +
                get dnsChallenge() {
         | 
| 620 | 
            +
                    return this._dnsChallenge;
         | 
| 621 | 
            +
                }
         | 
| 622 | 
            +
                putDnsChallenge(value) {
         | 
| 623 | 
            +
                    this._dnsChallenge.internalValue = value;
         | 
| 624 | 
            +
                }
         | 
| 625 | 
            +
                resetDnsChallenge() {
         | 
| 626 | 
            +
                    this._dnsChallenge.internalValue = undefined;
         | 
| 627 | 
            +
                }
         | 
| 628 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 629 | 
            +
                get dnsChallengeInput() {
         | 
| 630 | 
            +
                    return this._dnsChallenge.internalValue;
         | 
| 631 | 
            +
                }
         | 
| 632 | 
            +
                get httpChallenge() {
         | 
| 633 | 
            +
                    return this._httpChallenge;
         | 
| 634 | 
            +
                }
         | 
| 635 | 
            +
                putHttpChallenge(value) {
         | 
| 636 | 
            +
                    this._httpChallenge.internalValue = value;
         | 
| 637 | 
            +
                }
         | 
| 638 | 
            +
                resetHttpChallenge() {
         | 
| 639 | 
            +
                    this._httpChallenge.internalValue = undefined;
         | 
| 640 | 
            +
                }
         | 
| 641 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 642 | 
            +
                get httpChallengeInput() {
         | 
| 643 | 
            +
                    return this._httpChallenge.internalValue;
         | 
| 644 | 
            +
                }
         | 
| 645 | 
            +
                get httpMemcachedChallenge() {
         | 
| 646 | 
            +
                    return this._httpMemcachedChallenge;
         | 
| 647 | 
            +
                }
         | 
| 648 | 
            +
                putHttpMemcachedChallenge(value) {
         | 
| 649 | 
            +
                    this._httpMemcachedChallenge.internalValue = value;
         | 
| 650 | 
            +
                }
         | 
| 651 | 
            +
                resetHttpMemcachedChallenge() {
         | 
| 652 | 
            +
                    this._httpMemcachedChallenge.internalValue = undefined;
         | 
| 653 | 
            +
                }
         | 
| 654 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 655 | 
            +
                get httpMemcachedChallengeInput() {
         | 
| 656 | 
            +
                    return this._httpMemcachedChallenge.internalValue;
         | 
| 657 | 
            +
                }
         | 
| 658 | 
            +
                get httpWebrootChallenge() {
         | 
| 659 | 
            +
                    return this._httpWebrootChallenge;
         | 
| 660 | 
            +
                }
         | 
| 661 | 
            +
                putHttpWebrootChallenge(value) {
         | 
| 662 | 
            +
                    this._httpWebrootChallenge.internalValue = value;
         | 
| 663 | 
            +
                }
         | 
| 664 | 
            +
                resetHttpWebrootChallenge() {
         | 
| 665 | 
            +
                    this._httpWebrootChallenge.internalValue = undefined;
         | 
| 666 | 
            +
                }
         | 
| 667 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 668 | 
            +
                get httpWebrootChallengeInput() {
         | 
| 669 | 
            +
                    return this._httpWebrootChallenge.internalValue;
         | 
| 670 | 
            +
                }
         | 
| 671 | 
            +
                get tlsChallenge() {
         | 
| 672 | 
            +
                    return this._tlsChallenge;
         | 
| 673 | 
            +
                }
         | 
| 674 | 
            +
                putTlsChallenge(value) {
         | 
| 675 | 
            +
                    this._tlsChallenge.internalValue = value;
         | 
| 676 | 
            +
                }
         | 
| 677 | 
            +
                resetTlsChallenge() {
         | 
| 678 | 
            +
                    this._tlsChallenge.internalValue = undefined;
         | 
| 679 | 
            +
                }
         | 
| 680 | 
            +
                // Temporarily expose input value. Use with caution.
         | 
| 681 | 
            +
                get tlsChallengeInput() {
         | 
| 682 | 
            +
                    return this._tlsChallenge.internalValue;
         | 
| 683 | 
            +
                }
         | 
| 684 | 
            +
                // =========
         | 
| 685 | 
            +
                // SYNTHESIS
         | 
| 686 | 
            +
                // =========
         | 
| 687 | 
            +
                synthesizeAttributes() {
         | 
| 688 | 
            +
                    return {
         | 
| 689 | 
            +
                        account_key_pem: cdktf.stringToTerraform(this._accountKeyPem),
         | 
| 690 | 
            +
                        certificate_p12_password: cdktf.stringToTerraform(this._certificateP12Password),
         | 
| 691 | 
            +
                        certificate_request_pem: cdktf.stringToTerraform(this._certificateRequestPem),
         | 
| 692 | 
            +
                        common_name: cdktf.stringToTerraform(this._commonName),
         | 
| 693 | 
            +
                        disable_complete_propagation: cdktf.booleanToTerraform(this._disableCompletePropagation),
         | 
| 694 | 
            +
                        id: cdktf.stringToTerraform(this._id),
         | 
| 695 | 
            +
                        key_type: cdktf.stringToTerraform(this._keyType),
         | 
| 696 | 
            +
                        min_days_remaining: cdktf.numberToTerraform(this._minDaysRemaining),
         | 
| 697 | 
            +
                        must_staple: cdktf.booleanToTerraform(this._mustStaple),
         | 
| 698 | 
            +
                        pre_check_delay: cdktf.numberToTerraform(this._preCheckDelay),
         | 
| 699 | 
            +
                        preferred_chain: cdktf.stringToTerraform(this._preferredChain),
         | 
| 700 | 
            +
                        recursive_nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._recursiveNameservers),
         | 
| 701 | 
            +
                        revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),
         | 
| 702 | 
            +
                        subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform, false)(this._subjectAlternativeNames),
         | 
| 703 | 
            +
                        dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform, true)(this._dnsChallenge.internalValue),
         | 
| 704 | 
            +
                        http_challenge: certificateHttpChallengeToTerraform(this._httpChallenge.internalValue),
         | 
| 705 | 
            +
                        http_memcached_challenge: certificateHttpMemcachedChallengeToTerraform(this._httpMemcachedChallenge.internalValue),
         | 
| 706 | 
            +
                        http_webroot_challenge: certificateHttpWebrootChallengeToTerraform(this._httpWebrootChallenge.internalValue),
         | 
| 707 | 
            +
                        tls_challenge: certificateTlsChallengeToTerraform(this._tlsChallenge.internalValue),
         | 
| 708 | 
            +
                    };
         | 
| 709 | 
            +
                }
         | 
| 710 | 
            +
            }
         | 
| 711 | 
            +
            exports.Certificate = Certificate;
         | 
| 712 | 
            +
            _g = JSII_RTTI_SYMBOL_1;
         | 
| 713 | 
            +
            Certificate[_g] = { fqn: "@cdktf/provider-acme.certificate.Certificate", version: "3.0.1" };
         | 
| 714 | 
            +
            // =================
         | 
| 715 | 
            +
            // STATIC PROPERTIES
         | 
| 716 | 
            +
            // =================
         | 
| 717 | 
            +
            Certificate.tfResourceType = "acme_certificate";
         | 
| 718 | 
            +
            //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/certificate/index.ts"],"names":[],"mappings":"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","sourcesContent":["// https://www.terraform.io/docs/providers/acme/r/certificate\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface CertificateConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#account_key_pem Certificate#account_key_pem}\n  */\n  readonly accountKeyPem: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#certificate_p12_password Certificate#certificate_p12_password}\n  */\n  readonly certificateP12Password?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#certificate_request_pem Certificate#certificate_request_pem}\n  */\n  readonly certificateRequestPem?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#common_name Certificate#common_name}\n  */\n  readonly commonName?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#disable_complete_propagation Certificate#disable_complete_propagation}\n  */\n  readonly disableCompletePropagation?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#id Certificate#id}\n  *\n  * Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2.\n  * If you experience problems setting this value it might not be settable. Please take a look at the provider documentation to ensure it should be settable.\n  */\n  readonly id?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#key_type Certificate#key_type}\n  */\n  readonly keyType?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#min_days_remaining Certificate#min_days_remaining}\n  */\n  readonly minDaysRemaining?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#must_staple Certificate#must_staple}\n  */\n  readonly mustStaple?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#pre_check_delay Certificate#pre_check_delay}\n  */\n  readonly preCheckDelay?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#preferred_chain Certificate#preferred_chain}\n  */\n  readonly preferredChain?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#recursive_nameservers Certificate#recursive_nameservers}\n  */\n  readonly recursiveNameservers?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#revoke_certificate_on_destroy Certificate#revoke_certificate_on_destroy}\n  */\n  readonly revokeCertificateOnDestroy?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#subject_alternative_names Certificate#subject_alternative_names}\n  */\n  readonly subjectAlternativeNames?: string[];\n  /**\n  * dns_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#dns_challenge Certificate#dns_challenge}\n  */\n  readonly dnsChallenge?: CertificateDnsChallenge[] | cdktf.IResolvable;\n  /**\n  * http_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_challenge Certificate#http_challenge}\n  */\n  readonly httpChallenge?: CertificateHttpChallenge;\n  /**\n  * http_memcached_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_memcached_challenge Certificate#http_memcached_challenge}\n  */\n  readonly httpMemcachedChallenge?: CertificateHttpMemcachedChallenge;\n  /**\n  * http_webroot_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_webroot_challenge Certificate#http_webroot_challenge}\n  */\n  readonly httpWebrootChallenge?: CertificateHttpWebrootChallenge;\n  /**\n  * tls_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#tls_challenge Certificate#tls_challenge}\n  */\n  readonly tlsChallenge?: CertificateTlsChallenge;\n}\nexport interface CertificateDnsChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#config Certificate#config}\n  */\n  readonly config?: { [key: string]: string };\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#provider Certificate#provider}\n  */\n  readonly provider: string;\n}\n\nexport function certificateDnsChallengeToTerraform(struct?: CertificateDnsChallenge | cdktf.IResolvable): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    config: cdktf.hashMapper(cdktf.stringToTerraform)(struct!.config),\n    provider: cdktf.stringToTerraform(struct!.provider),\n  }\n}\n\nexport class CertificateDnsChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n  private resolvableValue?: cdktf.IResolvable;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): CertificateDnsChallenge | cdktf.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._config !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.config = this._config;\n    }\n    if (this._provider !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.provider = this._provider;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateDnsChallenge | cdktf.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._config = undefined;\n      this._provider = undefined;\n    }\n    else if (cdktf.Tokenization.isResolvable(value)) {\n      this.isEmptyObject = false;\n      this.resolvableValue = value;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this.resolvableValue = undefined;\n      this._config = value.config;\n      this._provider = value.provider;\n    }\n  }\n\n  // config - computed: false, optional: true, required: false\n  private _config?: { [key: string]: string }; \n  public get config() {\n    return this.getStringMapAttribute('config');\n  }\n  public set config(value: { [key: string]: string }) {\n    this._config = value;\n  }\n  public resetConfig() {\n    this._config = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get configInput() {\n    return this._config;\n  }\n\n  // provider - computed: false, optional: false, required: true\n  private _provider?: string; \n  public get provider() {\n    return this.getStringAttribute('provider');\n  }\n  public set provider(value: string) {\n    this._provider = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get providerInput() {\n    return this._provider;\n  }\n}\n\nexport class CertificateDnsChallengeList extends cdktf.ComplexList {\n  public internalValue? : CertificateDnsChallenge[] | cdktf.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktf.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): CertificateDnsChallengeOutputReference {\n    return new CertificateDnsChallengeOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface CertificateHttpChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#port Certificate#port}\n  */\n  readonly port?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#proxy_header Certificate#proxy_header}\n  */\n  readonly proxyHeader?: string;\n}\n\nexport function certificateHttpChallengeToTerraform(struct?: CertificateHttpChallengeOutputReference | CertificateHttpChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    port: cdktf.numberToTerraform(struct!.port),\n    proxy_header: cdktf.stringToTerraform(struct!.proxyHeader),\n  }\n}\n\nexport class CertificateHttpChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._port !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.port = this._port;\n    }\n    if (this._proxyHeader !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.proxyHeader = this._proxyHeader;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._port = undefined;\n      this._proxyHeader = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._port = value.port;\n      this._proxyHeader = value.proxyHeader;\n    }\n  }\n\n  // port - computed: false, optional: true, required: false\n  private _port?: number; \n  public get port() {\n    return this.getNumberAttribute('port');\n  }\n  public set port(value: number) {\n    this._port = value;\n  }\n  public resetPort() {\n    this._port = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get portInput() {\n    return this._port;\n  }\n\n  // proxy_header - computed: false, optional: true, required: false\n  private _proxyHeader?: string; \n  public get proxyHeader() {\n    return this.getStringAttribute('proxy_header');\n  }\n  public set proxyHeader(value: string) {\n    this._proxyHeader = value;\n  }\n  public resetProxyHeader() {\n    this._proxyHeader = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get proxyHeaderInput() {\n    return this._proxyHeader;\n  }\n}\nexport interface CertificateHttpMemcachedChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#hosts Certificate#hosts}\n  */\n  readonly hosts: string[];\n}\n\nexport function certificateHttpMemcachedChallengeToTerraform(struct?: CertificateHttpMemcachedChallengeOutputReference | CertificateHttpMemcachedChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    hosts: cdktf.listMapper(cdktf.stringToTerraform, false)(struct!.hosts),\n  }\n}\n\nexport class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpMemcachedChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._hosts !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.hosts = this._hosts;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpMemcachedChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._hosts = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._hosts = value.hosts;\n    }\n  }\n\n  // hosts - computed: false, optional: false, required: true\n  private _hosts?: string[]; \n  public get hosts() {\n    return cdktf.Fn.tolist(this.getListAttribute('hosts'));\n  }\n  public set hosts(value: string[]) {\n    this._hosts = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get hostsInput() {\n    return this._hosts;\n  }\n}\nexport interface CertificateHttpWebrootChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#directory Certificate#directory}\n  */\n  readonly directory: string;\n}\n\nexport function certificateHttpWebrootChallengeToTerraform(struct?: CertificateHttpWebrootChallengeOutputReference | CertificateHttpWebrootChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    directory: cdktf.stringToTerraform(struct!.directory),\n  }\n}\n\nexport class CertificateHttpWebrootChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpWebrootChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._directory !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.directory = this._directory;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpWebrootChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._directory = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._directory = value.directory;\n    }\n  }\n\n  // directory - computed: false, optional: false, required: true\n  private _directory?: string; \n  public get directory() {\n    return this.getStringAttribute('directory');\n  }\n  public set directory(value: string) {\n    this._directory = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get directoryInput() {\n    return this._directory;\n  }\n}\nexport interface CertificateTlsChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#port Certificate#port}\n  */\n  readonly port?: number;\n}\n\nexport function certificateTlsChallengeToTerraform(struct?: CertificateTlsChallengeOutputReference | CertificateTlsChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    port: cdktf.numberToTerraform(struct!.port),\n  }\n}\n\nexport class CertificateTlsChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateTlsChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._port !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.port = this._port;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateTlsChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._port = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._port = value.port;\n    }\n  }\n\n  // port - computed: false, optional: true, required: false\n  private _port?: number; \n  public get port() {\n    return this.getNumberAttribute('port');\n  }\n  public set port(value: number) {\n    this._port = value;\n  }\n  public resetPort() {\n    this._port = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get portInput() {\n    return this._port;\n  }\n}\n\n/**\n* Represents a {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate}\n*/\nexport class Certificate extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"acme_certificate\";\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate} Resource\n  *\n  * @param scope The scope in which to define this construct\n  * @param id The scoped construct ID. Must be unique amongst siblings in the same scope\n  * @param options CertificateConfig\n  */\n  public constructor(scope: Construct, id: string, config: CertificateConfig) {\n    super(scope, id, {\n      terraformResourceType: 'acme_certificate',\n      terraformGeneratorMetadata: {\n        providerName: 'acme',\n        providerVersion: '2.10.0',\n        providerVersionConstraint: '~> 2.10'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle,\n      provisioners: config.provisioners,\n      connection: config.connection,\n      forEach: config.forEach\n    });\n    this._accountKeyPem = config.accountKeyPem;\n    this._certificateP12Password = config.certificateP12Password;\n    this._certificateRequestPem = config.certificateRequestPem;\n    this._commonName = config.commonName;\n    this._disableCompletePropagation = config.disableCompletePropagation;\n    this._id = config.id;\n    this._keyType = config.keyType;\n    this._minDaysRemaining = config.minDaysRemaining;\n    this._mustStaple = config.mustStaple;\n    this._preCheckDelay = config.preCheckDelay;\n    this._preferredChain = config.preferredChain;\n    this._recursiveNameservers = config.recursiveNameservers;\n    this._revokeCertificateOnDestroy = config.revokeCertificateOnDestroy;\n    this._subjectAlternativeNames = config.subjectAlternativeNames;\n    this._dnsChallenge.internalValue = config.dnsChallenge;\n    this._httpChallenge.internalValue = config.httpChallenge;\n    this._httpMemcachedChallenge.internalValue = config.httpMemcachedChallenge;\n    this._httpWebrootChallenge.internalValue = config.httpWebrootChallenge;\n    this._tlsChallenge.internalValue = config.tlsChallenge;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // account_key_pem - computed: false, optional: false, required: true\n  private _accountKeyPem?: string; \n  public get accountKeyPem() {\n    return this.getStringAttribute('account_key_pem');\n  }\n  public set accountKeyPem(value: string) {\n    this._accountKeyPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get accountKeyPemInput() {\n    return this._accountKeyPem;\n  }\n\n  // certificate_domain - computed: true, optional: false, required: false\n  public get certificateDomain() {\n    return this.getStringAttribute('certificate_domain');\n  }\n\n  // certificate_p12 - computed: true, optional: false, required: false\n  public get certificateP12() {\n    return this.getStringAttribute('certificate_p12');\n  }\n\n  // certificate_p12_password - computed: false, optional: true, required: false\n  private _certificateP12Password?: string; \n  public get certificateP12Password() {\n    return this.getStringAttribute('certificate_p12_password');\n  }\n  public set certificateP12Password(value: string) {\n    this._certificateP12Password = value;\n  }\n  public resetCertificateP12Password() {\n    this._certificateP12Password = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certificateP12PasswordInput() {\n    return this._certificateP12Password;\n  }\n\n  // certificate_pem - computed: true, optional: false, required: false\n  public get certificatePem() {\n    return this.getStringAttribute('certificate_pem');\n  }\n\n  // certificate_request_pem - computed: false, optional: true, required: false\n  private _certificateRequestPem?: string; \n  public get certificateRequestPem() {\n    return this.getStringAttribute('certificate_request_pem');\n  }\n  public set certificateRequestPem(value: string) {\n    this._certificateRequestPem = value;\n  }\n  public resetCertificateRequestPem() {\n    this._certificateRequestPem = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certificateRequestPemInput() {\n    return this._certificateRequestPem;\n  }\n\n  // certificate_url - computed: true, optional: false, required: false\n  public get certificateUrl() {\n    return this.getStringAttribute('certificate_url');\n  }\n\n  // common_name - computed: false, optional: true, required: false\n  private _commonName?: string; \n  public get commonName() {\n    return this.getStringAttribute('common_name');\n  }\n  public set commonName(value: string) {\n    this._commonName = value;\n  }\n  public resetCommonName() {\n    this._commonName = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get commonNameInput() {\n    return this._commonName;\n  }\n\n  // disable_complete_propagation - computed: false, optional: true, required: false\n  private _disableCompletePropagation?: boolean | cdktf.IResolvable; \n  public get disableCompletePropagation() {\n    return this.getBooleanAttribute('disable_complete_propagation');\n  }\n  public set disableCompletePropagation(value: boolean | cdktf.IResolvable) {\n    this._disableCompletePropagation = value;\n  }\n  public resetDisableCompletePropagation() {\n    this._disableCompletePropagation = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get disableCompletePropagationInput() {\n    return this._disableCompletePropagation;\n  }\n\n  // id - computed: true, optional: true, required: false\n  private _id?: string; \n  public get id() {\n    return this.getStringAttribute('id');\n  }\n  public set id(value: string) {\n    this._id = value;\n  }\n  public resetId() {\n    this._id = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get idInput() {\n    return this._id;\n  }\n\n  // issuer_pem - computed: true, optional: false, required: false\n  public get issuerPem() {\n    return this.getStringAttribute('issuer_pem');\n  }\n\n  // key_type - computed: false, optional: true, required: false\n  private _keyType?: string; \n  public get keyType() {\n    return this.getStringAttribute('key_type');\n  }\n  public set keyType(value: string) {\n    this._keyType = value;\n  }\n  public resetKeyType() {\n    this._keyType = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get keyTypeInput() {\n    return this._keyType;\n  }\n\n  // min_days_remaining - computed: false, optional: true, required: false\n  private _minDaysRemaining?: number; \n  public get minDaysRemaining() {\n    return this.getNumberAttribute('min_days_remaining');\n  }\n  public set minDaysRemaining(value: number) {\n    this._minDaysRemaining = value;\n  }\n  public resetMinDaysRemaining() {\n    this._minDaysRemaining = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get minDaysRemainingInput() {\n    return this._minDaysRemaining;\n  }\n\n  // must_staple - computed: false, optional: true, required: false\n  private _mustStaple?: boolean | cdktf.IResolvable; \n  public get mustStaple() {\n    return this.getBooleanAttribute('must_staple');\n  }\n  public set mustStaple(value: boolean | cdktf.IResolvable) {\n    this._mustStaple = value;\n  }\n  public resetMustStaple() {\n    this._mustStaple = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get mustStapleInput() {\n    return this._mustStaple;\n  }\n\n  // pre_check_delay - computed: false, optional: true, required: false\n  private _preCheckDelay?: number; \n  public get preCheckDelay() {\n    return this.getNumberAttribute('pre_check_delay');\n  }\n  public set preCheckDelay(value: number) {\n    this._preCheckDelay = value;\n  }\n  public resetPreCheckDelay() {\n    this._preCheckDelay = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get preCheckDelayInput() {\n    return this._preCheckDelay;\n  }\n\n  // preferred_chain - computed: false, optional: true, required: false\n  private _preferredChain?: string; \n  public get preferredChain() {\n    return this.getStringAttribute('preferred_chain');\n  }\n  public set preferredChain(value: string) {\n    this._preferredChain = value;\n  }\n  public resetPreferredChain() {\n    this._preferredChain = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get preferredChainInput() {\n    return this._preferredChain;\n  }\n\n  // private_key_pem - computed: true, optional: false, required: false\n  public get privateKeyPem() {\n    return this.getStringAttribute('private_key_pem');\n  }\n\n  // recursive_nameservers - computed: false, optional: true, required: false\n  private _recursiveNameservers?: string[]; \n  public get recursiveNameservers() {\n    return this.getListAttribute('recursive_nameservers');\n  }\n  public set recursiveNameservers(value: string[]) {\n    this._recursiveNameservers = value;\n  }\n  public resetRecursiveNameservers() {\n    this._recursiveNameservers = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get recursiveNameserversInput() {\n    return this._recursiveNameservers;\n  }\n\n  // revoke_certificate_on_destroy - computed: false, optional: true, required: false\n  private _revokeCertificateOnDestroy?: boolean | cdktf.IResolvable; \n  public get revokeCertificateOnDestroy() {\n    return this.getBooleanAttribute('revoke_certificate_on_destroy');\n  }\n  public set revokeCertificateOnDestroy(value: boolean | cdktf.IResolvable) {\n    this._revokeCertificateOnDestroy = value;\n  }\n  public resetRevokeCertificateOnDestroy() {\n    this._revokeCertificateOnDestroy = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get revokeCertificateOnDestroyInput() {\n    return this._revokeCertificateOnDestroy;\n  }\n\n  // subject_alternative_names - computed: false, optional: true, required: false\n  private _subjectAlternativeNames?: string[]; \n  public get subjectAlternativeNames() {\n    return cdktf.Fn.tolist(this.getListAttribute('subject_alternative_names'));\n  }\n  public set subjectAlternativeNames(value: string[]) {\n    this._subjectAlternativeNames = value;\n  }\n  public resetSubjectAlternativeNames() {\n    this._subjectAlternativeNames = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get subjectAlternativeNamesInput() {\n    return this._subjectAlternativeNames;\n  }\n\n  // dns_challenge - computed: false, optional: true, required: false\n  private _dnsChallenge = new CertificateDnsChallengeList(this, \"dns_challenge\", false);\n  public get dnsChallenge() {\n    return this._dnsChallenge;\n  }\n  public putDnsChallenge(value: CertificateDnsChallenge[] | cdktf.IResolvable) {\n    this._dnsChallenge.internalValue = value;\n  }\n  public resetDnsChallenge() {\n    this._dnsChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get dnsChallengeInput() {\n    return this._dnsChallenge.internalValue;\n  }\n\n  // http_challenge - computed: false, optional: true, required: false\n  private _httpChallenge = new CertificateHttpChallengeOutputReference(this, \"http_challenge\");\n  public get httpChallenge() {\n    return this._httpChallenge;\n  }\n  public putHttpChallenge(value: CertificateHttpChallenge) {\n    this._httpChallenge.internalValue = value;\n  }\n  public resetHttpChallenge() {\n    this._httpChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpChallengeInput() {\n    return this._httpChallenge.internalValue;\n  }\n\n  // http_memcached_challenge - computed: false, optional: true, required: false\n  private _httpMemcachedChallenge = new CertificateHttpMemcachedChallengeOutputReference(this, \"http_memcached_challenge\");\n  public get httpMemcachedChallenge() {\n    return this._httpMemcachedChallenge;\n  }\n  public putHttpMemcachedChallenge(value: CertificateHttpMemcachedChallenge) {\n    this._httpMemcachedChallenge.internalValue = value;\n  }\n  public resetHttpMemcachedChallenge() {\n    this._httpMemcachedChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpMemcachedChallengeInput() {\n    return this._httpMemcachedChallenge.internalValue;\n  }\n\n  // http_webroot_challenge - computed: false, optional: true, required: false\n  private _httpWebrootChallenge = new CertificateHttpWebrootChallengeOutputReference(this, \"http_webroot_challenge\");\n  public get httpWebrootChallenge() {\n    return this._httpWebrootChallenge;\n  }\n  public putHttpWebrootChallenge(value: CertificateHttpWebrootChallenge) {\n    this._httpWebrootChallenge.internalValue = value;\n  }\n  public resetHttpWebrootChallenge() {\n    this._httpWebrootChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpWebrootChallengeInput() {\n    return this._httpWebrootChallenge.internalValue;\n  }\n\n  // tls_challenge - computed: false, optional: true, required: false\n  private _tlsChallenge = new CertificateTlsChallengeOutputReference(this, \"tls_challenge\");\n  public get tlsChallenge() {\n    return this._tlsChallenge;\n  }\n  public putTlsChallenge(value: CertificateTlsChallenge) {\n    this._tlsChallenge.internalValue = value;\n  }\n  public resetTlsChallenge() {\n    this._tlsChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get tlsChallengeInput() {\n    return this._tlsChallenge.internalValue;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      account_key_pem: cdktf.stringToTerraform(this._accountKeyPem),\n      certificate_p12_password: cdktf.stringToTerraform(this._certificateP12Password),\n      certificate_request_pem: cdktf.stringToTerraform(this._certificateRequestPem),\n      common_name: cdktf.stringToTerraform(this._commonName),\n      disable_complete_propagation: cdktf.booleanToTerraform(this._disableCompletePropagation),\n      id: cdktf.stringToTerraform(this._id),\n      key_type: cdktf.stringToTerraform(this._keyType),\n      min_days_remaining: cdktf.numberToTerraform(this._minDaysRemaining),\n      must_staple: cdktf.booleanToTerraform(this._mustStaple),\n      pre_check_delay: cdktf.numberToTerraform(this._preCheckDelay),\n      preferred_chain: cdktf.stringToTerraform(this._preferredChain),\n      recursive_nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._recursiveNameservers),\n      revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),\n      subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform, false)(this._subjectAlternativeNames),\n      dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform, true)(this._dnsChallenge.internalValue),\n      http_challenge: certificateHttpChallengeToTerraform(this._httpChallenge.internalValue),\n      http_memcached_challenge: certificateHttpMemcachedChallengeToTerraform(this._httpMemcachedChallenge.internalValue),\n      http_webroot_challenge: certificateHttpWebrootChallengeToTerraform(this._httpWebrootChallenge.internalValue),\n      tls_challenge: certificateTlsChallengeToTerraform(this._tlsChallenge.internalValue),\n    };\n  }\n}\n"]}
         |