@alekitto/cdk-constructs
Advanced tools
Comparing version 0.1.8-beta.3 to 0.1.8
@@ -111,2 +111,2 @@ "use strict"; | ||
exports.Code = Code; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["code.ts"],"names":[],"mappings":"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","sourcesContent":["import { AssetStaging, BundlingOptions, DockerVolume, aws_lambda as lambda, aws_s3_assets as s3_assets } from 'aws-cdk-lib';\nimport { SpawnSyncOptions, spawnSync } from 'child_process';\nimport { makeUniqueId } from \"../util/uniqueid\";\n\nfunction flatten(x: string[][]) {\n    return Array.prototype.concat([], ...x);\n}\n\nfunction dockerExec(args: string[], options?: SpawnSyncOptions) {\n    const prog = process.env.CDK_DOCKER ?? 'docker';\n    const proc = spawnSync(prog, args, options);\n\n    if (proc.error) {\n        throw proc.error;\n    }\n\n    if (0 !== proc.status) {\n        if (proc.stdout || proc.stderr) {\n            throw new Error(`[Status ${proc.status}] stdout: ${proc.stdout?.toString().trim()}\\n\\n\\nstderr: ${proc.stderr?.toString().trim()}`);\n        }\n        throw new Error(`${prog} exited with status ${proc.status}`);\n    }\n\n    return proc;\n}\n\nexport abstract class Code extends lambda.Code {\n    static fromAsset(path: string, options?: s3_assets.AssetOptions): lambda.AssetCode {\n        const bundlingOptions: BundlingOptions | undefined = options?.bundling !== undefined ? {\n            local: {\n                tryBundle(outputDir: string, options: BundlingOptions): boolean {\n                    const dockerVolumes: {\n                        volume: DockerVolume,\n                        volumeName: string,\n                    }[] = [];\n\n                    let inputVolume: any;\n                    let outputVolume: any;\n\n                    // Always mount input and output dir\n                    const volumes = [\n                        {\n                            hostPath: path,\n                            containerPath: AssetStaging.BUNDLING_INPUT_DIR,\n                        },\n                        {\n                            hostPath: outputDir,\n                            containerPath: AssetStaging.BUNDLING_OUTPUT_DIR,\n                        },\n                        ...options.volumes ?? [],\n                    ];\n\n                    for (const v of volumes) {\n                        const volumeName = makeUniqueId([ v.hostPath ]);\n                        const volume = {\n                            volume: v,\n                            volumeName,\n                        };\n\n                        dockerVolumes.push(volume);\n                        if (v.containerPath === AssetStaging.BUNDLING_INPUT_DIR) {\n                            inputVolume = volume;\n                        } else if (v.containerPath === AssetStaging.BUNDLING_OUTPUT_DIR) {\n                            outputVolume = volume;\n                        }\n\n                        dockerExec([ 'volume', 'create', volumeName ]);\n                    }\n\n                    // Docker run -v asset-input:/asset-input -v asset-output:/asset-output --name helper busybox\n                    const helperName = 'helper' + ~~(Math.random() * 10000000);\n                    const helperContainerProc = dockerExec([\n                        'run', '-d',\n                        ...flatten(dockerVolumes.map(dv => [ '-v', dv.volumeName + ':' + dv.volume.containerPath ])),\n                        '--name', helperName,\n                        'busybox',\n                        'sleep', '180',\n                    ]);\n\n                    if (helperContainerProc.error) {\n                        throw helperContainerProc.error;\n                    }\n\n                    if (0 !== helperContainerProc.status) {\n                        throw new Error('Bundling helper exited with status: ' + helperContainerProc.status);\n                    }\n\n                    // Docker cp <asset source> helper:/asset-input\n                    dockerExec([ 'cp', inputVolume!.volume.hostPath + '/.', helperName + ':' + inputVolume!.volume.containerPath ]);\n\n                    // Docker run --rm -v asset-input:/asset-input -v asset-output/asset-output <user command>\n                    const environment = options.environment || {};\n                    const command = options.command || [];\n                    const dockerArgs = [\n                        'run', '--rm',\n                        ...options.user\n                            ? [ '-u', options.user ]\n                            : [],\n                        ...flatten(dockerVolumes.map(v => {\n                            return [ '-v', `${v.volumeName}:${v.volume.containerPath}` ];\n                        })),\n                        ...flatten(Object.entries(environment).map(([ k, v ]) => [ '--env', `${k}=${v}` ])),\n                        '-w', inputVolume!.volume.containerPath,\n                        options.image.toJSON(),\n                        ...command,\n                    ];\n\n                    dockerExec(dockerArgs);\n\n                    // Docker cp helper:/asset-output <staged bundling dir>\n                    dockerExec([ 'cp', helperName + ':' + outputVolume!.volume.containerPath + '/.', outputVolume!.volume.hostPath ]);\n\n                    // Docker rm helper\n                    dockerExec([ 'rm', '--force', helperName ]);\n\n                    // Docker rm helper\n                    dockerExec([ 'volume', 'rm', ...dockerVolumes.map(v => v.volumeName) ]);\n\n                    return true;\n                },\n            },\n            ...options.bundling,\n        } : undefined;\n\n        return lambda.Code.fromAsset(path, { ...(options ?? {}), bundling: bundlingOptions });\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["code.ts"],"names":[],"mappings":"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","sourcesContent":["import { AssetStaging, BundlingOptions, DockerVolume, aws_lambda as lambda, aws_s3_assets as s3_assets } from 'aws-cdk-lib';\nimport { SpawnSyncOptions, spawnSync } from 'child_process';\nimport { makeUniqueId } from '../util/uniqueid';\n\nfunction flatten(x: string[][]) {\n    return Array.prototype.concat([], ...x);\n}\n\nfunction dockerExec(args: string[], options?: SpawnSyncOptions) {\n    const prog = process.env.CDK_DOCKER ?? 'docker';\n    const proc = spawnSync(prog, args, options);\n\n    if (proc.error) {\n        throw proc.error;\n    }\n\n    if (0 !== proc.status) {\n        if (proc.stdout || proc.stderr) {\n            throw new Error(`[Status ${proc.status}] stdout: ${proc.stdout?.toString().trim()}\\n\\n\\nstderr: ${proc.stderr?.toString().trim()}`);\n        }\n        throw new Error(`${prog} exited with status ${proc.status}`);\n    }\n\n    return proc;\n}\n\nexport abstract class Code extends lambda.Code {\n    static fromAsset(path: string, options?: s3_assets.AssetOptions): lambda.AssetCode {\n        const bundlingOptions: BundlingOptions | undefined = options?.bundling !== undefined ? {\n            local: {\n                tryBundle(outputDir: string, options: BundlingOptions): boolean {\n                    const dockerVolumes: {\n                        volume: DockerVolume,\n                        volumeName: string,\n                    }[] = [];\n\n                    let inputVolume: any;\n                    let outputVolume: any;\n\n                    // Always mount input and output dir\n                    const volumes = [\n                        {\n                            hostPath: path,\n                            containerPath: AssetStaging.BUNDLING_INPUT_DIR,\n                        },\n                        {\n                            hostPath: outputDir,\n                            containerPath: AssetStaging.BUNDLING_OUTPUT_DIR,\n                        },\n                        ...options.volumes ?? [],\n                    ];\n\n                    for (const v of volumes) {\n                        const volumeName = makeUniqueId([ v.hostPath ]);\n                        const volume = {\n                            volume: v,\n                            volumeName,\n                        };\n\n                        dockerVolumes.push(volume);\n                        if (v.containerPath === AssetStaging.BUNDLING_INPUT_DIR) {\n                            inputVolume = volume;\n                        } else if (v.containerPath === AssetStaging.BUNDLING_OUTPUT_DIR) {\n                            outputVolume = volume;\n                        }\n\n                        dockerExec([ 'volume', 'create', volumeName ]);\n                    }\n\n                    // Docker run -v asset-input:/asset-input -v asset-output:/asset-output --name helper busybox\n                    const helperName = 'helper' + ~~(Math.random() * 10000000);\n                    const helperContainerProc = dockerExec([\n                        'run', '-d',\n                        ...flatten(dockerVolumes.map(dv => [ '-v', dv.volumeName + ':' + dv.volume.containerPath ])),\n                        '--name', helperName,\n                        'busybox',\n                        'sleep', '180',\n                    ]);\n\n                    if (helperContainerProc.error) {\n                        throw helperContainerProc.error;\n                    }\n\n                    if (0 !== helperContainerProc.status) {\n                        throw new Error('Bundling helper exited with status: ' + helperContainerProc.status);\n                    }\n\n                    // Docker cp <asset source> helper:/asset-input\n                    dockerExec([ 'cp', inputVolume!.volume.hostPath + '/.', helperName + ':' + inputVolume!.volume.containerPath ]);\n\n                    // Docker run --rm -v asset-input:/asset-input -v asset-output/asset-output <user command>\n                    const environment = options.environment || {};\n                    const command = options.command || [];\n                    const dockerArgs = [\n                        'run', '--rm',\n                        ...options.user\n                            ? [ '-u', options.user ]\n                            : [],\n                        ...flatten(dockerVolumes.map(v => {\n                            return [ '-v', `${v.volumeName}:${v.volume.containerPath}` ];\n                        })),\n                        ...flatten(Object.entries(environment).map(([ k, v ]) => [ '--env', `${k}=${v}` ])),\n                        '-w', inputVolume!.volume.containerPath,\n                        options.image.toJSON(),\n                        ...command,\n                    ];\n\n                    dockerExec(dockerArgs);\n\n                    // Docker cp helper:/asset-output <staged bundling dir>\n                    dockerExec([ 'cp', helperName + ':' + outputVolume!.volume.containerPath + '/.', outputVolume!.volume.hostPath ]);\n\n                    // Docker rm helper\n                    dockerExec([ 'rm', '--force', helperName ]);\n\n                    // Docker rm helper\n                    dockerExec([ 'volume', 'rm', ...dockerVolumes.map(v => v.volumeName) ]);\n\n                    return true;\n                },\n            },\n            ...options.bundling,\n        } : undefined;\n\n        return lambda.Code.fromAsset(path, { ...(options ?? {}), bundling: bundlingOptions });\n    }\n}\n"]} |
@@ -1,2 +0,2 @@ | ||
import { IResolvable, TokenizedStringFragments } from "aws-cdk-lib"; | ||
import { IResolvable, TokenizedStringFragments } from 'aws-cdk-lib'; | ||
export declare const BEGIN_STRING_TOKEN_MARKER = "${Token["; | ||
@@ -3,0 +3,0 @@ export declare const BEGIN_LIST_TOKEN_MARKER = "#{Token["; |
@@ -19,2 +19,3 @@ "use strict"; | ||
class TokenString { | ||
/* eslint-disable no-useless-constructor */ | ||
constructor(str, re) { | ||
@@ -36,2 +37,3 @@ this.str = str; | ||
} | ||
/* eslint-enable no-useless-constructor */ | ||
/** | ||
@@ -81,14 +83,12 @@ * Split string on markers, substituting markers with Tokens | ||
function unresolved(obj) { | ||
if (typeof (obj) === 'string') { | ||
if ('string' === typeof (obj)) { | ||
return TokenString.forString(obj).test(); | ||
} | ||
else if (typeof obj === 'number') { | ||
else if ('number' === typeof obj) { | ||
return extractTokenDouble(obj) !== undefined; | ||
} | ||
else if (Array.isArray(obj) && obj.length === 1) { | ||
return typeof (obj[0]) === 'string' && TokenString.forListToken(obj[0]).test(); | ||
else if (Array.isArray(obj) && 1 === obj.length) { | ||
return 'string' === typeof (obj[0]) && TokenString.forListToken(obj[0]).test(); | ||
} | ||
else { | ||
return aws_cdk_lib_1.isResolvableObject(obj); | ||
} | ||
return aws_cdk_lib_1.isResolvableObject(obj); | ||
} | ||
@@ -150,3 +150,3 @@ exports.unresolved = unresolved; | ||
// Must use + instead of | here (bitwise operations | ||
// will force 32-bits integer arithmetic, + will not). | ||
// Will force 32-bits integer arithmetic, + will not). | ||
return ints[0] + shl32(ints[1] & 0xFFFF); | ||
@@ -156,2 +156,2 @@ /* eslint-enable no-bitwise */ | ||
exports.extractTokenDouble = extractTokenDouble; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encoding.js","sourceRoot":"","sources":["encoding.ts"],"names":[],"mappings":"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","sourcesContent":["import { IResolvable, isResolvableObject, TokenizedStringFragments } from \"aws-cdk-lib\";\n\n// Details for encoding and decoding Tokens into native types; should not be exported\n\nexport const BEGIN_STRING_TOKEN_MARKER = '${Token[';\nexport const BEGIN_LIST_TOKEN_MARKER = '#{Token[';\nexport const END_TOKEN_MARKER = ']}';\n\nexport const VALID_KEY_CHARS = 'a-zA-Z0-9:._-';\n\nconst QUOTED_BEGIN_STRING_TOKEN_MARKER = regexQuote(BEGIN_STRING_TOKEN_MARKER);\nconst QUOTED_BEGIN_LIST_TOKEN_MARKER = regexQuote(BEGIN_LIST_TOKEN_MARKER);\nconst QUOTED_END_TOKEN_MARKER = regexQuote(END_TOKEN_MARKER);\n\nconst STRING_TOKEN_REGEX = new RegExp(`${QUOTED_BEGIN_STRING_TOKEN_MARKER}([${VALID_KEY_CHARS}]+)${QUOTED_END_TOKEN_MARKER}`, 'g');\nconst LIST_TOKEN_REGEX = new RegExp(`${QUOTED_BEGIN_LIST_TOKEN_MARKER}([${VALID_KEY_CHARS}]+)${QUOTED_END_TOKEN_MARKER}`, 'g');\n\n/**\n * A string with markers in it that can be resolved to external values\n */\nexport class TokenString {\n    /**\n     * Returns a `TokenString` for this string.\n     */\n    public static forString(s: string) {\n        return new TokenString(s, STRING_TOKEN_REGEX);\n    }\n\n    /**\n     * Returns a `TokenString` for this string (must be the first string element of the list)\n     */\n    public static forListToken(s: string) {\n        return new TokenString(s, LIST_TOKEN_REGEX);\n    }\n\n    constructor(private readonly str: string, private readonly re: RegExp) {\n    }\n\n    /**\n     * Split string on markers, substituting markers with Tokens\n     */\n    public split(lookup: (id: string) => IResolvable): TokenizedStringFragments {\n        const ret = new TokenizedStringFragments();\n\n        let rest = 0;\n        this.re.lastIndex = 0; // Reset\n        let m = this.re.exec(this.str);\n        while (m) {\n            if (m.index > rest) {\n                ret.addLiteral(this.str.substring(rest, m.index));\n            }\n\n            ret.addToken(lookup(m[1]));\n\n            rest = this.re.lastIndex;\n            m = this.re.exec(this.str);\n        }\n\n        if (rest < this.str.length) {\n            ret.addLiteral(this.str.substring(rest));\n        }\n\n        return ret;\n    }\n\n    /**\n     * Indicates if this string includes tokens.\n     */\n    public test(): boolean {\n        this.re.lastIndex = 0; // Reset\n        return this.re.test(this.str);\n    }\n}\n\n/**\n * Quote a string for use in a regex\n */\nexport function regexQuote(s: string) {\n    return s.replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&');\n}\n\n/**\n * Returns true if obj is a token (i.e. has the resolve() method or is a string\n * that includes token markers), or it's a listifictaion of a Token string.\n *\n * @param obj The object to test.\n */\nexport function unresolved(obj: any): boolean {\n    if (typeof(obj) === 'string') {\n        return TokenString.forString(obj).test();\n    } else if (typeof obj === 'number') {\n        return extractTokenDouble(obj) !== undefined;\n    } else if (Array.isArray(obj) && obj.length === 1) {\n        return typeof(obj[0]) === 'string' && TokenString.forListToken(obj[0]).test();\n    } else {\n        return isResolvableObject(obj);\n    }\n}\n\n/**\n * Bit pattern in the top 16 bits of a double to indicate a Token\n *\n * An IEEE double in LE memory order looks like this (grouped\n * into octets, then grouped into 32-bit words):\n *\n * mmmmmmmm.mmmmmmmm.mmmmmmmm.mmmmmmmm | mmmmmmmm.mmmmmmmm.EEEEmmmm.sEEEEEEE\n *\n * - m: mantissa (52 bits)\n * - E: exponent (11 bits)\n * - s: sign (1 bit)\n *\n * We put the following marker into the top 16 bits (exponent and sign), and\n * use the mantissa part to encode the token index. To save some bit twiddling\n * we use all top 16 bits for the tag. That loses us 4 mantissa bits to store\n * information in but we still have 48, which is going to be plenty for any\n * number of tokens to be created during the lifetime of any CDK application.\n *\n * Can't have all bits set because that makes a NaN, so unset the least\n * significant exponent bit.\n *\n * Currently not supporting BE architectures.\n */\n// eslint-disable-next-line no-bitwise\nconst DOUBLE_TOKEN_MARKER_BITS = 0xFBFF << 16;\n\n/**\n * Get 2^32 as a number, so we can do multiplication and div instead of bit shifting\n *\n * Necessary because in JavaScript, bit operations implicitly convert\n * to int32 and we need them to work on \"int64\"s.\n *\n * So instead of x >> 32, we do Math.floor(x / 2^32), and vice versa.\n */\nconst BITS32 = Math.pow(2, 32);\n\n/**\n * Shift a 64-bit left 32 bits\n */\nfunction shl32(x: number) {\n    return x * BITS32;\n}\n\n/**\n * Extract the encoded integer out of the special Double value\n *\n * Returns undefined if the float is a not an encoded token.\n */\nexport function extractTokenDouble(encoded: number): number | undefined {\n    const buf = new ArrayBuffer(8);\n    (new Float64Array(buf))[0] = encoded;\n\n    const ints = new Uint32Array(buf);\n\n    /* eslint-disable no-bitwise */\n    if ((ints[1] & 0xFFFF0000) !== DOUBLE_TOKEN_MARKER_BITS) {\n        return undefined;\n    }\n\n    // Must use + instead of | here (bitwise operations\n    // will force 32-bits integer arithmetic, + will not).\n    return ints[0] + shl32(ints[1] & 0xFFFF);\n    /* eslint-enable no-bitwise */\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encoding.js","sourceRoot":"","sources":["encoding.ts"],"names":[],"mappings":"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","sourcesContent":["import { IResolvable, TokenizedStringFragments, isResolvableObject } from 'aws-cdk-lib';\n\n// Details for encoding and decoding Tokens into native types; should not be exported\n\nexport const BEGIN_STRING_TOKEN_MARKER = '${Token[';\nexport const BEGIN_LIST_TOKEN_MARKER = '#{Token[';\nexport const END_TOKEN_MARKER = ']}';\n\nexport const VALID_KEY_CHARS = 'a-zA-Z0-9:._-';\n\nconst QUOTED_BEGIN_STRING_TOKEN_MARKER = regexQuote(BEGIN_STRING_TOKEN_MARKER);\nconst QUOTED_BEGIN_LIST_TOKEN_MARKER = regexQuote(BEGIN_LIST_TOKEN_MARKER);\nconst QUOTED_END_TOKEN_MARKER = regexQuote(END_TOKEN_MARKER);\n\nconst STRING_TOKEN_REGEX = new RegExp(`${QUOTED_BEGIN_STRING_TOKEN_MARKER}([${VALID_KEY_CHARS}]+)${QUOTED_END_TOKEN_MARKER}`, 'g');\nconst LIST_TOKEN_REGEX = new RegExp(`${QUOTED_BEGIN_LIST_TOKEN_MARKER}([${VALID_KEY_CHARS}]+)${QUOTED_END_TOKEN_MARKER}`, 'g');\n\n/**\n * A string with markers in it that can be resolved to external values\n */\nexport class TokenString {\n    /**\n     * Returns a `TokenString` for this string.\n     */\n    public static forString(s: string) {\n        return new TokenString(s, STRING_TOKEN_REGEX);\n    }\n\n    /**\n     * Returns a `TokenString` for this string (must be the first string element of the list)\n     */\n    public static forListToken(s: string) {\n        return new TokenString(s, LIST_TOKEN_REGEX);\n    }\n\n    /* eslint-disable no-useless-constructor */\n    constructor(private readonly str: string, private readonly re: RegExp) {\n    }\n    /* eslint-enable no-useless-constructor */\n\n    /**\n     * Split string on markers, substituting markers with Tokens\n     */\n    public split(lookup: (id: string) => IResolvable): TokenizedStringFragments {\n        const ret = new TokenizedStringFragments();\n\n        let rest = 0;\n        this.re.lastIndex = 0; // Reset\n        let m = this.re.exec(this.str);\n        while (m) {\n            if (m.index > rest) {\n                ret.addLiteral(this.str.substring(rest, m.index));\n            }\n\n            ret.addToken(lookup(m[1]));\n\n            rest = this.re.lastIndex;\n            m = this.re.exec(this.str);\n        }\n\n        if (rest < this.str.length) {\n            ret.addLiteral(this.str.substring(rest));\n        }\n\n        return ret;\n    }\n\n    /**\n     * Indicates if this string includes tokens.\n     */\n    public test(): boolean {\n        this.re.lastIndex = 0; // Reset\n        return this.re.test(this.str);\n    }\n}\n\n/**\n * Quote a string for use in a regex\n */\nexport function regexQuote(s: string) {\n    return s.replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&');\n}\n\n/**\n * Returns true if obj is a token (i.e. has the resolve() method or is a string\n * that includes token markers), or it's a listifictaion of a Token string.\n *\n * @param obj The object to test.\n */\nexport function unresolved(obj: any): boolean {\n    if ('string' === typeof(obj)) {\n        return TokenString.forString(obj).test();\n    } else if ('number' === typeof obj) {\n        return extractTokenDouble(obj) !== undefined;\n    } else if (Array.isArray(obj) && 1 === obj.length) {\n        return 'string' === typeof(obj[0]) && TokenString.forListToken(obj[0]).test();\n    }\n    return isResolvableObject(obj);\n\n}\n\n/**\n * Bit pattern in the top 16 bits of a double to indicate a Token\n *\n * An IEEE double in LE memory order looks like this (grouped\n * into octets, then grouped into 32-bit words):\n *\n * mmmmmmmm.mmmmmmmm.mmmmmmmm.mmmmmmmm | mmmmmmmm.mmmmmmmm.EEEEmmmm.sEEEEEEE\n *\n * - m: mantissa (52 bits)\n * - E: exponent (11 bits)\n * - s: sign (1 bit)\n *\n * We put the following marker into the top 16 bits (exponent and sign), and\n * use the mantissa part to encode the token index. To save some bit twiddling\n * we use all top 16 bits for the tag. That loses us 4 mantissa bits to store\n * information in but we still have 48, which is going to be plenty for any\n * number of tokens to be created during the lifetime of any CDK application.\n *\n * Can't have all bits set because that makes a NaN, so unset the least\n * significant exponent bit.\n *\n * Currently not supporting BE architectures.\n */\n// eslint-disable-next-line no-bitwise\nconst DOUBLE_TOKEN_MARKER_BITS = 0xFBFF << 16;\n\n/**\n * Get 2^32 as a number, so we can do multiplication and div instead of bit shifting\n *\n * Necessary because in JavaScript, bit operations implicitly convert\n * to int32 and we need them to work on \"int64\"s.\n *\n * So instead of x >> 32, we do Math.floor(x / 2^32), and vice versa.\n */\nconst BITS32 = Math.pow(2, 32);\n\n/**\n * Shift a 64-bit left 32 bits\n */\nfunction shl32(x: number) {\n    return x * BITS32;\n}\n\n/**\n * Extract the encoded integer out of the special Double value\n *\n * Returns undefined if the float is a not an encoded token.\n */\nexport function extractTokenDouble(encoded: number): number | undefined {\n    const buf = new ArrayBuffer(8);\n    (new Float64Array(buf))[0] = encoded;\n\n    const ints = new Uint32Array(buf);\n\n    /* eslint-disable no-bitwise */\n    if ((ints[1] & 0xFFFF0000) !== DOUBLE_TOKEN_MARKER_BITS) {\n        return undefined;\n    }\n\n    // Must use + instead of | here (bitwise operations\n    // Will force 32-bits integer arithmetic, + will not).\n    return ints[0] + shl32(ints[1] & 0xFFFF);\n    /* eslint-enable no-bitwise */\n}\n"]} |
@@ -19,3 +19,3 @@ "use strict"; | ||
const HASH_LEN = 8; | ||
const MAX_HUMAN_LEN = 240; // max ID len is 255 | ||
const MAX_HUMAN_LEN = 240; // Max ID len is 255 | ||
const MAX_ID_LEN = 255; | ||
@@ -33,3 +33,3 @@ /** | ||
components = components.filter(x => x !== HIDDEN_ID); | ||
if (components.length === 0) { | ||
if (0 === components.length) { | ||
throw new Error('Unable to calculate a unique id for an empty set of components'); | ||
@@ -39,17 +39,17 @@ } | ||
const unresolvedTokens = components.filter(c => encoding_1.unresolved(c)); | ||
if (unresolvedTokens.length > 0) { | ||
if (0 < unresolvedTokens.length) { | ||
throw new Error(`ID components may not include unresolved tokens: ${unresolvedTokens.join(',')}`); | ||
} | ||
// top-level resources will simply use the `name` as-is in order to support | ||
// transparent migration of cloudformation templates to the CDK without the | ||
// need to rename all resources. | ||
if (components.length === 1) { | ||
// we filter out non-alpha characters but that is actually a bad idea | ||
// because it could create conflicts ("A-B" and "AB" will render the same | ||
// logical ID). sadly, changing it in the 1.x version line is impossible | ||
// because it will be a breaking change. we should consider for v2.0. | ||
// Top-level resources will simply use the `name` as-is in order to support | ||
// Transparent migration of cloudformation templates to the CDK without the | ||
// Need to rename all resources. | ||
if (1 === components.length) { | ||
// We filter out non-alpha characters but that is actually a bad idea | ||
// Because it could create conflicts ("A-B" and "AB" will render the same | ||
// Logical ID). sadly, changing it in the 1.x version line is impossible | ||
// Because it will be a breaking change. we should consider for v2.0. | ||
// https://github.com/aws/aws-cdk/issues/6421 | ||
const candidate = removeNonAlphanumeric(components[0]); | ||
// if our candidate is short enough, use it as is. otherwise, fall back to | ||
// the normal mode. | ||
// If our candidate is short enough, use it as is. otherwise, fall back to | ||
// The normal mode. | ||
if (candidate.length <= MAX_ID_LEN) { | ||
@@ -92,3 +92,3 @@ return candidate; | ||
for (const component of path) { | ||
if (ret.length === 0 || !ret[ret.length - 1].endsWith(component)) { | ||
if (0 === ret.length || !ret[ret.length - 1].endsWith(component)) { | ||
ret.push(component); | ||
@@ -99,2 +99,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pcXVlaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bmlxdWVpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBaUM7QUFDakMseUNBQXdDO0FBRXhDOzs7OztHQUtHO0FBQ0gsTUFBTSxvQkFBb0IsR0FBRyxVQUFVLENBQUM7QUFFeEM7O0dBRUc7QUFDSCxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUM7QUFFNUIsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDO0FBRXJCLE1BQU0sUUFBUSxHQUFHLENBQUMsQ0FBQztBQUNuQixNQUFNLGFBQWEsR0FBRyxHQUFHLENBQUMsQ0FBQyxvQkFBb0I7QUFDL0MsTUFBTSxVQUFVLEdBQUcsR0FBRyxDQUFDO0FBRXZCOzs7Ozs7OztHQVFHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLFVBQW9CO0lBQzdDLFVBQVUsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxDQUFDO0lBRXJELElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQyxnRUFBZ0UsQ0FBQyxDQUFDO0tBQ3JGO0lBRUQsMkRBQTJEO0lBQzNELE1BQU0sZ0JBQWdCLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMvRCxJQUFJLGdCQUFnQixDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxvREFBb0QsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUNyRztJQUVELDJFQUEyRTtJQUMzRSwyRUFBMkU7SUFDM0UsZ0NBQWdDO0lBQ2hDLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDekIscUVBQXFFO1FBQ3JFLHlFQUF5RTtRQUN6RSx3RUFBd0U7UUFDeEUscUVBQXFFO1FBQ3JFLDZDQUE2QztRQUM3QyxNQUFNLFNBQVMsR0FBRyxxQkFBcUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUV2RCwwRUFBMEU7UUFDMUUsbUJBQW1CO1FBQ25CLElBQUksU0FBUyxDQUFDLE1BQU0sSUFBSSxVQUFVLEVBQUU7WUFDaEMsT0FBTyxTQUFTLENBQUM7U0FDcEI7S0FDSjtJQUVELE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNsQyxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDO1NBQ2hDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxvQkFBb0IsQ0FBQztTQUN2QyxHQUFHLENBQUMscUJBQXFCLENBQUM7U0FDMUIsSUFBSSxDQUFDLEVBQUUsQ0FBQztTQUNSLEtBQUssQ0FBQyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFN0IsT0FBTyxLQUFLLEdBQUcsSUFBSSxDQUFDO0FBQ3hCLENBQUM7QUF2Q0Qsb0NBdUNDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQVMsUUFBUSxDQUFDLElBQWM7SUFDNUIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvRSxPQUFPLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQ2hELENBQUM7QUFFRDs7R0FFRztBQUNILFNBQVMscUJBQXFCLENBQUMsQ0FBUztJQUNwQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQzFDLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQVMsV0FBVyxDQUFDLElBQWM7SUFDL0IsTUFBTSxHQUFHLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQUVoQyxLQUFLLE1BQU0sU0FBUyxJQUFJLElBQUksRUFBRTtRQUMxQixJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzlELEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDdkI7S0FDSjtJQUVELE9BQU8sR0FBRyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNyeXB0byBmcm9tICdjcnlwdG8nO1xuaW1wb3J0IHsgdW5yZXNvbHZlZCB9IGZyb20gXCIuL2VuY29kaW5nXCI7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgaGlkZGVuIGZyb20gaHVtYW5zXG4gKlxuICogVGhleSBkbyBub3QgYXBwZWFyIGluIHRoZSBodW1hbi1yZWFkYWJsZSBwYXJ0IG9mIHRoZSBsb2dpY2FsIElELFxuICogYnV0IHRoZXkgYXJlIGluY2x1ZGVkIGluIHRoZSBoYXNoIGNhbGN1bGF0aW9uLlxuICovXG5jb25zdCBISURERU5fRlJPTV9IVU1BTl9JRCA9ICdSZXNvdXJjZSc7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgY29tcGxldGUgaGlkZGVuIGZyb20gdGhlIGxvZ2ljYWwgSUQgY2FsY3VsYXRpb24uXG4gKi9cbmNvbnN0IEhJRERFTl9JRCA9ICdEZWZhdWx0JztcblxuY29uc3QgUEFUSF9TRVAgPSAnLyc7XG5cbmNvbnN0IEhBU0hfTEVOID0gODtcbmNvbnN0IE1BWF9IVU1BTl9MRU4gPSAyNDA7IC8vIG1heCBJRCBsZW4gaXMgMjU1XG5jb25zdCBNQVhfSURfTEVOID0gMjU1O1xuXG4vKipcbiAqIENhbGN1bGF0ZXMgYSB1bmlxdWUgSUQgZm9yIGEgc2V0IG9mIHRleHR1YWwgY29tcG9uZW50cy5cbiAqXG4gKiBUaGlzIGlzIGRvbmUgYnkgY2FsY3VsYXRpbmcgYSBoYXNoIG9uIHRoZSBmdWxsIHBhdGggYW5kIHVzaW5nIGl0IGFzIGEgc3VmZml4XG4gKiBvZiBhIGxlbmd0aC1saW1pdGVkIFwiaHVtYW5cIiByZW5kaXRpb24gb2YgdGhlIHBhdGggY29tcG9uZW50cy5cbiAqXG4gKiBAcGFyYW0gY29tcG9uZW50cyBUaGUgcGF0aCBjb21wb25lbnRzXG4gKiBAcmV0dXJucyBhIHVuaXF1ZSBhbHBoYS1udW1lcmljIGlkZW50aWZpZXIgd2l0aCBhIG1heGltdW0gbGVuZ3RoIG9mIDI1NVxuICovXG5leHBvcnQgZnVuY3Rpb24gbWFrZVVuaXF1ZUlkKGNvbXBvbmVudHM6IHN0cmluZ1tdKSB7XG4gICAgY29tcG9uZW50cyA9IGNvbXBvbmVudHMuZmlsdGVyKHggPT4geCAhPT0gSElEREVOX0lEKTtcblxuICAgIGlmIChjb21wb25lbnRzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuYWJsZSB0byBjYWxjdWxhdGUgYSB1bmlxdWUgaWQgZm9yIGFuIGVtcHR5IHNldCBvZiBjb21wb25lbnRzJyk7XG4gICAgfVxuXG4gICAgLy8gTGF6eSByZXF1aXJlIGluIG9yZGVyIHRvIGJyZWFrIGEgbW9kdWxlIGRlcGVuZGVuY3kgY3ljbGVcbiAgICBjb25zdCB1bnJlc29sdmVkVG9rZW5zID0gY29tcG9uZW50cy5maWx0ZXIoYyA9PiB1bnJlc29sdmVkKGMpKTtcbiAgICBpZiAodW5yZXNvbHZlZFRva2Vucy5sZW5ndGggPiAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgSUQgY29tcG9uZW50cyBtYXkgbm90IGluY2x1ZGUgdW5yZXNvbHZlZCB0b2tlbnM6ICR7dW5yZXNvbHZlZFRva2Vucy5qb2luKCcsJyl9YCk7XG4gICAgfVxuXG4gICAgLy8gdG9wLWxldmVsIHJlc291cmNlcyB3aWxsIHNpbXBseSB1c2UgdGhlIGBuYW1lYCBhcy1pcyBpbiBvcmRlciB0byBzdXBwb3J0XG4gICAgLy8gdHJhbnNwYXJlbnQgbWlncmF0aW9uIG9mIGNsb3VkZm9ybWF0aW9uIHRlbXBsYXRlcyB0byB0aGUgQ0RLIHdpdGhvdXQgdGhlXG4gICAgLy8gbmVlZCB0byByZW5hbWUgYWxsIHJlc291cmNlcy5cbiAgICBpZiAoY29tcG9uZW50cy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgLy8gd2UgZmlsdGVyIG91dCBub24tYWxwaGEgY2hhcmFjdGVycyBidXQgdGhhdCBpcyBhY3R1YWxseSBhIGJhZCBpZGVhXG4gICAgICAgIC8vIGJlY2F1c2UgaXQgY291bGQgY3JlYXRlIGNvbmZsaWN0cyAoXCJBLUJcIiBhbmQgXCJBQlwiIHdpbGwgcmVuZGVyIHRoZSBzYW1lXG4gICAgICAgIC8vIGxvZ2ljYWwgSUQpLiBzYWRseSwgY2hhbmdpbmcgaXQgaW4gdGhlIDEueCB2ZXJzaW9uIGxpbmUgaXMgaW1wb3NzaWJsZVxuICAgICAgICAvLyBiZWNhdXNlIGl0IHdpbGwgYmUgYSBicmVha2luZyBjaGFuZ2UuIHdlIHNob3VsZCBjb25zaWRlciBmb3IgdjIuMC5cbiAgICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2F3cy9hd3MtY2RrL2lzc3Vlcy82NDIxXG4gICAgICAgIGNvbnN0IGNhbmRpZGF0ZSA9IHJlbW92ZU5vbkFscGhhbnVtZXJpYyhjb21wb25lbnRzWzBdKTtcblxuICAgICAgICAvLyBpZiBvdXIgY2FuZGlkYXRlIGlzIHNob3J0IGVub3VnaCwgdXNlIGl0IGFzIGlzLiBvdGhlcndpc2UsIGZhbGwgYmFjayB0b1xuICAgICAgICAvLyB0aGUgbm9ybWFsIG1vZGUuXG4gICAgICAgIGlmIChjYW5kaWRhdGUubGVuZ3RoIDw9IE1BWF9JRF9MRU4pIHtcbiAgICAgICAgICAgIHJldHVybiBjYW5kaWRhdGU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCBoYXNoID0gcGF0aEhhc2goY29tcG9uZW50cyk7XG4gICAgY29uc3QgaHVtYW4gPSByZW1vdmVEdXBlcyhjb21wb25lbnRzKVxuICAgICAgICAuZmlsdGVyKHggPT4geCAhPT0gSElEREVOX0ZST01fSFVNQU5fSUQpXG4gICAgICAgIC5tYXAocmVtb3ZlTm9uQWxwaGFudW1lcmljKVxuICAgICAgICAuam9pbignJylcbiAgICAgICAgLnNsaWNlKDAsIE1BWF9IVU1BTl9MRU4pO1xuXG4gICAgcmV0dXJuIGh1bWFuICsgaGFzaDtcbn1cblxuLyoqXG4gKiBUYWtlIGEgaGFzaCBvZiB0aGUgZ2l2ZW4gcGF0aC5cbiAqXG4gKiBUaGUgaGFzaCBpcyBsaW1pdGVkIGluIHNpemUuXG4gKi9cbmZ1bmN0aW9uIHBhdGhIYXNoKHBhdGg6IHN0cmluZ1tdKTogc3RyaW5nIHtcbiAgICBjb25zdCBtZDUgPSBjcnlwdG8uY3JlYXRlSGFzaCgnbWQ1JykudXBkYXRlKHBhdGguam9pbihQQVRIX1NFUCkpLmRpZ2VzdCgnaGV4Jyk7XG4gICAgcmV0dXJuIG1kNS5zbGljZSgwLCBIQVNIX0xFTikudG9VcHBlckNhc2UoKTtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIGFsbCBub24tYWxwaGFudW1lcmljIGNoYXJhY3RlcnMgaW4gYSBzdHJpbmcuXG4gKi9cbmZ1bmN0aW9uIHJlbW92ZU5vbkFscGhhbnVtZXJpYyhzOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gcy5yZXBsYWNlKC9bXkEtWmEtejAtOV0vZywgJycpO1xufVxuXG4vKipcbiAqIFJlbW92ZSBkdXBsaWNhdGUgXCJ0ZXJtc1wiIGZyb20gdGhlIHBhdGggbGlzdFxuICpcbiAqIElmIHRoZSBwcmV2aW91cyBwYXRoIGNvbXBvbmVudCBuYW1lIGVuZHMgd2l0aCB0aGlzIGNvbXBvbmVudCBuYW1lLCBza2lwIHRoZVxuICogY3VycmVudCBjb21wb25lbnQuXG4gKi9cbmZ1bmN0aW9uIHJlbW92ZUR1cGVzKHBhdGg6IHN0cmluZ1tdKTogc3RyaW5nW10ge1xuICAgIGNvbnN0IHJldCA9IG5ldyBBcnJheTxzdHJpbmc+KCk7XG5cbiAgICBmb3IgKGNvbnN0IGNvbXBvbmVudCBvZiBwYXRoKSB7XG4gICAgICAgIGlmIChyZXQubGVuZ3RoID09PSAwIHx8ICFyZXRbcmV0Lmxlbmd0aCAtIDFdLmVuZHNXaXRoKGNvbXBvbmVudCkpIHtcbiAgICAgICAgICAgIHJldC5wdXNoKGNvbXBvbmVudCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gcmV0O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pcXVlaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bmlxdWVpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBaUM7QUFDakMseUNBQXdDO0FBRXhDOzs7OztHQUtHO0FBQ0gsTUFBTSxvQkFBb0IsR0FBRyxVQUFVLENBQUM7QUFFeEM7O0dBRUc7QUFDSCxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUM7QUFFNUIsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDO0FBRXJCLE1BQU0sUUFBUSxHQUFHLENBQUMsQ0FBQztBQUNuQixNQUFNLGFBQWEsR0FBRyxHQUFHLENBQUMsQ0FBQyxvQkFBb0I7QUFDL0MsTUFBTSxVQUFVLEdBQUcsR0FBRyxDQUFDO0FBRXZCOzs7Ozs7OztHQVFHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLFVBQW9CO0lBQzdDLFVBQVUsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxDQUFDO0lBRXJELElBQUksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxNQUFNLEVBQUU7UUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQyxnRUFBZ0UsQ0FBQyxDQUFDO0tBQ3JGO0lBRUQsMkRBQTJEO0lBQzNELE1BQU0sZ0JBQWdCLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMvRCxJQUFJLENBQUMsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUU7UUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxvREFBb0QsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUNyRztJQUVELDJFQUEyRTtJQUMzRSwyRUFBMkU7SUFDM0UsZ0NBQWdDO0lBQ2hDLElBQUksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxNQUFNLEVBQUU7UUFDekIscUVBQXFFO1FBQ3JFLHlFQUF5RTtRQUN6RSx3RUFBd0U7UUFDeEUscUVBQXFFO1FBQ3JFLDZDQUE2QztRQUM3QyxNQUFNLFNBQVMsR0FBRyxxQkFBcUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUV2RCwwRUFBMEU7UUFDMUUsbUJBQW1CO1FBQ25CLElBQUksU0FBUyxDQUFDLE1BQU0sSUFBSSxVQUFVLEVBQUU7WUFDaEMsT0FBTyxTQUFTLENBQUM7U0FDcEI7S0FDSjtJQUVELE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNsQyxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDO1NBQ2hDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxvQkFBb0IsQ0FBQztTQUN2QyxHQUFHLENBQUMscUJBQXFCLENBQUM7U0FDMUIsSUFBSSxDQUFDLEVBQUUsQ0FBQztTQUNSLEtBQUssQ0FBQyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFN0IsT0FBTyxLQUFLLEdBQUcsSUFBSSxDQUFDO0FBQ3hCLENBQUM7QUF2Q0Qsb0NBdUNDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQVMsUUFBUSxDQUFDLElBQWM7SUFDNUIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvRSxPQUFPLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQ2hELENBQUM7QUFFRDs7R0FFRztBQUNILFNBQVMscUJBQXFCLENBQUMsQ0FBUztJQUNwQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQzFDLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQVMsV0FBVyxDQUFDLElBQWM7SUFDL0IsTUFBTSxHQUFHLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQUVoQyxLQUFLLE1BQU0sU0FBUyxJQUFJLElBQUksRUFBRTtRQUMxQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzlELEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDdkI7S0FDSjtJQUVELE9BQU8sR0FBRyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNyeXB0byBmcm9tICdjcnlwdG8nO1xuaW1wb3J0IHsgdW5yZXNvbHZlZCB9IGZyb20gJy4vZW5jb2RpbmcnO1xuXG4vKipcbiAqIFJlc291cmNlcyB3aXRoIHRoaXMgSUQgYXJlIGhpZGRlbiBmcm9tIGh1bWFuc1xuICpcbiAqIFRoZXkgZG8gbm90IGFwcGVhciBpbiB0aGUgaHVtYW4tcmVhZGFibGUgcGFydCBvZiB0aGUgbG9naWNhbCBJRCxcbiAqIGJ1dCB0aGV5IGFyZSBpbmNsdWRlZCBpbiB0aGUgaGFzaCBjYWxjdWxhdGlvbi5cbiAqL1xuY29uc3QgSElEREVOX0ZST01fSFVNQU5fSUQgPSAnUmVzb3VyY2UnO1xuXG4vKipcbiAqIFJlc291cmNlcyB3aXRoIHRoaXMgSUQgYXJlIGNvbXBsZXRlIGhpZGRlbiBmcm9tIHRoZSBsb2dpY2FsIElEIGNhbGN1bGF0aW9uLlxuICovXG5jb25zdCBISURERU5fSUQgPSAnRGVmYXVsdCc7XG5cbmNvbnN0IFBBVEhfU0VQID0gJy8nO1xuXG5jb25zdCBIQVNIX0xFTiA9IDg7XG5jb25zdCBNQVhfSFVNQU5fTEVOID0gMjQwOyAvLyBNYXggSUQgbGVuIGlzIDI1NVxuY29uc3QgTUFYX0lEX0xFTiA9IDI1NTtcblxuLyoqXG4gKiBDYWxjdWxhdGVzIGEgdW5pcXVlIElEIGZvciBhIHNldCBvZiB0ZXh0dWFsIGNvbXBvbmVudHMuXG4gKlxuICogVGhpcyBpcyBkb25lIGJ5IGNhbGN1bGF0aW5nIGEgaGFzaCBvbiB0aGUgZnVsbCBwYXRoIGFuZCB1c2luZyBpdCBhcyBhIHN1ZmZpeFxuICogb2YgYSBsZW5ndGgtbGltaXRlZCBcImh1bWFuXCIgcmVuZGl0aW9uIG9mIHRoZSBwYXRoIGNvbXBvbmVudHMuXG4gKlxuICogQHBhcmFtIGNvbXBvbmVudHMgVGhlIHBhdGggY29tcG9uZW50c1xuICogQHJldHVybnMgYSB1bmlxdWUgYWxwaGEtbnVtZXJpYyBpZGVudGlmaWVyIHdpdGggYSBtYXhpbXVtIGxlbmd0aCBvZiAyNTVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1ha2VVbmlxdWVJZChjb21wb25lbnRzOiBzdHJpbmdbXSkge1xuICAgIGNvbXBvbmVudHMgPSBjb21wb25lbnRzLmZpbHRlcih4ID0+IHggIT09IEhJRERFTl9JRCk7XG5cbiAgICBpZiAoMCA9PT0gY29tcG9uZW50cy5sZW5ndGgpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gY2FsY3VsYXRlIGEgdW5pcXVlIGlkIGZvciBhbiBlbXB0eSBzZXQgb2YgY29tcG9uZW50cycpO1xuICAgIH1cblxuICAgIC8vIExhenkgcmVxdWlyZSBpbiBvcmRlciB0byBicmVhayBhIG1vZHVsZSBkZXBlbmRlbmN5IGN5Y2xlXG4gICAgY29uc3QgdW5yZXNvbHZlZFRva2VucyA9IGNvbXBvbmVudHMuZmlsdGVyKGMgPT4gdW5yZXNvbHZlZChjKSk7XG4gICAgaWYgKDAgPCB1bnJlc29sdmVkVG9rZW5zLmxlbmd0aCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYElEIGNvbXBvbmVudHMgbWF5IG5vdCBpbmNsdWRlIHVucmVzb2x2ZWQgdG9rZW5zOiAke3VucmVzb2x2ZWRUb2tlbnMuam9pbignLCcpfWApO1xuICAgIH1cblxuICAgIC8vIFRvcC1sZXZlbCByZXNvdXJjZXMgd2lsbCBzaW1wbHkgdXNlIHRoZSBgbmFtZWAgYXMtaXMgaW4gb3JkZXIgdG8gc3VwcG9ydFxuICAgIC8vIFRyYW5zcGFyZW50IG1pZ3JhdGlvbiBvZiBjbG91ZGZvcm1hdGlvbiB0ZW1wbGF0ZXMgdG8gdGhlIENESyB3aXRob3V0IHRoZVxuICAgIC8vIE5lZWQgdG8gcmVuYW1lIGFsbCByZXNvdXJjZXMuXG4gICAgaWYgKDEgPT09IGNvbXBvbmVudHMubGVuZ3RoKSB7XG4gICAgICAgIC8vIFdlIGZpbHRlciBvdXQgbm9uLWFscGhhIGNoYXJhY3RlcnMgYnV0IHRoYXQgaXMgYWN0dWFsbHkgYSBiYWQgaWRlYVxuICAgICAgICAvLyBCZWNhdXNlIGl0IGNvdWxkIGNyZWF0ZSBjb25mbGljdHMgKFwiQS1CXCIgYW5kIFwiQUJcIiB3aWxsIHJlbmRlciB0aGUgc2FtZVxuICAgICAgICAvLyBMb2dpY2FsIElEKS4gc2FkbHksIGNoYW5naW5nIGl0IGluIHRoZSAxLnggdmVyc2lvbiBsaW5lIGlzIGltcG9zc2libGVcbiAgICAgICAgLy8gQmVjYXVzZSBpdCB3aWxsIGJlIGEgYnJlYWtpbmcgY2hhbmdlLiB3ZSBzaG91bGQgY29uc2lkZXIgZm9yIHYyLjAuXG4gICAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hd3MvYXdzLWNkay9pc3N1ZXMvNjQyMVxuICAgICAgICBjb25zdCBjYW5kaWRhdGUgPSByZW1vdmVOb25BbHBoYW51bWVyaWMoY29tcG9uZW50c1swXSk7XG5cbiAgICAgICAgLy8gSWYgb3VyIGNhbmRpZGF0ZSBpcyBzaG9ydCBlbm91Z2gsIHVzZSBpdCBhcyBpcy4gb3RoZXJ3aXNlLCBmYWxsIGJhY2sgdG9cbiAgICAgICAgLy8gVGhlIG5vcm1hbCBtb2RlLlxuICAgICAgICBpZiAoY2FuZGlkYXRlLmxlbmd0aCA8PSBNQVhfSURfTEVOKSB7XG4gICAgICAgICAgICByZXR1cm4gY2FuZGlkYXRlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgaGFzaCA9IHBhdGhIYXNoKGNvbXBvbmVudHMpO1xuICAgIGNvbnN0IGh1bWFuID0gcmVtb3ZlRHVwZXMoY29tcG9uZW50cylcbiAgICAgICAgLmZpbHRlcih4ID0+IHggIT09IEhJRERFTl9GUk9NX0hVTUFOX0lEKVxuICAgICAgICAubWFwKHJlbW92ZU5vbkFscGhhbnVtZXJpYylcbiAgICAgICAgLmpvaW4oJycpXG4gICAgICAgIC5zbGljZSgwLCBNQVhfSFVNQU5fTEVOKTtcblxuICAgIHJldHVybiBodW1hbiArIGhhc2g7XG59XG5cbi8qKlxuICogVGFrZSBhIGhhc2ggb2YgdGhlIGdpdmVuIHBhdGguXG4gKlxuICogVGhlIGhhc2ggaXMgbGltaXRlZCBpbiBzaXplLlxuICovXG5mdW5jdGlvbiBwYXRoSGFzaChwYXRoOiBzdHJpbmdbXSk6IHN0cmluZyB7XG4gICAgY29uc3QgbWQ1ID0gY3J5cHRvLmNyZWF0ZUhhc2goJ21kNScpLnVwZGF0ZShwYXRoLmpvaW4oUEFUSF9TRVApKS5kaWdlc3QoJ2hleCcpO1xuICAgIHJldHVybiBtZDUuc2xpY2UoMCwgSEFTSF9MRU4pLnRvVXBwZXJDYXNlKCk7XG59XG5cbi8qKlxuICogUmVtb3ZlcyBhbGwgbm9uLWFscGhhbnVtZXJpYyBjaGFyYWN0ZXJzIGluIGEgc3RyaW5nLlxuICovXG5mdW5jdGlvbiByZW1vdmVOb25BbHBoYW51bWVyaWMoczogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHMucmVwbGFjZSgvW15BLVphLXowLTldL2csICcnKTtcbn1cblxuLyoqXG4gKiBSZW1vdmUgZHVwbGljYXRlIFwidGVybXNcIiBmcm9tIHRoZSBwYXRoIGxpc3RcbiAqXG4gKiBJZiB0aGUgcHJldmlvdXMgcGF0aCBjb21wb25lbnQgbmFtZSBlbmRzIHdpdGggdGhpcyBjb21wb25lbnQgbmFtZSwgc2tpcCB0aGVcbiAqIGN1cnJlbnQgY29tcG9uZW50LlxuICovXG5mdW5jdGlvbiByZW1vdmVEdXBlcyhwYXRoOiBzdHJpbmdbXSk6IHN0cmluZ1tdIHtcbiAgICBjb25zdCByZXQgPSBuZXcgQXJyYXk8c3RyaW5nPigpO1xuXG4gICAgZm9yIChjb25zdCBjb21wb25lbnQgb2YgcGF0aCkge1xuICAgICAgICBpZiAoMCA9PT0gcmV0Lmxlbmd0aCB8fCAhcmV0W3JldC5sZW5ndGggLSAxXS5lbmRzV2l0aChjb21wb25lbnQpKSB7XG4gICAgICAgICAgICByZXQucHVzaChjb21wb25lbnQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHJldDtcbn1cbiJdfQ== |
{ | ||
"name": "@alekitto/cdk-constructs", | ||
"version": "0.1.8-beta.3", | ||
"version": "0.1.8", | ||
"description": "AWS CDK constructs", | ||
@@ -5,0 +5,0 @@ "main": "lib/index.js", |
1013794