@cloudsnorkel/cdk-github-runners 0.12.3 → 0.12.5

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/lib/access.js CHANGED
@@ -59,7 +59,7 @@ class LambdaAccess {
59
59
  }
60
60
  exports.LambdaAccess = LambdaAccess;
61
61
  _a = JSII_RTTI_SYMBOL_1;
62
- LambdaAccess[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaAccess", version: "0.12.3" };
62
+ LambdaAccess[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaAccess", version: "0.12.5" };
63
63
  /**
64
64
  * @internal
65
65
  */
@@ -30,7 +30,7 @@ class RunnerImageBuilder extends common_1.RunnerImageBuilderBase {
30
30
  return new aws_image_builder_1.AwsImageBuilderRunnerImageBuilder(scope, id, props);
31
31
  }
32
32
  const os = props?.os ?? providers_1.Os.LINUX_UBUNTU;
33
- if (os.is(providers_1.Os.LINUX_UBUNTU) || os.is(providers_1.Os.LINUX_AMAZON_2) || os.is(providers_1.Os.LINUX_AMAZON_2023)) {
33
+ if (os.isIn(providers_1.Os._ALL_LINUX_VERSIONS)) {
34
34
  return new codebuild_1.CodeBuildRunnerImageBuilder(scope, id, props);
35
35
  }
36
36
  else if (os.is(providers_1.Os.WINDOWS)) {
@@ -43,5 +43,5 @@ class RunnerImageBuilder extends common_1.RunnerImageBuilderBase {
43
43
  }
44
44
  exports.RunnerImageBuilder = RunnerImageBuilder;
45
45
  _a = JSII_RTTI_SYMBOL_1;
46
- RunnerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerImageBuilder", version: "0.12.3" };
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ltYWdlLWJ1aWxkZXJzL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUEwQztBQUUxQywyREFBd0U7QUFDeEUsMkNBQTBEO0FBQzFELHFDQUFvSTtBQUNwSSw0Q0FBa0M7QUFFbEM7Ozs7OztHQU1HO0FBQ0gsTUFBc0Isa0JBQW1CLFNBQVEsK0JBQXNCO0lBQ3JFOztPQUVHO0lBQ0gsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN0RSxJQUFJLEtBQUssRUFBRSxVQUFVLElBQUksS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzdDLHlCQUFXLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FBQyxrSEFBa0gsQ0FBQyxDQUFDO1FBQ3ZKLENBQUM7UUFFRCxJQUFJLEtBQUssRUFBRSxXQUFXLEtBQUssK0JBQXNCLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDN0QsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFdBQVcsS0FBSywrQkFBc0IsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQzNFLE9BQU8sSUFBSSxxREFBaUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFFRCxNQUFNLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxJQUFJLGNBQUUsQ0FBQyxZQUFZLENBQUM7UUFDeEMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLGNBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLGNBQUUsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLGNBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDdEYsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxjQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM3QixPQUFPLElBQUkscURBQWlDLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNqRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsMERBQTBELEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZGLENBQUM7SUFDSCxDQUFDOztBQXZCSCxnREF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbm5vdGF0aW9ucyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyIH0gZnJvbSAnLi9hd3MtaW1hZ2UtYnVpbGRlcic7XG5pbXBvcnQgeyBDb2RlQnVpbGRSdW5uZXJJbWFnZUJ1aWxkZXIgfSBmcm9tICcuL2NvZGVidWlsZCc7XG5pbXBvcnQgeyBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyLCBSdW5uZXJJbWFnZUJ1aWxkZXJCYXNlLCBSdW5uZXJJbWFnZUJ1aWxkZXJQcm9wcywgUnVubmVySW1hZ2VCdWlsZGVyVHlwZSB9IGZyb20gJy4vY29tbW9uJztcbmltcG9ydCB7IE9zIH0gZnJvbSAnLi4vcHJvdmlkZXJzJztcblxuLyoqXG4gKiBHaXRIdWIgUnVubmVyIGltYWdlIGJ1aWxkZXIuIEJ1aWxkcyBhIERvY2tlciBpbWFnZSBvciBBTUkgd2l0aCBHaXRIdWIgUnVubmVyIGFuZCBvdGhlciByZXF1aXJlbWVudHMgaW5zdGFsbGVkLlxuICpcbiAqIEltYWdlcyBjYW4gYmUgY3VzdG9taXplZCBiZWZvcmUgcGFzc2VkIGludG8gdGhlIHByb3ZpZGVyIGJ5IGFkZGluZyBvciByZW1vdmluZyBjb21wb25lbnRzIHRvIGJlIGluc3RhbGxlZC5cbiAqXG4gKiBJbWFnZXMgYXJlIHJlYnVpbHQgZXZlcnkgd2VlayBieSBkZWZhdWx0IHRvIGVuc3VyZSB0aGF0IHRoZSBsYXRlc3Qgc2VjdXJpdHkgcGF0Y2hlcyBhcmUgYXBwbGllZC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJ1bm5lckltYWdlQnVpbGRlciBleHRlbmRzIFJ1bm5lckltYWdlQnVpbGRlckJhc2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGltYWdlIGJ1aWxkZXIgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHByb3BlcnRpZXMuIFRoZSBpbXBsZW1lbnRhdGlvbiB3aWxsIGRpZmZlciBiYXNlZCBvbiB0aGUgT1MsIGFyY2hpdGVjdHVyZSwgYW5kIHJlcXVlc3RlZCBidWlsZGVyIHR5cGUuXG4gICAqL1xuICBzdGF0aWMgbmV3KHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogUnVubmVySW1hZ2VCdWlsZGVyUHJvcHMpOiBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyIHtcbiAgICBpZiAocHJvcHM/LmNvbXBvbmVudHMgJiYgcHJvcHMucnVubmVyVmVyc2lvbikge1xuICAgICAgQW5ub3RhdGlvbnMub2Yoc2NvcGUpLmFkZFdhcm5pbmcoJ3J1bm5lclZlcnNpb24gaXMgaWdub3JlZCB3aGVuIGNvbXBvbmVudHMgYXJlIHNwZWNpZmllZC4gVGhlIHJ1bm5lciB2ZXJzaW9uIHdpbGwgYmUgZGV0ZXJtaW5lZCBieSB0aGUgY29tcG9uZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkNPREVfQlVJTEQpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkFXU19JTUFHRV9CVUlMREVSKSB7XG4gICAgICByZXR1cm4gbmV3IEF3c0ltYWdlQnVpbGRlclJ1bm5lckltYWdlQnVpbGRlcihzY29wZSwgaWQsIHByb3BzKTtcbiAgICB9XG5cbiAgICBjb25zdCBvcyA9IHByb3BzPy5vcyA/PyBPcy5MSU5VWF9VQlVOVFU7XG4gICAgaWYgKG9zLmlzKE9zLkxJTlVYX1VCVU5UVSkgfHwgb3MuaXMoT3MuTElOVVhfQU1BWk9OXzIpIHx8IG9zLmlzKE9zLkxJTlVYX0FNQVpPTl8yMDIzKSkge1xuICAgICAgcmV0dXJuIG5ldyBDb2RlQnVpbGRSdW5uZXJJbWFnZUJ1aWxkZXIoc2NvcGUsIGlkLCBwcm9wcyk7XG4gICAgfSBlbHNlIGlmIChvcy5pcyhPcy5XSU5ET1dTKSkge1xuICAgICAgcmV0dXJuIG5ldyBBd3NJbWFnZUJ1aWxkZXJSdW5uZXJJbWFnZUJ1aWxkZXIoc2NvcGUsIGlkLCBwcm9wcyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5hYmxlIHRvIGZpbmQgcnVubmVyIGltYWdlIGJ1aWxkZXIgaW1wbGVtZW50YXRpb24gZm9yICR7b3MubmFtZX1gKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
46
+ RunnerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerImageBuilder", version: "0.12.5" };
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ltYWdlLWJ1aWxkZXJzL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUEwQztBQUUxQywyREFBd0U7QUFDeEUsMkNBQTBEO0FBQzFELHFDQUFvSTtBQUNwSSw0Q0FBa0M7QUFFbEM7Ozs7OztHQU1HO0FBQ0gsTUFBc0Isa0JBQW1CLFNBQVEsK0JBQXNCO0lBQ3JFOztPQUVHO0lBQ0gsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN0RSxJQUFJLEtBQUssRUFBRSxVQUFVLElBQUksS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzdDLHlCQUFXLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FBQyxrSEFBa0gsQ0FBQyxDQUFDO1FBQ3ZKLENBQUM7UUFFRCxJQUFJLEtBQUssRUFBRSxXQUFXLEtBQUssK0JBQXNCLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDN0QsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFdBQVcsS0FBSywrQkFBc0IsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQzNFLE9BQU8sSUFBSSxxREFBaUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFFRCxNQUFNLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxJQUFJLGNBQUUsQ0FBQyxZQUFZLENBQUM7UUFDeEMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7WUFDcEMsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxjQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM3QixPQUFPLElBQUkscURBQWlDLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNqRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsMERBQTBELEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZGLENBQUM7SUFDSCxDQUFDOztBQXZCSCxnREF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbm5vdGF0aW9ucyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyIH0gZnJvbSAnLi9hd3MtaW1hZ2UtYnVpbGRlcic7XG5pbXBvcnQgeyBDb2RlQnVpbGRSdW5uZXJJbWFnZUJ1aWxkZXIgfSBmcm9tICcuL2NvZGVidWlsZCc7XG5pbXBvcnQgeyBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyLCBSdW5uZXJJbWFnZUJ1aWxkZXJCYXNlLCBSdW5uZXJJbWFnZUJ1aWxkZXJQcm9wcywgUnVubmVySW1hZ2VCdWlsZGVyVHlwZSB9IGZyb20gJy4vY29tbW9uJztcbmltcG9ydCB7IE9zIH0gZnJvbSAnLi4vcHJvdmlkZXJzJztcblxuLyoqXG4gKiBHaXRIdWIgUnVubmVyIGltYWdlIGJ1aWxkZXIuIEJ1aWxkcyBhIERvY2tlciBpbWFnZSBvciBBTUkgd2l0aCBHaXRIdWIgUnVubmVyIGFuZCBvdGhlciByZXF1aXJlbWVudHMgaW5zdGFsbGVkLlxuICpcbiAqIEltYWdlcyBjYW4gYmUgY3VzdG9taXplZCBiZWZvcmUgcGFzc2VkIGludG8gdGhlIHByb3ZpZGVyIGJ5IGFkZGluZyBvciByZW1vdmluZyBjb21wb25lbnRzIHRvIGJlIGluc3RhbGxlZC5cbiAqXG4gKiBJbWFnZXMgYXJlIHJlYnVpbHQgZXZlcnkgd2VlayBieSBkZWZhdWx0IHRvIGVuc3VyZSB0aGF0IHRoZSBsYXRlc3Qgc2VjdXJpdHkgcGF0Y2hlcyBhcmUgYXBwbGllZC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJ1bm5lckltYWdlQnVpbGRlciBleHRlbmRzIFJ1bm5lckltYWdlQnVpbGRlckJhc2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGltYWdlIGJ1aWxkZXIgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHByb3BlcnRpZXMuIFRoZSBpbXBsZW1lbnRhdGlvbiB3aWxsIGRpZmZlciBiYXNlZCBvbiB0aGUgT1MsIGFyY2hpdGVjdHVyZSwgYW5kIHJlcXVlc3RlZCBidWlsZGVyIHR5cGUuXG4gICAqL1xuICBzdGF0aWMgbmV3KHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogUnVubmVySW1hZ2VCdWlsZGVyUHJvcHMpOiBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyIHtcbiAgICBpZiAocHJvcHM/LmNvbXBvbmVudHMgJiYgcHJvcHMucnVubmVyVmVyc2lvbikge1xuICAgICAgQW5ub3RhdGlvbnMub2Yoc2NvcGUpLmFkZFdhcm5pbmcoJ3J1bm5lclZlcnNpb24gaXMgaWdub3JlZCB3aGVuIGNvbXBvbmVudHMgYXJlIHNwZWNpZmllZC4gVGhlIHJ1bm5lciB2ZXJzaW9uIHdpbGwgYmUgZGV0ZXJtaW5lZCBieSB0aGUgY29tcG9uZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkNPREVfQlVJTEQpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkFXU19JTUFHRV9CVUlMREVSKSB7XG4gICAgICByZXR1cm4gbmV3IEF3c0ltYWdlQnVpbGRlclJ1bm5lckltYWdlQnVpbGRlcihzY29wZSwgaWQsIHByb3BzKTtcbiAgICB9XG5cbiAgICBjb25zdCBvcyA9IHByb3BzPy5vcyA/PyBPcy5MSU5VWF9VQlVOVFU7XG4gICAgaWYgKG9zLmlzSW4oT3MuX0FMTF9MSU5VWF9WRVJTSU9OUykpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAob3MuaXMoT3MuV0lORE9XUykpIHtcbiAgICAgIHJldHVybiBuZXcgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuYWJsZSB0byBmaW5kIHJ1bm5lciBpbWFnZSBidWlsZGVyIGltcGxlbWVudGF0aW9uIGZvciAke29zLm5hbWV9YCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -79,6 +79,14 @@ function defaultBaseAmi(scope, os, architecture) {
79
79
  resourceName: `amazon-linux-2-${arch}/x.x.x`,
80
80
  });
81
81
  }
82
+ if (os.is(providers_1.Os.LINUX_AMAZON_2023)) {
83
+ return stack.formatArn({
84
+ service: 'imagebuilder',
85
+ resource: 'image',
86
+ account: 'aws',
87
+ resourceName: `amazon-linux-2023-${arch}/x.x.x`,
88
+ });
89
+ }
82
90
  if (os.is(providers_1.Os.WINDOWS)) {
83
91
  return stack.formatArn({
84
92
  service: 'imagebuilder',
@@ -90,4 +98,4 @@ function defaultBaseAmi(scope, os, architecture) {
90
98
  throw new Error(`OS ${os.name} not supported for AMI runner image`);
91
99
  }
92
100
  exports.defaultBaseAmi = defaultBaseAmi;
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1pLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ltYWdlLWJ1aWxkZXJzL2F3cy1pbWFnZS1idWlsZGVyL2FtaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBbUM7QUFDbkMsNkNBQStEO0FBRy9ELHFDQUFrRDtBQUNsRCwrQ0FBbUQ7QUFDbkQsc0NBQW1EO0FBMkJuRDs7OztHQUlHO0FBQ0gsTUFBYSxTQUFVLFNBQVEsK0JBQXNCO0lBS25ELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsRUFBRTtZQUNoRCxPQUFPO2dCQUNMLFlBQVksRUFBRSxTQUFTLENBQUMsR0FBRzthQUM1QixDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUEsK0JBQXNCLEVBQUMsSUFBSSxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQzVELFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUTtZQUN4QixVQUFVO1lBQ1YsU0FBUyxFQUFFLEtBQUssQ0FBQyxPQUFPO1NBQ3pCLENBQUMsQ0FBQztRQUVILElBQUksZ0JBQWdCLENBQUM7UUFDckIsSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQzlCLGdCQUFnQixHQUFHLGNBQWMsQ0FBQztRQUNwQyxDQUFDO2FBQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ3ZDLGdCQUFnQixHQUFHLEtBQUssQ0FBQyxDQUFDLHlIQUF5SDtRQUNySixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsb0NBQW9DLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ3hFLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLDhCQUFZLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxRQUFRLEVBQUU7WUFDN0QsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1lBQ3JCLFdBQVcsRUFBRSxLQUFLLENBQUMsT0FBTztZQUMxQixVQUFVO1lBQ1YsZ0JBQWdCO1NBQ2pCLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUF4Q0QsOEJBd0NDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLGNBQWMsQ0FBQyxLQUFnQixFQUFFLEVBQU0sRUFBRSxZQUEwQjtJQUNqRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUVsQyxJQUFJLElBQUksQ0FBQztJQUNULElBQUksWUFBWSxDQUFDLEVBQUUsQ0FBQyx3QkFBWSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDekMsSUFBSSxHQUFHLEtBQUssQ0FBQztJQUNmLENBQUM7U0FBTSxJQUFJLFlBQVksQ0FBQyxFQUFFLENBQUMsd0JBQVksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQy9DLElBQUksR0FBRyxPQUFPLENBQUM7SUFDakIsQ0FBQztTQUFNLENBQUM7UUFDTixNQUFNLElBQUksS0FBSyxDQUFDLDBDQUEwQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBRUQsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLGNBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLGNBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQzlDLE9BQU8sS0FBSyxDQUFDLFNBQVMsQ0FBQztZQUNyQixPQUFPLEVBQUUsY0FBYztZQUN2QixRQUFRLEVBQUUsT0FBTztZQUNqQixPQUFPLEVBQUUsS0FBSztZQUNkLFlBQVksRUFBRSx3QkFBd0IsSUFBSSxRQUFRO1NBQ25ELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsY0FBRSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7UUFDN0IsT0FBTyxLQUFLLENBQUMsU0FBUyxDQUFDO1lBQ3JCLE9BQU8sRUFBRSxjQUFjO1lBQ3ZCLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLE9BQU8sRUFBRSxLQUFLO1lBQ2QsWUFBWSxFQUFFLGtCQUFrQixJQUFJLFFBQVE7U0FDN0MsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxjQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUN0QixPQUFPLEtBQUssQ0FBQyxTQUFTLENBQUM7WUFDckIsT0FBTyxFQUFFLGNBQWM7WUFDdkIsUUFBUSxFQUFFLE9BQU87WUFDakIsT0FBTyxFQUFFLEtBQUs7WUFDZCxZQUFZLEVBQUUseUNBQXlDLElBQUksUUFBUTtTQUNwRSxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLHFDQUFxQyxDQUFDLENBQUM7QUFDdEUsQ0FBQztBQXhDRCx3Q0F3Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgYXdzX2ltYWdlYnVpbGRlciBhcyBpbWFnZWJ1aWxkZXIgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEltYWdlQnVpbGRlckNvbXBvbmVudCB9IGZyb20gJy4vYnVpbGRlcic7XG5pbXBvcnQgeyBJbWFnZUJ1aWxkZXJPYmplY3RCYXNlIH0gZnJvbSAnLi9jb21tb24nO1xuaW1wb3J0IHsgQXJjaGl0ZWN0dXJlLCBPcyB9IGZyb20gJy4uLy4uL3Byb3ZpZGVycyc7XG5pbXBvcnQgeyB1bmlxdWVJbWFnZUJ1aWxkZXJOYW1lIH0gZnJvbSAnLi4vY29tbW9uJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBBbWlSZWNpcGUgY29uc3RydWN0LlxuICovXG5pbnRlcmZhY2UgQW1pUmVjaXBlUHJvcGVydGllcyB7XG4gIC8qKlxuICAgKiBUYXJnZXQgcGxhdGZvcm0uIE11c3QgbWF0Y2ggYnVpbGRlciBwbGF0Zm9ybS5cbiAgICovXG4gIHJlYWRvbmx5IHBsYXRmb3JtOiAnTGludXgnIHwgJ1dpbmRvd3MnO1xuXG4gIC8qKlxuICAgKiBUYXJnZXQgYXJjaGl0ZWN0dXJlLiBNdXN0IG1hdGNoIGJ1aWxkZXIgcGxhdGZvcm0uXG4gICAqL1xuICByZWFkb25seSBhcmNoaXRlY3R1cmU6IEFyY2hpdGVjdHVyZTtcblxuICAvKipcbiAgICogQmFzZSBBTUkgdG8gdXNlIGZvciB0aGUgbmV3IHJ1bm5lciBBTUkuXG4gICAqL1xuICByZWFkb25seSBiYXNlQW1pOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIENvbXBvbmVudHMgdG8gYWRkIHRvIHRhcmdldCBjb250YWluZXIgaW1hZ2UuXG4gICAqL1xuICByZWFkb25seSBjb21wb25lbnRzOiBJbWFnZUJ1aWxkZXJDb21wb25lbnRbXTtcbn1cblxuLyoqXG4gKiBJbWFnZSBidWlsZGVyIHJlY2lwZSBmb3IgQW1hem9uIE1hY2hpbmUgSW1hZ2UgKEFNSSkuXG4gKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjbGFzcyBBbWlSZWNpcGUgZXh0ZW5kcyBJbWFnZUJ1aWxkZXJPYmplY3RCYXNlIHtcbiAgcHVibGljIHJlYWRvbmx5IGFybjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgdmVyc2lvbjogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBBbWlSZWNpcGVQcm9wZXJ0aWVzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGxldCBjb21wb25lbnRzID0gcHJvcHMuY29tcG9uZW50cy5tYXAoY29tcG9uZW50ID0+IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGNvbXBvbmVudEFybjogY29tcG9uZW50LmFybixcbiAgICAgIH07XG4gICAgfSk7XG5cbiAgICB0aGlzLm5hbWUgPSB1bmlxdWVJbWFnZUJ1aWxkZXJOYW1lKHRoaXMpO1xuICAgIHRoaXMudmVyc2lvbiA9IHRoaXMuZ2VuZXJhdGVWZXJzaW9uKCdJbWFnZVJlY2lwZScsIHRoaXMubmFtZSwge1xuICAgICAgcGxhdGZvcm06IHByb3BzLnBsYXRmb3JtLFxuICAgICAgY29tcG9uZW50cyxcbiAgICAgIHBhcmVudEFtaTogcHJvcHMuYmFzZUFtaSxcbiAgICB9KTtcblxuICAgIGxldCB3b3JraW5nRGlyZWN0b3J5O1xuICAgIGlmIChwcm9wcy5wbGF0Zm9ybSA9PSAnTGludXgnKSB7XG4gICAgICB3b3JraW5nRGlyZWN0b3J5ID0gJy9ob21lL3J1bm5lcic7XG4gICAgfSBlbHNlIGlmIChwcm9wcy5wbGF0Zm9ybSA9PSAnV2luZG93cycpIHtcbiAgICAgIHdvcmtpbmdEaXJlY3RvcnkgPSAnQzovJzsgLy8gbXVzdCBleGlzdCBvciBJbWFnZSBCdWlsZGVyIGZhaWxzIGFuZCBtdXN0IG5vdCBiZSBlbXB0eSBvciBnaXQgd2lsbCBzdGFsbCBpbnN0YWxsaW5nIGZyb20gdGhlIGRlZmF1bHQgd2luZG93c1xcc3lzdGVtMzJcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbnN1cHBvcnRlZCBBTUkgcmVjaXBlIHBsYXRmb3JtOiAke3Byb3BzLnBsYXRmb3JtfWApO1xuICAgIH1cblxuICAgIGNvbnN0IHJlY2lwZSA9IG5ldyBpbWFnZWJ1aWxkZXIuQ2ZuSW1hZ2VSZWNpcGUodGhpcywgJ1JlY2lwZScsIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIHZlcnNpb246IHRoaXMudmVyc2lvbixcbiAgICAgIHBhcmVudEltYWdlOiBwcm9wcy5iYXNlQW1pLFxuICAgICAgY29tcG9uZW50cyxcbiAgICAgIHdvcmtpbmdEaXJlY3RvcnksXG4gICAgfSk7XG5cbiAgICB0aGlzLmFybiA9IHJlY2lwZS5hdHRyQXJuO1xuICB9XG59XG5cbi8qKlxuICogRGVmYXVsdCBiYXNlIEFNSSBmb3IgZ2l2ZW4gT1MgYW5kIGFyY2hpdGVjdHVyZS5cbiAqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlZmF1bHRCYXNlQW1pKHNjb3BlOiBDb25zdHJ1Y3QsIG9zOiBPcywgYXJjaGl0ZWN0dXJlOiBBcmNoaXRlY3R1cmUpIHtcbiAgY29uc3Qgc3RhY2sgPSBjZGsuU3RhY2sub2Yoc2NvcGUpO1xuXG4gIGxldCBhcmNoO1xuICBpZiAoYXJjaGl0ZWN0dXJlLmlzKEFyY2hpdGVjdHVyZS5YODZfNjQpKSB7XG4gICAgYXJjaCA9ICd4ODYnO1xuICB9IGVsc2UgaWYgKGFyY2hpdGVjdHVyZS5pcyhBcmNoaXRlY3R1cmUuQVJNNjQpKSB7XG4gICAgYXJjaCA9ICdhcm02NCc7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBVbnN1cHBvcnRlZCBhcmNoaXRlY3R1cmUgZm9yIGJhc2UgQU1JOiAke2FyY2hpdGVjdHVyZS5uYW1lfWApO1xuICB9XG5cbiAgaWYgKG9zLmlzKE9zLkxJTlVYX1VCVU5UVSkgfHwgb3MuaXMoT3MuTElOVVgpKSB7XG4gICAgcmV0dXJuIHN0YWNrLmZvcm1hdEFybih7XG4gICAgICBzZXJ2aWNlOiAnaW1hZ2VidWlsZGVyJyxcbiAgICAgIHJlc291cmNlOiAnaW1hZ2UnLFxuICAgICAgYWNjb3VudDogJ2F3cycsXG4gICAgICByZXNvdXJjZU5hbWU6IGB1YnVudHUtc2VydmVyLTIyLWx0cy0ke2FyY2h9L3gueC54YCxcbiAgICB9KTtcbiAgfVxuXG4gIGlmIChvcy5pcyhPcy5MSU5VWF9BTUFaT05fMikpIHtcbiAgICByZXR1cm4gc3RhY2suZm9ybWF0QXJuKHtcbiAgICAgIHNlcnZpY2U6ICdpbWFnZWJ1aWxkZXInLFxuICAgICAgcmVzb3VyY2U6ICdpbWFnZScsXG4gICAgICBhY2NvdW50OiAnYXdzJyxcbiAgICAgIHJlc291cmNlTmFtZTogYGFtYXpvbi1saW51eC0yLSR7YXJjaH0veC54LnhgLFxuICAgIH0pO1xuICB9XG5cbiAgaWYgKG9zLmlzKE9zLldJTkRPV1MpKSB7XG4gICAgcmV0dXJuIHN0YWNrLmZvcm1hdEFybih7XG4gICAgICBzZXJ2aWNlOiAnaW1hZ2VidWlsZGVyJyxcbiAgICAgIHJlc291cmNlOiAnaW1hZ2UnLFxuICAgICAgYWNjb3VudDogJ2F3cycsXG4gICAgICByZXNvdXJjZU5hbWU6IGB3aW5kb3dzLXNlcnZlci0yMDIyLWVuZ2xpc2gtZnVsbC1iYXNlLSR7YXJjaH0veC54LnhgLFxuICAgIH0pO1xuICB9XG5cbiAgdGhyb3cgbmV3IEVycm9yKGBPUyAke29zLm5hbWV9IG5vdCBzdXBwb3J0ZWQgZm9yIEFNSSBydW5uZXIgaW1hZ2VgKTtcbn1cblxuIl19
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/ami.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { aws_imagebuilder as imagebuilder } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ImageBuilderComponent } from './builder';\nimport { ImageBuilderObjectBase } from './common';\nimport { Architecture, Os } from '../../providers';\nimport { uniqueImageBuilderName } from '../common';\n\n/**\n * Properties for AmiRecipe construct.\n */\ninterface AmiRecipeProperties {\n  /**\n   * Target platform. Must match builder platform.\n   */\n  readonly platform: 'Linux' | 'Windows';\n\n  /**\n   * Target architecture. Must match builder platform.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * Base AMI to use for the new runner AMI.\n   */\n  readonly baseAmi: string;\n\n  /**\n   * Components to add to target container image.\n   */\n  readonly components: ImageBuilderComponent[];\n}\n\n/**\n * Image builder recipe for Amazon Machine Image (AMI).\n *\n * @internal\n */\nexport class AmiRecipe extends ImageBuilderObjectBase {\n  public readonly arn: string;\n  public readonly name: string;\n  public readonly version: string;\n\n  constructor(scope: Construct, id: string, props: AmiRecipeProperties) {\n    super(scope, id);\n\n    let components = props.components.map(component => {\n      return {\n        componentArn: component.arn,\n      };\n    });\n\n    this.name = uniqueImageBuilderName(this);\n    this.version = this.generateVersion('ImageRecipe', this.name, {\n      platform: props.platform,\n      components,\n      parentAmi: props.baseAmi,\n    });\n\n    let workingDirectory;\n    if (props.platform == 'Linux') {\n      workingDirectory = '/home/runner';\n    } else if (props.platform == 'Windows') {\n      workingDirectory = 'C:/'; // must exist or Image Builder fails and must not be empty or git will stall installing from the default windows\\system32\n    } else {\n      throw new Error(`Unsupported AMI recipe platform: ${props.platform}`);\n    }\n\n    const recipe = new imagebuilder.CfnImageRecipe(this, 'Recipe', {\n      name: this.name,\n      version: this.version,\n      parentImage: props.baseAmi,\n      components,\n      workingDirectory,\n    });\n\n    this.arn = recipe.attrArn;\n  }\n}\n\n/**\n * Default base AMI for given OS and architecture.\n *\n * @internal\n */\nexport function defaultBaseAmi(scope: Construct, os: Os, architecture: Architecture) {\n  const stack = cdk.Stack.of(scope);\n\n  let arch;\n  if (architecture.is(Architecture.X86_64)) {\n    arch = 'x86';\n  } else if (architecture.is(Architecture.ARM64)) {\n    arch = 'arm64';\n  } else {\n    throw new Error(`Unsupported architecture for base AMI: ${architecture.name}`);\n  }\n\n  if (os.is(Os.LINUX_UBUNTU) || os.is(Os.LINUX)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `ubuntu-server-22-lts-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `amazon-linux-2-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2023)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `amazon-linux-2023-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.WINDOWS)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `windows-server-2022-english-full-base-${arch}/x.x.x`,\n    });\n  }\n\n  throw new Error(`OS ${os.name} not supported for AMI runner image`);\n}\n\n"]}
@@ -11,6 +11,44 @@ export interface AwsImageBuilderRunnerImageBuilderProps {
11
11
  * @default m5.large
12
12
  */
13
13
  readonly instanceType?: ec2.InstanceType;
14
+ /**
15
+ * Options for fast launch.
16
+ *
17
+ * This is only supported for Windows AMIs.
18
+ *
19
+ * @default disabled
20
+ */
21
+ readonly fastLaunchOptions?: FastLaunchOptions;
22
+ }
23
+ /**
24
+ * Options for fast launch.
25
+ */
26
+ export interface FastLaunchOptions {
27
+ /**
28
+ * Enable fast launch for AMIs generated by this builder. It creates a snapshot of the root volume and uses it to launch new instances faster.
29
+ *
30
+ * This is only supported for Windows AMIs.
31
+ *
32
+ * @note this feature comes with additional resource costs. See the documentation for more details. https://docs.aws.amazon.com/AWSEC2/latest/WindowsGuide/win-fast-launch-manage-costs.html
33
+ * @note enabling fast launch on an existing builder will not enable it for existing AMIs. It will only affect new AMIs. If you want immediate effect, trigger a new image build. Alternatively, you can create a new builder with fast launch enabled and use it for new AMIs.
34
+ *
35
+ * @default false
36
+ */
37
+ readonly enabled?: boolean;
38
+ /**
39
+ * The maximum number of parallel instances that are launched for creating resources.
40
+ *
41
+ * Must be at least 6.
42
+ *
43
+ * @default 6
44
+ */
45
+ readonly maxParallelLaunches?: number;
46
+ /**
47
+ * The number of pre-provisioned snapshots to keep on hand for a fast-launch enabled Windows AMI.
48
+ *
49
+ * @default 1
50
+ */
51
+ readonly targetResourceCount?: number;
14
52
  }
15
53
  /**
16
54
  * An asset including file or directory to place inside the built image.
@@ -116,6 +154,7 @@ export declare class AwsImageBuilderRunnerImageBuilder extends RunnerImageBuilde
116
154
  private readonly instanceType;
117
155
  private infrastructure;
118
156
  private readonly role;
157
+ private readonly fastLaunchOptions?;
119
158
  constructor(scope: Construct, id: string, props?: RunnerImageBuilderProps);
120
159
  private platform;
121
160
  /**
@@ -152,7 +152,7 @@ class ImageBuilderComponent extends common_1.ImageBuilderObjectBase {
152
152
  }
153
153
  exports.ImageBuilderComponent = ImageBuilderComponent;
154
154
  _a = JSII_RTTI_SYMBOL_1;
155
- ImageBuilderComponent[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ImageBuilderComponent", version: "0.12.3" };
155
+ ImageBuilderComponent[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ImageBuilderComponent", version: "0.12.5" };
156
156
  /**
157
157
  * @internal
158
158
  */
@@ -174,6 +174,7 @@ class AwsImageBuilderRunnerImageBuilder extends common_2.RunnerImageBuilderBase
174
174
  this.baseImage = props?.baseDockerImage ?? (0, container_1.defaultBaseDockerImage)(this.os);
175
175
  this.baseAmi = props?.baseAmi ?? (0, ami_1.defaultBaseAmi)(this, this.os, this.architecture);
176
176
  this.instanceType = props?.awsImageBuilderOptions?.instanceType ?? aws_cdk_lib_1.aws_ec2.InstanceType.of(aws_cdk_lib_1.aws_ec2.InstanceClass.M5, aws_cdk_lib_1.aws_ec2.InstanceSize.LARGE);
177
+ this.fastLaunchOptions = props?.awsImageBuilderOptions?.fastLaunchOptions;
177
178
  // confirm instance type
178
179
  if (!this.architecture.instanceTypeMatch(this.instanceType)) {
179
180
  throw new Error(`Builder architecture (${this.architecture.name}) doesn't match selected instance type (${this.instanceType} / ${this.instanceType.architecture})`);
@@ -192,7 +193,7 @@ class AwsImageBuilderRunnerImageBuilder extends common_2.RunnerImageBuilderBase
192
193
  if (this.os.is(providers_1.Os.WINDOWS)) {
193
194
  return 'Windows';
194
195
  }
195
- if (this.os.is(providers_1.Os.LINUX_AMAZON_2) || this.os.is(providers_1.Os.LINUX_UBUNTU)) {
196
+ if (this.os.isIn(providers_1.Os._ALL_LINUX_VERSIONS)) {
196
197
  return 'Linux';
197
198
  }
198
199
  throw new Error(`OS ${this.os.name} is not supported by AWS Image Builder`);
@@ -439,6 +440,71 @@ class AwsImageBuilderRunnerImageBuilder extends common_2.RunnerImageBuilderBase
439
440
  const launchTemplate = new aws_cdk_lib_1.aws_ec2.LaunchTemplate(this, 'Launch template', {
440
441
  requireImdsv2: true,
441
442
  });
443
+ const launchTemplateConfigs = [{
444
+ launchTemplateId: launchTemplate.launchTemplateId,
445
+ setDefaultVersion: true,
446
+ }];
447
+ const fastLaunchConfigs = [];
448
+ if (this.fastLaunchOptions?.enabled ?? false) {
449
+ if (!this.os.is(providers_1.Os.WINDOWS)) {
450
+ throw new Error('Fast launch is only supported for Windows');
451
+ }
452
+ // create a separate launch template for fast launch so:
453
+ // - settings don't affect the runners
454
+ // - enabling fast launch on an existing builder works (without a new launch template, EC2 Image Builder will use the first version of the launch template, which doesn't have instance or VPC config)
455
+ // - setting vpc + subnet on the main launch template will cause RunInstances to fail
456
+ // - EC2 Image Builder seems to get confused with which launch template version to base any new version on, so a new template is always best
457
+ const fastLaunchTemplate = new aws_cdk_lib_1.aws_ec2.CfnLaunchTemplate(this, 'Fast Launch Template', {
458
+ launchTemplateData: {
459
+ metadataOptions: {
460
+ httpTokens: 'required',
461
+ },
462
+ instanceType: this.instanceType.toString(),
463
+ networkInterfaces: [{
464
+ subnetId: this.vpc?.selectSubnets(this.subnetSelection).subnetIds[0],
465
+ deviceIndex: 0,
466
+ groups: this.securityGroups.map(sg => sg.securityGroupId),
467
+ }],
468
+ tagSpecifications: [
469
+ {
470
+ resourceType: 'instance',
471
+ tags: [{
472
+ key: 'Name',
473
+ value: `${this.node.path}/Fast Launch Instance`,
474
+ }],
475
+ },
476
+ {
477
+ resourceType: 'volume',
478
+ tags: [{
479
+ key: 'Name',
480
+ value: `${this.node.path}/Fast Launch Instance`,
481
+ }],
482
+ },
483
+ ],
484
+ },
485
+ tagSpecifications: [{
486
+ resourceType: 'launch-template',
487
+ tags: [{
488
+ key: 'Name',
489
+ value: `${this.node.path}/Fast Launch Template`,
490
+ }],
491
+ }],
492
+ });
493
+ launchTemplateConfigs.push({
494
+ launchTemplateId: fastLaunchTemplate.attrLaunchTemplateId,
495
+ setDefaultVersion: true,
496
+ });
497
+ fastLaunchConfigs.push({
498
+ enabled: true,
499
+ launchTemplate: {
500
+ launchTemplateId: fastLaunchTemplate.attrLaunchTemplateId,
501
+ },
502
+ maxParallelLaunches: this.fastLaunchOptions?.maxParallelLaunches ?? 6,
503
+ snapshotConfiguration: {
504
+ targetResourceCount: this.fastLaunchOptions?.targetResourceCount ?? 1,
505
+ },
506
+ });
507
+ }
442
508
  const stackName = cdk.Stack.of(this).stackName;
443
509
  const builderName = this.node.path;
444
510
  const dist = new aws_cdk_lib_1.aws_imagebuilder.CfnDistributionConfiguration(this, 'AMI Distribution', {
@@ -459,11 +525,8 @@ class AwsImageBuilderRunnerImageBuilder extends common_2.RunnerImageBuilderBase
459
525
  'GitHubRunners:Builder': builderName,
460
526
  },
461
527
  },
462
- launchTemplateConfigurations: [
463
- {
464
- launchTemplateId: launchTemplate.launchTemplateId,
465
- },
466
- ],
528
+ launchTemplateConfigurations: launchTemplateConfigs,
529
+ fastLaunchConfigurations: fastLaunchConfigs.length > 0 ? fastLaunchConfigs : undefined,
467
530
  },
468
531
  ],
469
532
  });
@@ -504,7 +567,6 @@ class AwsImageBuilderRunnerImageBuilder extends common_2.RunnerImageBuilderBase
504
567
  conditions: {
505
568
  StringEquals: {
506
569
  'aws:ResourceTag/GitHubRunners:Stack': stackName,
507
- 'aws:ResourceTag/GitHubRunners:Builder': builderName,
508
570
  },
509
571
  },
510
572
  }),
@@ -622,4 +684,4 @@ class AwsImageBuilderFailedBuildNotifier {
622
684
  }
623
685
  }
624
686
  exports.AwsImageBuilderFailedBuildNotifier = AwsImageBuilderFailedBuildNotifier;
625
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/builder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  Annotations,\n  aws_ec2 as ec2,\n  aws_ecr as ecr,\n  aws_events as events,\n  aws_iam as iam,\n  aws_imagebuilder as imagebuilder,\n  aws_logs as logs,\n  aws_s3_assets as s3_assets,\n  aws_sns as sns,\n  aws_sns_subscriptions as subs,\n  CustomResource,\n  Duration,\n  RemovalPolicy,\n  Stack,\n} from 'aws-cdk-lib';\nimport { TagMutability } from 'aws-cdk-lib/aws-ecr';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct, IConstruct } from 'constructs';\nimport { AmiRecipe, defaultBaseAmi } from './ami';\nimport { ImageBuilderObjectBase } from './common';\nimport { ContainerRecipe, defaultBaseDockerImage } from './container';\nimport { DeleteAmiFunction } from './delete-ami-function';\nimport { FilterFailedBuildsFunction } from './filter-failed-builds-function';\nimport { Architecture, Os, RunnerAmi, RunnerImage, RunnerVersion } from '../../providers';\nimport { singletonLambda } from '../../utils';\nimport { BuildImageFunction } from '../build-image-function';\nimport { RunnerImageBuilderBase, RunnerImageBuilderProps, uniqueImageBuilderName } from '../common';\n\nexport interface AwsImageBuilderRunnerImageBuilderProps {\n  /**\n   * The instance type used to build the image.\n   *\n   * @default m5.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n}\n\n/**\n * An asset including file or directory to place inside the built image.\n */\nexport interface ImageBuilderAsset {\n  /**\n   * Path to place asset in the image.\n   */\n  readonly path: string;\n\n  /**\n   * Asset to place in the image.\n   */\n  readonly asset: s3_assets.Asset;\n}\n\n/**\n * Properties for ImageBuilderComponent construct.\n */\nexport interface ImageBuilderComponentProperties {\n  /**\n   * Component platform. Must match the builder platform.\n   */\n  readonly platform: 'Linux' | 'Windows';\n\n  /**\n   * Component display name.\n   */\n  readonly displayName: string;\n\n  /**\n   * Component description.\n   */\n  readonly description: string;\n\n  /**\n   * Shell commands to run when adding this component to the image.\n   *\n   * On Linux, these are bash commands. On Windows, there are PowerShell commands.\n   */\n  readonly commands: string[];\n\n  /**\n   * Optional assets to add to the built image.\n   */\n  readonly assets?: ImageBuilderAsset[];\n\n  /**\n   * Require a reboot after installing this component.\n   *\n   * @default false\n   */\n  readonly reboot?: boolean;\n}\n\n/**\n * Components are a set of commands to run and optional files to add to an image. Components are the building blocks of images built by Image Builder.\n *\n * Example:\n *\n * ```\n * new ImageBuilderComponent(this, 'AWS CLI', {\n *   platform: 'Windows',\n *   displayName: 'AWS CLI',\n *   description: 'Install latest version of AWS CLI',\n *   commands: [\n *     '$p = Start-Process msiexec.exe -PassThru -Wait -ArgumentList \\'/i https://awscli.amazonaws.com/AWSCLIV2.msi /qn\\'',\n *     'if ($p.ExitCode -ne 0) { throw \"Exit code is $p.ExitCode\" }',\n *   ],\n * }\n * ```\n *\n * @deprecated Use `RunnerImageComponent` instead as this be internal soon.\n */\nexport class ImageBuilderComponent extends ImageBuilderObjectBase {\n  /**\n   * Component ARN.\n   */\n  public readonly arn: string;\n\n  /**\n   * Supported platform for the component.\n   */\n  public readonly platform: 'Windows' | 'Linux';\n\n  private readonly assets: s3_assets.Asset[] = [];\n\n  constructor(scope: Construct, id: string, props: ImageBuilderComponentProperties) {\n    super(scope, id);\n\n    this.platform = props.platform;\n\n    let steps: any[] = [];\n\n    if (props.assets) {\n      let inputs: any[] = [];\n      let extractCommands: string[] = [];\n      for (const asset of props.assets) {\n        this.assets.push(asset.asset);\n\n        if (asset.asset.isFile) {\n          inputs.push({\n            source: asset.asset.s3ObjectUrl,\n            destination: asset.path,\n          });\n        } else if (asset.asset.isZipArchive) {\n          inputs.push({\n            source: asset.asset.s3ObjectUrl,\n            destination: `${asset.path}.zip`,\n          });\n          if (props.platform === 'Windows') {\n            extractCommands.push(`Expand-Archive \"${asset.path}.zip\" -DestinationPath \"${asset.path}\"`);\n            extractCommands.push(`del \"${asset.path}.zip\"`);\n          } else {\n            extractCommands.push(`unzip \"${asset.path}.zip\" -d \"${asset.path}\"`);\n            extractCommands.push(`rm \"${asset.path}.zip\"`);\n          }\n        } else {\n          throw new Error(`Unknown asset type: ${asset.asset}`);\n        }\n      }\n\n      steps.push({\n        name: 'Download',\n        action: 'S3Download',\n        inputs,\n      });\n\n      if (extractCommands.length > 0) {\n        steps.push({\n          name: 'Extract',\n          action: props.platform === 'Linux' ? 'ExecuteBash' : 'ExecutePowerShell',\n          inputs: {\n            commands: this.prefixCommandsWithErrorHandling(props.platform, extractCommands),\n          },\n        });\n      }\n    }\n\n    if (props.commands.length > 0) {\n      steps.push({\n        name: 'Run',\n        action: props.platform === 'Linux' ? 'ExecuteBash' : 'ExecutePowerShell',\n        inputs: {\n          commands: this.prefixCommandsWithErrorHandling(props.platform, props.commands),\n        },\n      });\n    }\n\n    if (props.reboot ?? false) {\n      steps.push({\n        name: 'Reboot',\n        action: 'Reboot',\n        inputs: {},\n      });\n    }\n\n    const data = {\n      name: props.displayName,\n      schemaVersion: '1.0',\n      phases: [\n        {\n          name: 'build',\n          steps,\n        },\n      ],\n    };\n\n    const name = uniqueImageBuilderName(this);\n    const component = new imagebuilder.CfnComponent(this, 'Component', {\n      name: name,\n      description: props.description,\n      platform: props.platform,\n      version: this.generateVersion('Component', name, {\n        platform: props.platform,\n        data,\n        description: props.description,\n      }),\n      data: JSON.stringify(data),\n    });\n\n    this.arn = component.attrArn;\n  }\n\n  /**\n   * Grants read permissions to the principal on the assets buckets.\n   *\n   * @param grantee\n   */\n  grantAssetsRead(grantee: iam.IGrantable) {\n    for (const asset of this.assets) {\n      asset.grantRead(grantee);\n    }\n  }\n\n  prefixCommandsWithErrorHandling(platform: 'Windows' | 'Linux', commands: string[]) {\n    if (platform == 'Windows') {\n      return [\n        '$ErrorActionPreference = \\'Stop\\'',\n        '$ProgressPreference = \\'SilentlyContinue\\'',\n        'Set-PSDebug -Trace 1',\n      ].concat(commands);\n    } else {\n      return [\n        'set -ex',\n      ].concat(commands);\n    }\n  }\n}\n\n/**\n * @internal\n */\nexport class AwsImageBuilderRunnerImageBuilder extends RunnerImageBuilderBase {\n  private boundDockerImage?: RunnerImage;\n  private boundAmi?: RunnerAmi;\n  private readonly os: Os;\n  private readonly architecture: Architecture;\n  private readonly baseImage: string;\n  private readonly baseAmi: string;\n  private readonly logRetention: RetentionDays;\n  private readonly logRemovalPolicy: RemovalPolicy;\n  private readonly vpc: ec2.IVpc;\n  private readonly securityGroups: ec2.ISecurityGroup[];\n  private readonly subnetSelection: ec2.SubnetSelection | undefined;\n  private readonly rebuildInterval: cdk.Duration;\n  private readonly boundComponents: ImageBuilderComponent[] = [];\n  private readonly instanceType: ec2.InstanceType;\n  private infrastructure: imagebuilder.CfnInfrastructureConfiguration | undefined;\n  private readonly role: iam.Role;\n\n  constructor(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    super(scope, id, props);\n\n    if (props?.codeBuildOptions) {\n      Annotations.of(this).addWarning('codeBuildOptions are ignored when using AWS Image Builder to build runner images.');\n    }\n\n    this.os = props?.os ?? Os.LINUX_UBUNTU;\n    this.architecture = props?.architecture ?? Architecture.X86_64;\n    this.rebuildInterval = props?.rebuildInterval ?? Duration.days(7);\n    this.logRetention = props?.logRetention ?? RetentionDays.ONE_MONTH;\n    this.logRemovalPolicy = props?.logRemovalPolicy ?? RemovalPolicy.DESTROY;\n    this.vpc = props?.vpc ?? ec2.Vpc.fromLookup(this, 'VPC', { isDefault: true });\n    this.securityGroups = props?.securityGroups ?? [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })];\n    this.subnetSelection = props?.subnetSelection;\n    this.baseImage = props?.baseDockerImage ?? defaultBaseDockerImage(this.os);\n    this.baseAmi = props?.baseAmi ?? defaultBaseAmi(this, this.os, this.architecture);\n    this.instanceType = props?.awsImageBuilderOptions?.instanceType ?? ec2.InstanceType.of(ec2.InstanceClass.M5, ec2.InstanceSize.LARGE);\n\n    // confirm instance type\n    if (!this.architecture.instanceTypeMatch(this.instanceType)) {\n      throw new Error(`Builder architecture (${this.architecture.name}) doesn't match selected instance type (${this.instanceType} / ${this.instanceType.architecture})`);\n    }\n\n    // warn against isolated networks\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PRIVATE_ISOLATED) {\n      Annotations.of(this).addWarning('Private isolated subnets cannot pull from public ECR and VPC endpoint is not supported yet. ' +\n        'See https://github.com/aws/containers-roadmap/issues/1160');\n    }\n\n    // role to be used by AWS Image Builder\n    this.role = new iam.Role(this, 'Role', {\n      assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n    });\n  }\n\n  private platform() {\n    if (this.os.is(Os.WINDOWS)) {\n      return 'Windows';\n    }\n    if (this.os.is(Os.LINUX_AMAZON_2) || this.os.is(Os.LINUX_UBUNTU)) {\n      return 'Linux';\n    }\n    throw new Error(`OS ${this.os.name} is not supported by AWS Image Builder`);\n  }\n\n  /**\n   * Called by IRunnerProvider to finalize settings and create the image builder.\n   */\n  bindDockerImage(): RunnerImage {\n    if (this.boundDockerImage) {\n      return this.boundDockerImage;\n    }\n\n    // create repository that only keeps one tag\n    const repository = new ecr.Repository(this, 'Repository', {\n      imageScanOnPush: true,\n      imageTagMutability: TagMutability.MUTABLE,\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteImages: true,\n    });\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'Docker Distribution', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          containerDistributionConfiguration: {\n            ContainerTags: ['latest'],\n            TargetRepository: {\n              Service: 'ECR',\n              RepositoryName: repository.repositoryName,\n            },\n          },\n        },\n      ],\n    });\n\n    let dockerfileTemplate = `FROM {{{ imagebuilder:parentImage }}}\n{{{ imagebuilder:environments }}}\n{{{ imagebuilder:components }}}`;\n\n    for (const c of this.components) {\n      const commands = c.getDockerCommands(this.os, this.architecture);\n      if (commands.length > 0) {\n        dockerfileTemplate += '\\n' + commands.join('\\n') + '\\n';\n      }\n    }\n\n    const recipe = new ContainerRecipe(this, 'Container Recipe', {\n      platform: this.platform(),\n      components: this.bindComponents(),\n      targetRepository: repository,\n      dockerfileTemplate: dockerfileTemplate,\n      parentImage: this.baseImage,\n    });\n\n    const log = this.createLog('Docker Log', recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilderECRContainerBuilds'),\n    ]);\n    const image = this.createImage(infra, dist, log, undefined, recipe.arn);\n    this.createPipeline(infra, dist, log, undefined, recipe.arn);\n\n    this.dockerImageCleaner(recipe, image, repository);\n\n    this.boundDockerImage = {\n      imageRepository: repository,\n      imageTag: 'latest',\n      os: this.os,\n      architecture: this.architecture,\n      logGroup: log,\n      runnerVersion: RunnerVersion.specific('unknown'),\n      // no dependable as CloudFormation will fail to get image ARN once the image is deleted (we delete old images daily)\n    };\n\n    return this.boundDockerImage;\n  }\n\n  private dockerImageCleaner(recipe: ContainerRecipe, image: imagebuilder.CfnImage, repository: ecr.IRepository) {\n    // delete all left over dockers images on\n    const crHandler = singletonLambda(BuildImageFunction, this, 'build-image', {\n      description: 'Custom resource handler that triggers CodeBuild to build runner images, and cleans-up images on deletion',\n      timeout: cdk.Duration.minutes(3),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    const policy = new iam.Policy(this, 'CR Policy', {\n      statements: [\n        new iam.PolicyStatement({\n          actions: ['imagebuilder:ListImages', 'imagebuilder:ListImageBuildVersions', 'imagebuilder:DeleteImage'],\n          resources: ['*'], // Image Builder doesn't support scoping this :(\n        }),\n      ],\n    });\n    crHandler.role?.attachInlinePolicy(policy);\n\n    const cr = new CustomResource(this, 'Deleter', {\n      serviceToken: crHandler.functionArn,\n      resourceType: 'Custom::ImageDeleter',\n      properties: {\n        RepoName: repository.repositoryName,\n        ImageBuilderName: recipe.name, // we don't use image.name because CloudFormation complains if it was deleted already\n        // TODO pass version too and then when a new version is deployed, it will delete the old one (careful with upgrades)\n        DeleteOnly: true,\n      },\n    });\n\n    // add dependencies to make sure resources are there when we need them\n    cr.node.addDependency(image);\n    cr.node.addDependency(policy);\n    cr.node.addDependency(crHandler);\n\n    // delete old docker images + IB resources daily\n    new imagebuilder.CfnLifecyclePolicy(this, 'Lifecycle Policy Docker', {\n      name: uniqueImageBuilderName(this),\n      description: `Delete old GitHub Runner Docker images for ${this.node.path}`,\n      executionRole: new iam.Role(this, 'Lifecycle Policy Docker Role', {\n        assumedBy: new iam.ServicePrincipal('imagebuilder.amazonaws.com'),\n        inlinePolicies: {\n          ib: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['tag:GetResources', 'imagebuilder:DeleteImage'],\n                resources: ['*'], // Image Builder doesn't support scoping this :(\n              }),\n            ],\n          }),\n          ecr: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['ecr:BatchGetImage', 'ecr:BatchDeleteImage'],\n                resources: [repository.repositoryArn],\n              }),\n            ],\n          }),\n        },\n      }).roleArn,\n      policyDetails: [{\n        action: {\n          type: 'DELETE',\n          includeResources: {\n            containers: true,\n          },\n        },\n        filter: {\n          type: 'COUNT',\n          value: 2,\n        },\n      }],\n      resourceType: 'CONTAINER_IMAGE',\n      resourceSelection: {\n        recipes: [\n          {\n            name: recipe.name,\n            semanticVersion: recipe.version, // docs say it's optional, but it's not\n          },\n        ],\n      },\n    });\n  }\n\n  protected createLog(id: string, recipeName: string): logs.LogGroup {\n    return new logs.LogGroup(this, id, {\n      logGroupName: `/aws/imagebuilder/${recipeName}`,\n      retention: this.logRetention,\n      removalPolicy: this.logRemovalPolicy,\n    });\n  }\n\n  protected createInfrastructure(managedPolicies: iam.IManagedPolicy[]): imagebuilder.CfnInfrastructureConfiguration {\n    if (this.infrastructure) {\n      return this.infrastructure;\n    }\n\n    for (const managedPolicy of managedPolicies) {\n      this.role.addManagedPolicy(managedPolicy);\n    }\n\n    for (const component of this.boundComponents) {\n      component.grantAssetsRead(this.role);\n    }\n\n    this.infrastructure = new imagebuilder.CfnInfrastructureConfiguration(this, 'Infrastructure', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      subnetId: this.vpc?.selectSubnets(this.subnetSelection).subnetIds[0],\n      securityGroupIds: this.securityGroups?.map(sg => sg.securityGroupId),\n      instanceTypes: [this.instanceType.toString()],\n      instanceMetadataOptions: {\n        httpTokens: 'required',\n        // Container builds require a minimum of two hops.\n        httpPutResponseHopLimit: 2,\n      },\n      instanceProfileName: new iam.CfnInstanceProfile(this, 'Instance Profile', {\n        roles: [\n          this.role.roleName,\n        ],\n      }).ref,\n    });\n\n    return this.infrastructure;\n  }\n\n  protected createImage(infra: imagebuilder.CfnInfrastructureConfiguration, dist: imagebuilder.CfnDistributionConfiguration, log: logs.LogGroup,\n    imageRecipeArn?: string, containerRecipeArn?: string): imagebuilder.CfnImage {\n    const image = new imagebuilder.CfnImage(this, this.amiOrContainerId('Image', imageRecipeArn, containerRecipeArn), {\n      infrastructureConfigurationArn: infra.attrArn,\n      distributionConfigurationArn: dist.attrArn,\n      imageRecipeArn,\n      containerRecipeArn,\n      imageTestsConfiguration: {\n        imageTestsEnabled: false,\n      },\n    });\n    image.node.addDependency(infra);\n    image.node.addDependency(log);\n\n    return image;\n  }\n\n  private amiOrContainerId(baseId: string, imageRecipeArn?: string, containerRecipeArn?: string) {\n    if (imageRecipeArn) {\n      return `AMI ${baseId}`;\n    }\n    if (containerRecipeArn) {\n      return `Docker ${baseId}`;\n    }\n    throw new Error('Either imageRecipeArn or containerRecipeArn must be defined');\n  }\n\n  protected createPipeline(infra: imagebuilder.CfnInfrastructureConfiguration, dist: imagebuilder.CfnDistributionConfiguration, log: logs.LogGroup,\n    imageRecipeArn?: string, containerRecipeArn?: string): imagebuilder.CfnImagePipeline {\n    let scheduleOptions: imagebuilder.CfnImagePipeline.ScheduleProperty | undefined;\n    if (this.rebuildInterval.toDays() > 0) {\n      scheduleOptions = {\n        scheduleExpression: events.Schedule.rate(this.rebuildInterval).expressionString,\n        pipelineExecutionStartCondition: 'EXPRESSION_MATCH_ONLY',\n      };\n    }\n    const pipeline = new imagebuilder.CfnImagePipeline(this, this.amiOrContainerId('Pipeline', imageRecipeArn, containerRecipeArn), {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      infrastructureConfigurationArn: infra.attrArn,\n      distributionConfigurationArn: dist.attrArn,\n      imageRecipeArn,\n      containerRecipeArn,\n      schedule: scheduleOptions,\n      imageTestsConfiguration: {\n        imageTestsEnabled: false,\n      },\n    });\n    pipeline.node.addDependency(infra);\n    pipeline.node.addDependency(log);\n\n    return pipeline;\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return new ec2.Connections({ securityGroups: this.securityGroups });\n  }\n\n  public get grantPrincipal(): iam.IPrincipal {\n    return this.role;\n  }\n\n  bindAmi(): RunnerAmi {\n    if (this.boundAmi) {\n      return this.boundAmi;\n    }\n\n    const launchTemplate = new ec2.LaunchTemplate(this, 'Launch template', {\n      requireImdsv2: true,\n    });\n\n    const stackName = cdk.Stack.of(this).stackName;\n    const builderName = this.node.path;\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'AMI Distribution', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          amiDistributionConfiguration: {\n            Name: `${cdk.Names.uniqueResourceName(this, {\n              maxLength: 100,\n              separator: '-',\n              allowedSpecialCharacters: '_-',\n            })}-{{ imagebuilder:buildDate }}`,\n            AmiTags: {\n              'Name': this.node.id,\n              'GitHubRunners:Stack': stackName,\n              'GitHubRunners:Builder': builderName,\n            },\n          },\n          launchTemplateConfigurations: [\n            {\n              launchTemplateId: launchTemplate.launchTemplateId,\n            },\n          ],\n        },\n      ],\n    });\n\n    const recipe = new AmiRecipe(this, 'Ami Recipe', {\n      platform: this.platform(),\n      components: this.bindComponents(),\n      architecture: this.architecture,\n      baseAmi: this.baseAmi,\n    });\n\n    const log = this.createLog('Ami Log', recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilder'),\n    ]);\n    this.createImage(infra, dist, log, recipe.arn, undefined);\n    this.createPipeline(infra, dist, log, recipe.arn, undefined);\n\n    this.boundAmi = {\n      launchTemplate: launchTemplate,\n      architecture: this.architecture,\n      os: this.os,\n      logGroup: log,\n      runnerVersion: RunnerVersion.specific('unknown'),\n    };\n\n    this.amiCleaner(recipe, stackName, builderName);\n\n    return this.boundAmi;\n  }\n\n  private amiCleaner(recipe: AmiRecipe, stackName: string, builderName: string) {\n    const deleter = singletonLambda(DeleteAmiFunction, this, 'delete-ami', {\n      description: 'Delete old GitHub Runner AMIs',\n      initialPolicy: [\n        new iam.PolicyStatement({\n          actions: ['ec2:DescribeImages'],\n          resources: ['*'],\n        }),\n        new iam.PolicyStatement({\n          actions: ['ec2:DeregisterImage', 'ec2:DeleteSnapshot'],\n          resources: ['*'],\n          conditions: {\n            StringEquals: {\n              'aws:ResourceTag/GitHubRunners:Stack': stackName,\n              'aws:ResourceTag/GitHubRunners:Builder': builderName,\n            },\n          },\n        }),\n      ],\n      timeout: cdk.Duration.minutes(5),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    // delete all AMIs when this construct is removed\n    new CustomResource(this, 'AMI Deleter', {\n      serviceToken: deleter.functionArn,\n      resourceType: 'Custom::AmiDeleter',\n      properties: {\n        StackName: stackName,\n        BuilderName: builderName,\n      },\n    });\n\n    // delete old AMIs + IB resources daily\n    new imagebuilder.CfnLifecyclePolicy(this, 'Lifecycle Policy AMI', {\n      name: uniqueImageBuilderName(this),\n      description: `Delete old GitHub Runner AMIs for ${this.node.path}`,\n      executionRole: new iam.Role(this, 'Lifecycle Policy AMI Role', {\n        assumedBy: new iam.ServicePrincipal('imagebuilder.amazonaws.com'),\n        inlinePolicies: {\n          ib: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['tag:GetResources', 'imagebuilder:DeleteImage'],\n                resources: ['*'], // Image Builder doesn't support scoping this :(\n              }),\n            ],\n          }),\n          ami: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['ec2:DescribeImages', 'ec2:DescribeImageAttribute'],\n                resources: ['*'],\n              }),\n              new iam.PolicyStatement({\n                actions: ['ec2:DeregisterImage', 'ec2:DeleteSnapshot'],\n                resources: ['*'],\n                conditions: {\n                  StringEquals: {\n                    'aws:ResourceTag/GitHubRunners:Stack': stackName,\n                    'aws:ResourceTag/GitHubRunners:Builder': builderName,\n                  },\n                },\n              }),\n            ],\n          }),\n        },\n      }).roleArn,\n      policyDetails: [{\n        action: {\n          type: 'DELETE',\n          includeResources: {\n            amis: true,\n            snapshots: true,\n          },\n        },\n        filter: {\n          type: 'COUNT',\n          value: 2,\n        },\n      }],\n      resourceType: 'AMI_IMAGE',\n      resourceSelection: {\n        recipes: [\n          {\n            name: recipe.name,\n            semanticVersion: recipe.version, // docs say it's optional, but it's not\n          },\n        ],\n      },\n    });\n  }\n\n  private bindComponents(): ImageBuilderComponent[] {\n    if (this.boundComponents.length == 0) {\n      this.boundComponents.push(...this.components.map((c, i) => c._asAwsImageBuilderComponent(this, `Component ${i} ${c.name}`, this.os, this.architecture)));\n    }\n\n    return this.boundComponents;\n  }\n}\n\n/**\n * @internal\n */\nexport class AwsImageBuilderFailedBuildNotifier implements cdk.IAspect {\n  public static createFilteringTopic(scope: Construct, targetTopic: sns.Topic) {\n    const topic = new sns.Topic(scope, 'Image Builder Builds');\n    const filter = new FilterFailedBuildsFunction(scope, 'Image Builder Builds Filter', {\n      logRetention: logs.RetentionDays.ONE_MONTH,\n      environment: {\n        TARGET_TOPIC_ARN: targetTopic.topicArn,\n      },\n    });\n\n    topic.addSubscription(new subs.LambdaSubscription(filter));\n    targetTopic.grantPublish(filter);\n\n    return topic;\n  }\n\n  constructor(private topic: sns.ITopic) {\n  }\n\n  public visit(node: IConstruct): void {\n    if (node instanceof AwsImageBuilderRunnerImageBuilder) {\n      const builder = node as AwsImageBuilderRunnerImageBuilder;\n      const infraNode = builder.node.tryFindChild('Infrastructure');\n      if (infraNode) {\n        const infra = infraNode as imagebuilder.CfnInfrastructureConfiguration;\n        infra.snsTopicArn = this.topic.topicArn;\n      } else {\n        cdk.Annotations.of(builder).addWarning('Unused builder cannot get notifications of failed builds');\n      }\n    }\n  }\n}\n"]}
687
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/builder.ts"],"names":[],"mappings":";;;;;AAAA,mCAAmC;AACnC,6CAeqB;AACrB,iDAAoD;AACpD,mDAAqD;AAErD,+BAAkD;AAClD,qCAAkD;AAClD,2CAAsE;AACtE,+DAA0D;AAC1D,mFAA6E;AAC7E,+CAA0F;AAC1F,uCAA8C;AAC9C,kEAA6D;AAC7D,sCAAoG;AA2GpG;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAa,qBAAsB,SAAQ,+BAAsB;IAa/D,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsC;QAC9E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAHF,WAAM,GAAsB,EAAE,CAAC;QAK9C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAE/B,IAAI,KAAK,GAAU,EAAE,CAAC;QAEtB,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,MAAM,GAAU,EAAE,CAAC;YACvB,IAAI,eAAe,GAAa,EAAE,CAAC;YACnC,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAE9B,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;oBACvB,MAAM,CAAC,IAAI,CAAC;wBACV,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,WAAW;wBAC/B,WAAW,EAAE,KAAK,CAAC,IAAI;qBACxB,CAAC,CAAC;gBACL,CAAC;qBAAM,IAAI,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;oBACpC,MAAM,CAAC,IAAI,CAAC;wBACV,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,WAAW;wBAC/B,WAAW,EAAE,GAAG,KAAK,CAAC,IAAI,MAAM;qBACjC,CAAC,CAAC;oBACH,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;wBACjC,eAAe,CAAC,IAAI,CAAC,mBAAmB,KAAK,CAAC,IAAI,2BAA2B,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC;wBAC5F,eAAe,CAAC,IAAI,CAAC,QAAQ,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC;oBAClD,CAAC;yBAAM,CAAC;wBACN,eAAe,CAAC,IAAI,CAAC,UAAU,KAAK,CAAC,IAAI,aAAa,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC;wBACrE,eAAe,CAAC,IAAI,CAAC,OAAO,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC;oBACjD,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,uBAAuB,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;gBACxD,CAAC;YACH,CAAC;YAED,KAAK,CAAC,IAAI,CAAC;gBACT,IAAI,EAAE,UAAU;gBAChB,MAAM,EAAE,YAAY;gBACpB,MAAM;aACP,CAAC,CAAC;YAEH,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC/B,KAAK,CAAC,IAAI,CAAC;oBACT,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,mBAAmB;oBACxE,MAAM,EAAE;wBACN,QAAQ,EAAE,IAAI,CAAC,+BAA+B,CAAC,KAAK,CAAC,QAAQ,EAAE,eAAe,CAAC;qBAChF;iBACF,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,CAAC,IAAI,CAAC;gBACT,IAAI,EAAE,KAAK;gBACX,MAAM,EAAE,KAAK,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,mBAAmB;gBACxE,MAAM,EAAE;oBACN,QAAQ,EAAE,IAAI,CAAC,+BAA+B,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC;iBAC/E;aACF,CAAC,CAAC;QACL,CAAC;QAED,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,EAAE,CAAC;YAC1B,KAAK,CAAC,IAAI,CAAC;gBACT,IAAI,EAAE,QAAQ;gBACd,MAAM,EAAE,QAAQ;gBAChB,MAAM,EAAE,EAAE;aACX,CAAC,CAAC;QACL,CAAC;QAED,MAAM,IAAI,GAAG;YACX,IAAI,EAAE,KAAK,CAAC,WAAW;YACvB,aAAa,EAAE,KAAK;YACpB,MAAM,EAAE;gBACN;oBACE,IAAI,EAAE,OAAO;oBACb,KAAK;iBACN;aACF;SACF,CAAC;QAEF,MAAM,IAAI,GAAG,IAAA,+BAAsB,EAAC,IAAI,CAAC,CAAC;QAC1C,MAAM,SAAS,GAAG,IAAI,8BAAY,CAAC,YAAY,CAAC,IAAI,EAAE,WAAW,EAAE;YACjE,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,IAAI,EAAE;gBAC/C,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,IAAI;gBACJ,WAAW,EAAE,KAAK,CAAC,WAAW;aAC/B,CAAC;YACF,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC3B,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACH,eAAe,CAAC,OAAuB;QACrC,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,+BAA+B,CAAC,QAA6B,EAAE,QAAkB;QAC/E,IAAI,QAAQ,IAAI,SAAS,EAAE,CAAC;YAC1B,OAAO;gBACL,mCAAmC;gBACnC,4CAA4C;gBAC5C,sBAAsB;aACvB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,OAAO;gBACL,SAAS;aACV,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;;AArIH,sDAsIC;;;AAED;;GAEG;AACH,MAAa,iCAAkC,SAAQ,+BAAsB;IAmB3E,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA+B;QACvE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAPT,oBAAe,GAA4B,EAAE,CAAC;QAS7D,IAAI,KAAK,EAAE,gBAAgB,EAAE,CAAC;YAC5B,yBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,mFAAmF,CAAC,CAAC;QACvH,CAAC;QAED,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,EAAE,IAAI,cAAE,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,YAAY,GAAG,KAAK,EAAE,YAAY,IAAI,wBAAY,CAAC,MAAM,CAAC;QAC/D,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,eAAe,IAAI,sBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,YAAY,GAAG,KAAK,EAAE,YAAY,IAAI,wBAAa,CAAC,SAAS,CAAC;QACnE,IAAI,CAAC,gBAAgB,GAAG,KAAK,EAAE,gBAAgB,IAAI,2BAAa,CAAC,OAAO,CAAC;QACzE,IAAI,CAAC,GAAG,GAAG,KAAK,EAAE,GAAG,IAAI,qBAAG,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC9E,IAAI,CAAC,cAAc,GAAG,KAAK,EAAE,cAAc,IAAI,CAAC,IAAI,qBAAG,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACtG,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,eAAe,CAAC;QAC9C,IAAI,CAAC,SAAS,GAAG,KAAK,EAAE,eAAe,IAAI,IAAA,kCAAsB,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC3E,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,OAAO,IAAI,IAAA,oBAAc,EAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAClF,IAAI,CAAC,YAAY,GAAG,KAAK,EAAE,sBAAsB,EAAE,YAAY,IAAI,qBAAG,CAAC,YAAY,CAAC,EAAE,CAAC,qBAAG,CAAC,aAAa,CAAC,EAAE,EAAE,qBAAG,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACrI,IAAI,CAAC,iBAAiB,GAAG,KAAK,EAAE,sBAAsB,EAAE,iBAAiB,CAAC;QAE1E,wBAAwB;QACxB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;YAC5D,MAAM,IAAI,KAAK,CAAC,yBAAyB,IAAI,CAAC,YAAY,CAAC,IAAI,2CAA2C,IAAI,CAAC,YAAY,MAAM,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,CAAC,CAAC;QACtK,CAAC;QAED,iCAAiC;QACjC,IAAI,KAAK,EAAE,eAAe,EAAE,UAAU,IAAI,qBAAG,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;YAC1E,yBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,8FAA8F;gBAC5H,2DAA2D,CAAC,CAAC;QACjE,CAAC;QAED,uCAAuC;QACvC,IAAI,CAAC,IAAI,GAAG,IAAI,qBAAG,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE;YACrC,SAAS,EAAE,IAAI,qBAAG,CAAC,gBAAgB,CAAC,mBAAmB,CAAC;SACzD,CAAC,CAAC;IACL,CAAC;IAEO,QAAQ;QACd,IAAI,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,cAAE,CAAC,OAAO,CAAC,EAAE,CAAC;YAC3B,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,IAAI,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,cAAE,CAAC,mBAAmB,CAAC,EAAE,CAAC;YACzC,OAAO,OAAO,CAAC;QACjB,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,IAAI,wCAAwC,CAAC,CAAC;IAC9E,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,OAAO,IAAI,CAAC,gBAAgB,CAAC;QAC/B,CAAC;QAED,4CAA4C;QAC5C,MAAM,UAAU,GAAG,IAAI,qBAAG,CAAC,UAAU,CAAC,IAAI,EAAE,YAAY,EAAE;YACxD,eAAe,EAAE,IAAI;YACrB,kBAAkB,EAAE,uBAAa,CAAC,OAAO;YACzC,aAAa,EAAE,2BAAa,CAAC,OAAO;YACpC,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,IAAI,8BAAY,CAAC,4BAA4B,CAAC,IAAI,EAAE,qBAAqB,EAAE;YACtF,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,iCAAiC;YACjC,aAAa,EAAE;gBACb;oBACE,MAAM,EAAE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM;oBAC7B,kCAAkC,EAAE;wBAClC,aAAa,EAAE,CAAC,QAAQ,CAAC;wBACzB,gBAAgB,EAAE;4BAChB,OAAO,EAAE,KAAK;4BACd,cAAc,EAAE,UAAU,CAAC,cAAc;yBAC1C;qBACF;iBACF;aACF;SACF,CAAC,CAAC;QAEH,IAAI,kBAAkB,GAAG;;gCAEG,CAAC;QAE7B,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,CAAC,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;YACjE,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACxB,kBAAkB,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;YAC1D,CAAC;QACH,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,2BAAe,CAAC,IAAI,EAAE,kBAAkB,EAAE;YAC3D,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;YACzB,UAAU,EAAE,IAAI,CAAC,cAAc,EAAE;YACjC,gBAAgB,EAAE,UAAU;YAC5B,kBAAkB,EAAE,kBAAkB;YACtC,WAAW,EAAE,IAAI,CAAC,SAAS;SAC5B,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC;YACtC,qBAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,8BAA8B,CAAC;YAC1E,qBAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,qDAAqD,CAAC;SAClG,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;QACxE,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;QAE7D,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;QAEnD,IAAI,CAAC,gBAAgB,GAAG;YACtB,eAAe,EAAE,UAAU;YAC3B,QAAQ,EAAE,QAAQ;YAClB,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,QAAQ,EAAE,GAAG;YACb,aAAa,EAAE,yBAAa,CAAC,QAAQ,CAAC,SAAS,CAAC;YAChD,oHAAoH;SACrH,CAAC;QAEF,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAEO,kBAAkB,CAAC,MAAuB,EAAE,KAA4B,EAAE,UAA2B;QAC3G,yCAAyC;QACzC,MAAM,SAAS,GAAG,IAAA,uBAAe,EAAC,yCAAkB,EAAE,IAAI,EAAE,aAAa,EAAE;YACzE,WAAW,EAAE,0GAA0G;YACvH,OAAO,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAChC,YAAY,EAAE,sBAAI,CAAC,aAAa,CAAC,SAAS;SAC3C,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,IAAI,qBAAG,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,EAAE;YAC/C,UAAU,EAAE;gBACV,IAAI,qBAAG,CAAC,eAAe,CAAC;oBACtB,OAAO,EAAE,CAAC,yBAAyB,EAAE,qCAAqC,EAAE,0BAA0B,CAAC;oBACvG,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,gDAAgD;iBACnE,CAAC;aACH;SACF,CAAC,CAAC;QACH,SAAS,CAAC,IAAI,EAAE,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAE3C,MAAM,EAAE,GAAG,IAAI,4BAAc,CAAC,IAAI,EAAE,SAAS,EAAE;YAC7C,YAAY,EAAE,SAAS,CAAC,WAAW;YACnC,YAAY,EAAE,sBAAsB;YACpC,UAAU,EAAE;gBACV,QAAQ,EAAE,UAAU,CAAC,cAAc;gBACnC,gBAAgB,EAAE,MAAM,CAAC,IAAI,EAAE,qFAAqF;gBACpH,oHAAoH;gBACpH,UAAU,EAAE,IAAI;aACjB;SACF,CAAC,CAAC;QAEH,sEAAsE;QACtE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC7B,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC9B,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAEjC,gDAAgD;QAChD,IAAI,8BAAY,CAAC,kBAAkB,CAAC,IAAI,EAAE,yBAAyB,EAAE;YACnE,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,WAAW,EAAE,8CAA8C,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YAC3E,aAAa,EAAE,IAAI,qBAAG,CAAC,IAAI,CAAC,IAAI,EAAE,8BAA8B,EAAE;gBAChE,SAAS,EAAE,IAAI,qBAAG,CAAC,gBAAgB,CAAC,4BAA4B,CAAC;gBACjE,cAAc,EAAE;oBACd,EAAE,EAAE,IAAI,qBAAG,CAAC,cAAc,CAAC;wBACzB,UAAU,EAAE;4BACV,IAAI,qBAAG,CAAC,eAAe,CAAC;gCACtB,OAAO,EAAE,CAAC,kBAAkB,EAAE,0BAA0B,CAAC;gCACzD,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,gDAAgD;6BACnE,CAAC;yBACH;qBACF,CAAC;oBACF,GAAG,EAAE,IAAI,qBAAG,CAAC,cAAc,CAAC;wBAC1B,UAAU,EAAE;4BACV,IAAI,qBAAG,CAAC,eAAe,CAAC;gCACtB,OAAO,EAAE,CAAC,mBAAmB,EAAE,sBAAsB,CAAC;gCACtD,SAAS,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC;6BACtC,CAAC;yBACH;qBACF,CAAC;iBACH;aACF,CAAC,CAAC,OAAO;YACV,aAAa,EAAE,CAAC;oBACd,MAAM,EAAE;wBACN,IAAI,EAAE,QAAQ;wBACd,gBAAgB,EAAE;4BAChB,UAAU,EAAE,IAAI;yBACjB;qBACF;oBACD,MAAM,EAAE;wBACN,IAAI,EAAE,OAAO;wBACb,KAAK,EAAE,CAAC;qBACT;iBACF,CAAC;YACF,YAAY,EAAE,iBAAiB;YAC/B,iBAAiB,EAAE;gBACjB,OAAO,EAAE;oBACP;wBACE,IAAI,EAAE,MAAM,CAAC,IAAI;wBACjB,eAAe,EAAE,MAAM,CAAC,OAAO,EAAE,uCAAuC;qBACzE;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAES,SAAS,CAAC,EAAU,EAAE,UAAkB;QAChD,OAAO,IAAI,sBAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,EAAE;YACjC,YAAY,EAAE,qBAAqB,UAAU,EAAE;YAC/C,SAAS,EAAE,IAAI,CAAC,YAAY;YAC5B,aAAa,EAAE,IAAI,CAAC,gBAAgB;SACrC,CAAC,CAAC;IACL,CAAC;IAES,oBAAoB,CAAC,eAAqC;QAClE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,cAAc,CAAC;QAC7B,CAAC;QAED,KAAK,MAAM,aAAa,IAAI,eAAe,EAAE,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YAC7C,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,8BAAY,CAAC,8BAA8B,CAAC,IAAI,EAAE,gBAAgB,EAAE;YAC5F,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,iCAAiC;YACjC,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YACpE,gBAAgB,EAAE,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;YACpE,aAAa,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC7C,uBAAuB,EAAE;gBACvB,UAAU,EAAE,UAAU;gBACtB,kDAAkD;gBAClD,uBAAuB,EAAE,CAAC;aAC3B;YACD,mBAAmB,EAAE,IAAI,qBAAG,CAAC,kBAAkB,CAAC,IAAI,EAAE,kBAAkB,EAAE;gBACxE,KAAK,EAAE;oBACL,IAAI,CAAC,IAAI,CAAC,QAAQ;iBACnB;aACF,CAAC,CAAC,GAAG;SACP,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAES,WAAW,CAAC,KAAkD,EAAE,IAA+C,EAAE,GAAkB,EAC3I,cAAuB,EAAE,kBAA2B;QACpD,MAAM,KAAK,GAAG,IAAI,8BAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,cAAc,EAAE,kBAAkB,CAAC,EAAE;YAChH,8BAA8B,EAAE,KAAK,CAAC,OAAO;YAC7C,4BAA4B,EAAE,IAAI,CAAC,OAAO;YAC1C,cAAc;YACd,kBAAkB;YAClB,uBAAuB,EAAE;gBACvB,iBAAiB,EAAE,KAAK;aACzB;SACF,CAAC,CAAC;QACH,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QAE9B,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,gBAAgB,CAAC,MAAc,EAAE,cAAuB,EAAE,kBAA2B;QAC3F,IAAI,cAAc,EAAE,CAAC;YACnB,OAAO,OAAO,MAAM,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,kBAAkB,EAAE,CAAC;YACvB,OAAO,UAAU,MAAM,EAAE,CAAC;QAC5B,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;IACjF,CAAC;IAES,cAAc,CAAC,KAAkD,EAAE,IAA+C,EAAE,GAAkB,EAC9I,cAAuB,EAAE,kBAA2B;QACpD,IAAI,eAA2E,CAAC;QAChF,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC;YACtC,eAAe,GAAG;gBAChB,kBAAkB,EAAE,wBAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,gBAAgB;gBAC/E,+BAA+B,EAAE,uBAAuB;aACzD,CAAC;QACJ,CAAC;QACD,MAAM,QAAQ,GAAG,IAAI,8BAAY,CAAC,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,cAAc,EAAE,kBAAkB,CAAC,EAAE;YAC9H,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,iCAAiC;YACjC,8BAA8B,EAAE,KAAK,CAAC,OAAO;YAC7C,4BAA4B,EAAE,IAAI,CAAC,OAAO;YAC1C,cAAc;YACd,kBAAkB;YAClB,QAAQ,EAAE,eAAe;YACzB,uBAAuB,EAAE;gBACvB,iBAAiB,EAAE,KAAK;aACzB;SACF,CAAC,CAAC;QACH,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACnC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QAEjC,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;OAEG;IACH,IAAW,WAAW;QACpB,OAAO,IAAI,qBAAG,CAAC,WAAW,CAAC,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,QAAQ,CAAC;QACvB,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,qBAAG,CAAC,cAAc,CAAC,IAAI,EAAE,iBAAiB,EAAE;YACrE,aAAa,EAAE,IAAI;SACpB,CAAC,CAAC;QAEH,MAAM,qBAAqB,GAAoF,CAAC;gBAC9G,gBAAgB,EAAE,cAAc,CAAC,gBAAgB;gBACjD,iBAAiB,EAAE,IAAI;aACxB,CAAC,CAAC;QACH,MAAM,iBAAiB,GAAgF,EAAE,CAAC;QAE1G,IAAI,IAAI,CAAC,iBAAiB,EAAE,OAAO,IAAI,KAAK,EAAE,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,cAAE,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;YAC/D,CAAC;YAED,wDAAwD;YACxD,uCAAuC;YACvC,uMAAuM;YACvM,sFAAsF;YACtF,6IAA6I;YAC7I,MAAM,kBAAkB,GAAG,IAAI,qBAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,sBAAsB,EAAE;gBACjF,kBAAkB,EAAE;oBAClB,eAAe,EAAE;wBACf,UAAU,EAAE,UAAU;qBACvB;oBACD,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE;oBAC1C,iBAAiB,EAAE,CAAC;4BAClB,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;4BACpE,WAAW,EAAE,CAAC;4BACd,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;yBAC1D,CAAC;oBACF,iBAAiB,EAAE;wBACjB;4BACE,YAAY,EAAE,UAAU;4BACxB,IAAI,EAAE,CAAC;oCACL,GAAG,EAAE,MAAM;oCACX,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,uBAAuB;iCAChD,CAAC;yBACH;wBACD;4BACE,YAAY,EAAE,QAAQ;4BACtB,IAAI,EAAE,CAAC;oCACL,GAAG,EAAE,MAAM;oCACX,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,uBAAuB;iCAChD,CAAC;yBACH;qBACF;iBACF;gBACD,iBAAiB,EAAE,CAAC;wBAClB,YAAY,EAAE,iBAAiB;wBAC/B,IAAI,EAAE,CAAC;gCACL,GAAG,EAAE,MAAM;gCACX,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,uBAAuB;6BAChD,CAAC;qBACH,CAAC;aACH,CAAC,CAAC;YAEH,qBAAqB,CAAC,IAAI,CAAC;gBACzB,gBAAgB,EAAE,kBAAkB,CAAC,oBAAoB;gBACzD,iBAAiB,EAAE,IAAI;aACxB,CAAC,CAAC;YACH,iBAAiB,CAAC,IAAI,CAAC;gBACrB,OAAO,EAAE,IAAI;gBACb,cAAc,EAAE;oBACd,gBAAgB,EAAE,kBAAkB,CAAC,oBAAoB;iBAC1D;gBACD,mBAAmB,EAAE,IAAI,CAAC,iBAAiB,EAAE,mBAAmB,IAAI,CAAC;gBACrE,qBAAqB,EAAE;oBACrB,mBAAmB,EAAE,IAAI,CAAC,iBAAiB,EAAE,mBAAmB,IAAI,CAAC;iBACtE;aACF,CAAC,CAAC;QACL,CAAC;QAED,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;QAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QAEnC,MAAM,IAAI,GAAG,IAAI,8BAAY,CAAC,4BAA4B,CAAC,IAAI,EAAE,kBAAkB,EAAE;YACnF,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,iCAAiC;YACjC,aAAa,EAAE;gBACb;oBACE,MAAM,EAAE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM;oBAC7B,4BAA4B,EAAE;wBAC5B,IAAI,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,EAAE;4BAC1C,SAAS,EAAE,GAAG;4BACd,SAAS,EAAE,GAAG;4BACd,wBAAwB,EAAE,IAAI;yBAC/B,CAAC,+BAA+B;wBACjC,OAAO,EAAE;4BACP,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE;4BACpB,qBAAqB,EAAE,SAAS;4BAChC,uBAAuB,EAAE,WAAW;yBACrC;qBACF;oBACD,4BAA4B,EAAE,qBAAqB;oBACnD,wBAAwB,EAAE,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,SAAS;iBACvF;aACF;SACF,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,IAAI,EAAE,YAAY,EAAE;YAC/C,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;YACzB,UAAU,EAAE,IAAI,CAAC,cAAc,EAAE;YACjC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;QACnD,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC;YACtC,qBAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,8BAA8B,CAAC;YAC1E,qBAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,mCAAmC,CAAC;SAChF,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC1D,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAE7D,IAAI,CAAC,QAAQ,GAAG;YACd,cAAc,EAAE,cAAc;YAC9B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,QAAQ,EAAE,GAAG;YACb,aAAa,EAAE,yBAAa,CAAC,QAAQ,CAAC,SAAS,CAAC;SACjD,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QAEhD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAEO,UAAU,CAAC,MAAiB,EAAE,SAAiB,EAAE,WAAmB;QAC1E,MAAM,OAAO,GAAG,IAAA,uBAAe,EAAC,uCAAiB,EAAE,IAAI,EAAE,YAAY,EAAE;YACrE,WAAW,EAAE,+BAA+B;YAC5C,aAAa,EAAE;gBACb,IAAI,qBAAG,CAAC,eAAe,CAAC;oBACtB,OAAO,EAAE,CAAC,oBAAoB,CAAC;oBAC/B,SAAS,EAAE,CAAC,GAAG,CAAC;iBACjB,CAAC;gBACF,IAAI,qBAAG,CAAC,eAAe,CAAC;oBACtB,OAAO,EAAE,CAAC,qBAAqB,EAAE,oBAAoB,CAAC;oBACtD,SAAS,EAAE,CAAC,GAAG,CAAC;oBAChB,UAAU,EAAE;wBACV,YAAY,EAAE;4BACZ,qCAAqC,EAAE,SAAS;yBACjD;qBACF;iBACF,CAAC;aACH;YACD,OAAO,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAChC,YAAY,EAAE,sBAAI,CAAC,aAAa,CAAC,SAAS;SAC3C,CAAC,CAAC;QAEH,iDAAiD;QACjD,IAAI,4BAAc,CAAC,IAAI,EAAE,aAAa,EAAE;YACtC,YAAY,EAAE,OAAO,CAAC,WAAW;YACjC,YAAY,EAAE,oBAAoB;YAClC,UAAU,EAAE;gBACV,SAAS,EAAE,SAAS;gBACpB,WAAW,EAAE,WAAW;aACzB;SACF,CAAC,CAAC;QAEH,uCAAuC;QACvC,IAAI,8BAAY,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,EAAE;YAChE,IAAI,EAAE,IAAA,+BAAsB,EAAC,IAAI,CAAC;YAClC,WAAW,EAAE,qCAAqC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YAClE,aAAa,EAAE,IAAI,qBAAG,CAAC,IAAI,CAAC,IAAI,EAAE,2BAA2B,EAAE;gBAC7D,SAAS,EAAE,IAAI,qBAAG,CAAC,gBAAgB,CAAC,4BAA4B,CAAC;gBACjE,cAAc,EAAE;oBACd,EAAE,EAAE,IAAI,qBAAG,CAAC,cAAc,CAAC;wBACzB,UAAU,EAAE;4BACV,IAAI,qBAAG,CAAC,eAAe,CAAC;gCACtB,OAAO,EAAE,CAAC,kBAAkB,EAAE,0BAA0B,CAAC;gCACzD,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,gDAAgD;6BACnE,CAAC;yBACH;qBACF,CAAC;oBACF,GAAG,EAAE,IAAI,qBAAG,CAAC,cAAc,CAAC;wBAC1B,UAAU,EAAE;4BACV,IAAI,qBAAG,CAAC,eAAe,CAAC;gCACtB,OAAO,EAAE,CAAC,oBAAoB,EAAE,4BAA4B,CAAC;gCAC7D,SAAS,EAAE,CAAC,GAAG,CAAC;6BACjB,CAAC;4BACF,IAAI,qBAAG,CAAC,eAAe,CAAC;gCACtB,OAAO,EAAE,CAAC,qBAAqB,EAAE,oBAAoB,CAAC;gCACtD,SAAS,EAAE,CAAC,GAAG,CAAC;gCAChB,UAAU,EAAE;oCACV,YAAY,EAAE;wCACZ,qCAAqC,EAAE,SAAS;wCAChD,uCAAuC,EAAE,WAAW;qCACrD;iCACF;6BACF,CAAC;yBACH;qBACF,CAAC;iBACH;aACF,CAAC,CAAC,OAAO;YACV,aAAa,EAAE,CAAC;oBACd,MAAM,EAAE;wBACN,IAAI,EAAE,QAAQ;wBACd,gBAAgB,EAAE;4BAChB,IAAI,EAAE,IAAI;4BACV,SAAS,EAAE,IAAI;yBAChB;qBACF;oBACD,MAAM,EAAE;wBACN,IAAI,EAAE,OAAO;wBACb,KAAK,EAAE,CAAC;qBACT;iBACF,CAAC;YACF,YAAY,EAAE,WAAW;YACzB,iBAAiB,EAAE;gBACjB,OAAO,EAAE;oBACP;wBACE,IAAI,EAAE,MAAM,CAAC,IAAI;wBACjB,eAAe,EAAE,MAAM,CAAC,OAAO,EAAE,uCAAuC;qBACzE;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,2BAA2B,CAAC,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC3J,CAAC;QAED,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;CACF;AAnjBD,8EAmjBC;AAED;;GAEG;AACH,MAAa,kCAAkC;IACtC,MAAM,CAAC,oBAAoB,CAAC,KAAgB,EAAE,WAAsB;QACzE,MAAM,KAAK,GAAG,IAAI,qBAAG,CAAC,KAAK,CAAC,KAAK,EAAE,sBAAsB,CAAC,CAAC;QAC3D,MAAM,MAAM,GAAG,IAAI,0DAA0B,CAAC,KAAK,EAAE,6BAA6B,EAAE;YAClF,YAAY,EAAE,sBAAI,CAAC,aAAa,CAAC,SAAS;YAC1C,WAAW,EAAE;gBACX,gBAAgB,EAAE,WAAW,CAAC,QAAQ;aACvC;SACF,CAAC,CAAC;QAEH,KAAK,CAAC,eAAe,CAAC,IAAI,mCAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC;QAC3D,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEjC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,YAAoB,KAAiB;QAAjB,UAAK,GAAL,KAAK,CAAY;IACrC,CAAC;IAEM,KAAK,CAAC,IAAgB;QAC3B,IAAI,IAAI,YAAY,iCAAiC,EAAE,CAAC;YACtD,MAAM,OAAO,GAAG,IAAyC,CAAC;YAC1D,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;YAC9D,IAAI,SAAS,EAAE,CAAC;gBACd,MAAM,KAAK,GAAG,SAAwD,CAAC;gBACvE,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YAC1C,CAAC;iBAAM,CAAC;gBACN,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,0DAA0D,CAAC,CAAC;YACrG,CAAC;QACH,CAAC;IACH,CAAC;CACF;AA/BD,gFA+BC","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  Annotations,\n  aws_ec2 as ec2,\n  aws_ecr as ecr,\n  aws_events as events,\n  aws_iam as iam,\n  aws_imagebuilder as imagebuilder,\n  aws_logs as logs,\n  aws_s3_assets as s3_assets,\n  aws_sns as sns,\n  aws_sns_subscriptions as subs,\n  CustomResource,\n  Duration,\n  RemovalPolicy,\n  Stack,\n} from 'aws-cdk-lib';\nimport { TagMutability } from 'aws-cdk-lib/aws-ecr';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct, IConstruct } from 'constructs';\nimport { AmiRecipe, defaultBaseAmi } from './ami';\nimport { ImageBuilderObjectBase } from './common';\nimport { ContainerRecipe, defaultBaseDockerImage } from './container';\nimport { DeleteAmiFunction } from './delete-ami-function';\nimport { FilterFailedBuildsFunction } from './filter-failed-builds-function';\nimport { Architecture, Os, RunnerAmi, RunnerImage, RunnerVersion } from '../../providers';\nimport { singletonLambda } from '../../utils';\nimport { BuildImageFunction } from '../build-image-function';\nimport { RunnerImageBuilderBase, RunnerImageBuilderProps, uniqueImageBuilderName } from '../common';\n\nexport interface AwsImageBuilderRunnerImageBuilderProps {\n  /**\n   * The instance type used to build the image.\n   *\n   * @default m5.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n\n  /**\n   * Options for fast launch.\n   *\n   * This is only supported for Windows AMIs.\n   *\n   * @default disabled\n   */\n  readonly fastLaunchOptions?: FastLaunchOptions;\n}\n\n/**\n * Options for fast launch.\n */\nexport interface FastLaunchOptions {\n  /**\n   * Enable fast launch for AMIs generated by this builder. It creates a snapshot of the root volume and uses it to launch new instances faster.\n   *\n   * This is only supported for Windows AMIs.\n   *\n   * @note this feature comes with additional resource costs. See the documentation for more details. https://docs.aws.amazon.com/AWSEC2/latest/WindowsGuide/win-fast-launch-manage-costs.html\n   * @note enabling fast launch on an existing builder will not enable it for existing AMIs. It will only affect new AMIs. If you want immediate effect, trigger a new image build. Alternatively, you can create a new builder with fast launch enabled and use it for new AMIs.\n   *\n   * @default false\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * The maximum number of parallel instances that are launched for creating resources.\n   *\n   * Must be at least 6.\n   *\n   * @default 6\n   */\n  readonly maxParallelLaunches?: number;\n\n  /**\n   * The number of pre-provisioned snapshots to keep on hand for a fast-launch enabled Windows AMI.\n   *\n   * @default 1\n   */\n  readonly targetResourceCount?: number;\n}\n\n/**\n * An asset including file or directory to place inside the built image.\n */\nexport interface ImageBuilderAsset {\n  /**\n   * Path to place asset in the image.\n   */\n  readonly path: string;\n\n  /**\n   * Asset to place in the image.\n   */\n  readonly asset: s3_assets.Asset;\n}\n\n/**\n * Properties for ImageBuilderComponent construct.\n */\nexport interface ImageBuilderComponentProperties {\n  /**\n   * Component platform. Must match the builder platform.\n   */\n  readonly platform: 'Linux' | 'Windows';\n\n  /**\n   * Component display name.\n   */\n  readonly displayName: string;\n\n  /**\n   * Component description.\n   */\n  readonly description: string;\n\n  /**\n   * Shell commands to run when adding this component to the image.\n   *\n   * On Linux, these are bash commands. On Windows, there are PowerShell commands.\n   */\n  readonly commands: string[];\n\n  /**\n   * Optional assets to add to the built image.\n   */\n  readonly assets?: ImageBuilderAsset[];\n\n  /**\n   * Require a reboot after installing this component.\n   *\n   * @default false\n   */\n  readonly reboot?: boolean;\n}\n\n/**\n * Components are a set of commands to run and optional files to add to an image. Components are the building blocks of images built by Image Builder.\n *\n * Example:\n *\n * ```\n * new ImageBuilderComponent(this, 'AWS CLI', {\n *   platform: 'Windows',\n *   displayName: 'AWS CLI',\n *   description: 'Install latest version of AWS CLI',\n *   commands: [\n *     '$p = Start-Process msiexec.exe -PassThru -Wait -ArgumentList \\'/i https://awscli.amazonaws.com/AWSCLIV2.msi /qn\\'',\n *     'if ($p.ExitCode -ne 0) { throw \"Exit code is $p.ExitCode\" }',\n *   ],\n * }\n * ```\n *\n * @deprecated Use `RunnerImageComponent` instead as this be internal soon.\n */\nexport class ImageBuilderComponent extends ImageBuilderObjectBase {\n  /**\n   * Component ARN.\n   */\n  public readonly arn: string;\n\n  /**\n   * Supported platform for the component.\n   */\n  public readonly platform: 'Windows' | 'Linux';\n\n  private readonly assets: s3_assets.Asset[] = [];\n\n  constructor(scope: Construct, id: string, props: ImageBuilderComponentProperties) {\n    super(scope, id);\n\n    this.platform = props.platform;\n\n    let steps: any[] = [];\n\n    if (props.assets) {\n      let inputs: any[] = [];\n      let extractCommands: string[] = [];\n      for (const asset of props.assets) {\n        this.assets.push(asset.asset);\n\n        if (asset.asset.isFile) {\n          inputs.push({\n            source: asset.asset.s3ObjectUrl,\n            destination: asset.path,\n          });\n        } else if (asset.asset.isZipArchive) {\n          inputs.push({\n            source: asset.asset.s3ObjectUrl,\n            destination: `${asset.path}.zip`,\n          });\n          if (props.platform === 'Windows') {\n            extractCommands.push(`Expand-Archive \"${asset.path}.zip\" -DestinationPath \"${asset.path}\"`);\n            extractCommands.push(`del \"${asset.path}.zip\"`);\n          } else {\n            extractCommands.push(`unzip \"${asset.path}.zip\" -d \"${asset.path}\"`);\n            extractCommands.push(`rm \"${asset.path}.zip\"`);\n          }\n        } else {\n          throw new Error(`Unknown asset type: ${asset.asset}`);\n        }\n      }\n\n      steps.push({\n        name: 'Download',\n        action: 'S3Download',\n        inputs,\n      });\n\n      if (extractCommands.length > 0) {\n        steps.push({\n          name: 'Extract',\n          action: props.platform === 'Linux' ? 'ExecuteBash' : 'ExecutePowerShell',\n          inputs: {\n            commands: this.prefixCommandsWithErrorHandling(props.platform, extractCommands),\n          },\n        });\n      }\n    }\n\n    if (props.commands.length > 0) {\n      steps.push({\n        name: 'Run',\n        action: props.platform === 'Linux' ? 'ExecuteBash' : 'ExecutePowerShell',\n        inputs: {\n          commands: this.prefixCommandsWithErrorHandling(props.platform, props.commands),\n        },\n      });\n    }\n\n    if (props.reboot ?? false) {\n      steps.push({\n        name: 'Reboot',\n        action: 'Reboot',\n        inputs: {},\n      });\n    }\n\n    const data = {\n      name: props.displayName,\n      schemaVersion: '1.0',\n      phases: [\n        {\n          name: 'build',\n          steps,\n        },\n      ],\n    };\n\n    const name = uniqueImageBuilderName(this);\n    const component = new imagebuilder.CfnComponent(this, 'Component', {\n      name: name,\n      description: props.description,\n      platform: props.platform,\n      version: this.generateVersion('Component', name, {\n        platform: props.platform,\n        data,\n        description: props.description,\n      }),\n      data: JSON.stringify(data),\n    });\n\n    this.arn = component.attrArn;\n  }\n\n  /**\n   * Grants read permissions to the principal on the assets buckets.\n   *\n   * @param grantee\n   */\n  grantAssetsRead(grantee: iam.IGrantable) {\n    for (const asset of this.assets) {\n      asset.grantRead(grantee);\n    }\n  }\n\n  prefixCommandsWithErrorHandling(platform: 'Windows' | 'Linux', commands: string[]) {\n    if (platform == 'Windows') {\n      return [\n        '$ErrorActionPreference = \\'Stop\\'',\n        '$ProgressPreference = \\'SilentlyContinue\\'',\n        'Set-PSDebug -Trace 1',\n      ].concat(commands);\n    } else {\n      return [\n        'set -ex',\n      ].concat(commands);\n    }\n  }\n}\n\n/**\n * @internal\n */\nexport class AwsImageBuilderRunnerImageBuilder extends RunnerImageBuilderBase {\n  private boundDockerImage?: RunnerImage;\n  private boundAmi?: RunnerAmi;\n  private readonly os: Os;\n  private readonly architecture: Architecture;\n  private readonly baseImage: string;\n  private readonly baseAmi: string;\n  private readonly logRetention: RetentionDays;\n  private readonly logRemovalPolicy: RemovalPolicy;\n  private readonly vpc: ec2.IVpc;\n  private readonly securityGroups: ec2.ISecurityGroup[];\n  private readonly subnetSelection: ec2.SubnetSelection | undefined;\n  private readonly rebuildInterval: cdk.Duration;\n  private readonly boundComponents: ImageBuilderComponent[] = [];\n  private readonly instanceType: ec2.InstanceType;\n  private infrastructure: imagebuilder.CfnInfrastructureConfiguration | undefined;\n  private readonly role: iam.Role;\n  private readonly fastLaunchOptions?: FastLaunchOptions;\n\n  constructor(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    super(scope, id, props);\n\n    if (props?.codeBuildOptions) {\n      Annotations.of(this).addWarning('codeBuildOptions are ignored when using AWS Image Builder to build runner images.');\n    }\n\n    this.os = props?.os ?? Os.LINUX_UBUNTU;\n    this.architecture = props?.architecture ?? Architecture.X86_64;\n    this.rebuildInterval = props?.rebuildInterval ?? Duration.days(7);\n    this.logRetention = props?.logRetention ?? RetentionDays.ONE_MONTH;\n    this.logRemovalPolicy = props?.logRemovalPolicy ?? RemovalPolicy.DESTROY;\n    this.vpc = props?.vpc ?? ec2.Vpc.fromLookup(this, 'VPC', { isDefault: true });\n    this.securityGroups = props?.securityGroups ?? [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })];\n    this.subnetSelection = props?.subnetSelection;\n    this.baseImage = props?.baseDockerImage ?? defaultBaseDockerImage(this.os);\n    this.baseAmi = props?.baseAmi ?? defaultBaseAmi(this, this.os, this.architecture);\n    this.instanceType = props?.awsImageBuilderOptions?.instanceType ?? ec2.InstanceType.of(ec2.InstanceClass.M5, ec2.InstanceSize.LARGE);\n    this.fastLaunchOptions = props?.awsImageBuilderOptions?.fastLaunchOptions;\n\n    // confirm instance type\n    if (!this.architecture.instanceTypeMatch(this.instanceType)) {\n      throw new Error(`Builder architecture (${this.architecture.name}) doesn't match selected instance type (${this.instanceType} / ${this.instanceType.architecture})`);\n    }\n\n    // warn against isolated networks\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PRIVATE_ISOLATED) {\n      Annotations.of(this).addWarning('Private isolated subnets cannot pull from public ECR and VPC endpoint is not supported yet. ' +\n        'See https://github.com/aws/containers-roadmap/issues/1160');\n    }\n\n    // role to be used by AWS Image Builder\n    this.role = new iam.Role(this, 'Role', {\n      assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n    });\n  }\n\n  private platform() {\n    if (this.os.is(Os.WINDOWS)) {\n      return 'Windows';\n    }\n    if (this.os.isIn(Os._ALL_LINUX_VERSIONS)) {\n      return 'Linux';\n    }\n    throw new Error(`OS ${this.os.name} is not supported by AWS Image Builder`);\n  }\n\n  /**\n   * Called by IRunnerProvider to finalize settings and create the image builder.\n   */\n  bindDockerImage(): RunnerImage {\n    if (this.boundDockerImage) {\n      return this.boundDockerImage;\n    }\n\n    // create repository that only keeps one tag\n    const repository = new ecr.Repository(this, 'Repository', {\n      imageScanOnPush: true,\n      imageTagMutability: TagMutability.MUTABLE,\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteImages: true,\n    });\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'Docker Distribution', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          containerDistributionConfiguration: {\n            ContainerTags: ['latest'],\n            TargetRepository: {\n              Service: 'ECR',\n              RepositoryName: repository.repositoryName,\n            },\n          },\n        },\n      ],\n    });\n\n    let dockerfileTemplate = `FROM {{{ imagebuilder:parentImage }}}\n{{{ imagebuilder:environments }}}\n{{{ imagebuilder:components }}}`;\n\n    for (const c of this.components) {\n      const commands = c.getDockerCommands(this.os, this.architecture);\n      if (commands.length > 0) {\n        dockerfileTemplate += '\\n' + commands.join('\\n') + '\\n';\n      }\n    }\n\n    const recipe = new ContainerRecipe(this, 'Container Recipe', {\n      platform: this.platform(),\n      components: this.bindComponents(),\n      targetRepository: repository,\n      dockerfileTemplate: dockerfileTemplate,\n      parentImage: this.baseImage,\n    });\n\n    const log = this.createLog('Docker Log', recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilderECRContainerBuilds'),\n    ]);\n    const image = this.createImage(infra, dist, log, undefined, recipe.arn);\n    this.createPipeline(infra, dist, log, undefined, recipe.arn);\n\n    this.dockerImageCleaner(recipe, image, repository);\n\n    this.boundDockerImage = {\n      imageRepository: repository,\n      imageTag: 'latest',\n      os: this.os,\n      architecture: this.architecture,\n      logGroup: log,\n      runnerVersion: RunnerVersion.specific('unknown'),\n      // no dependable as CloudFormation will fail to get image ARN once the image is deleted (we delete old images daily)\n    };\n\n    return this.boundDockerImage;\n  }\n\n  private dockerImageCleaner(recipe: ContainerRecipe, image: imagebuilder.CfnImage, repository: ecr.IRepository) {\n    // delete all left over dockers images on\n    const crHandler = singletonLambda(BuildImageFunction, this, 'build-image', {\n      description: 'Custom resource handler that triggers CodeBuild to build runner images, and cleans-up images on deletion',\n      timeout: cdk.Duration.minutes(3),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    const policy = new iam.Policy(this, 'CR Policy', {\n      statements: [\n        new iam.PolicyStatement({\n          actions: ['imagebuilder:ListImages', 'imagebuilder:ListImageBuildVersions', 'imagebuilder:DeleteImage'],\n          resources: ['*'], // Image Builder doesn't support scoping this :(\n        }),\n      ],\n    });\n    crHandler.role?.attachInlinePolicy(policy);\n\n    const cr = new CustomResource(this, 'Deleter', {\n      serviceToken: crHandler.functionArn,\n      resourceType: 'Custom::ImageDeleter',\n      properties: {\n        RepoName: repository.repositoryName,\n        ImageBuilderName: recipe.name, // we don't use image.name because CloudFormation complains if it was deleted already\n        // TODO pass version too and then when a new version is deployed, it will delete the old one (careful with upgrades)\n        DeleteOnly: true,\n      },\n    });\n\n    // add dependencies to make sure resources are there when we need them\n    cr.node.addDependency(image);\n    cr.node.addDependency(policy);\n    cr.node.addDependency(crHandler);\n\n    // delete old docker images + IB resources daily\n    new imagebuilder.CfnLifecyclePolicy(this, 'Lifecycle Policy Docker', {\n      name: uniqueImageBuilderName(this),\n      description: `Delete old GitHub Runner Docker images for ${this.node.path}`,\n      executionRole: new iam.Role(this, 'Lifecycle Policy Docker Role', {\n        assumedBy: new iam.ServicePrincipal('imagebuilder.amazonaws.com'),\n        inlinePolicies: {\n          ib: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['tag:GetResources', 'imagebuilder:DeleteImage'],\n                resources: ['*'], // Image Builder doesn't support scoping this :(\n              }),\n            ],\n          }),\n          ecr: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['ecr:BatchGetImage', 'ecr:BatchDeleteImage'],\n                resources: [repository.repositoryArn],\n              }),\n            ],\n          }),\n        },\n      }).roleArn,\n      policyDetails: [{\n        action: {\n          type: 'DELETE',\n          includeResources: {\n            containers: true,\n          },\n        },\n        filter: {\n          type: 'COUNT',\n          value: 2,\n        },\n      }],\n      resourceType: 'CONTAINER_IMAGE',\n      resourceSelection: {\n        recipes: [\n          {\n            name: recipe.name,\n            semanticVersion: recipe.version, // docs say it's optional, but it's not\n          },\n        ],\n      },\n    });\n  }\n\n  protected createLog(id: string, recipeName: string): logs.LogGroup {\n    return new logs.LogGroup(this, id, {\n      logGroupName: `/aws/imagebuilder/${recipeName}`,\n      retention: this.logRetention,\n      removalPolicy: this.logRemovalPolicy,\n    });\n  }\n\n  protected createInfrastructure(managedPolicies: iam.IManagedPolicy[]): imagebuilder.CfnInfrastructureConfiguration {\n    if (this.infrastructure) {\n      return this.infrastructure;\n    }\n\n    for (const managedPolicy of managedPolicies) {\n      this.role.addManagedPolicy(managedPolicy);\n    }\n\n    for (const component of this.boundComponents) {\n      component.grantAssetsRead(this.role);\n    }\n\n    this.infrastructure = new imagebuilder.CfnInfrastructureConfiguration(this, 'Infrastructure', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      subnetId: this.vpc?.selectSubnets(this.subnetSelection).subnetIds[0],\n      securityGroupIds: this.securityGroups?.map(sg => sg.securityGroupId),\n      instanceTypes: [this.instanceType.toString()],\n      instanceMetadataOptions: {\n        httpTokens: 'required',\n        // Container builds require a minimum of two hops.\n        httpPutResponseHopLimit: 2,\n      },\n      instanceProfileName: new iam.CfnInstanceProfile(this, 'Instance Profile', {\n        roles: [\n          this.role.roleName,\n        ],\n      }).ref,\n    });\n\n    return this.infrastructure;\n  }\n\n  protected createImage(infra: imagebuilder.CfnInfrastructureConfiguration, dist: imagebuilder.CfnDistributionConfiguration, log: logs.LogGroup,\n    imageRecipeArn?: string, containerRecipeArn?: string): imagebuilder.CfnImage {\n    const image = new imagebuilder.CfnImage(this, this.amiOrContainerId('Image', imageRecipeArn, containerRecipeArn), {\n      infrastructureConfigurationArn: infra.attrArn,\n      distributionConfigurationArn: dist.attrArn,\n      imageRecipeArn,\n      containerRecipeArn,\n      imageTestsConfiguration: {\n        imageTestsEnabled: false,\n      },\n    });\n    image.node.addDependency(infra);\n    image.node.addDependency(log);\n\n    return image;\n  }\n\n  private amiOrContainerId(baseId: string, imageRecipeArn?: string, containerRecipeArn?: string) {\n    if (imageRecipeArn) {\n      return `AMI ${baseId}`;\n    }\n    if (containerRecipeArn) {\n      return `Docker ${baseId}`;\n    }\n    throw new Error('Either imageRecipeArn or containerRecipeArn must be defined');\n  }\n\n  protected createPipeline(infra: imagebuilder.CfnInfrastructureConfiguration, dist: imagebuilder.CfnDistributionConfiguration, log: logs.LogGroup,\n    imageRecipeArn?: string, containerRecipeArn?: string): imagebuilder.CfnImagePipeline {\n    let scheduleOptions: imagebuilder.CfnImagePipeline.ScheduleProperty | undefined;\n    if (this.rebuildInterval.toDays() > 0) {\n      scheduleOptions = {\n        scheduleExpression: events.Schedule.rate(this.rebuildInterval).expressionString,\n        pipelineExecutionStartCondition: 'EXPRESSION_MATCH_ONLY',\n      };\n    }\n    const pipeline = new imagebuilder.CfnImagePipeline(this, this.amiOrContainerId('Pipeline', imageRecipeArn, containerRecipeArn), {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      infrastructureConfigurationArn: infra.attrArn,\n      distributionConfigurationArn: dist.attrArn,\n      imageRecipeArn,\n      containerRecipeArn,\n      schedule: scheduleOptions,\n      imageTestsConfiguration: {\n        imageTestsEnabled: false,\n      },\n    });\n    pipeline.node.addDependency(infra);\n    pipeline.node.addDependency(log);\n\n    return pipeline;\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return new ec2.Connections({ securityGroups: this.securityGroups });\n  }\n\n  public get grantPrincipal(): iam.IPrincipal {\n    return this.role;\n  }\n\n  bindAmi(): RunnerAmi {\n    if (this.boundAmi) {\n      return this.boundAmi;\n    }\n\n    const launchTemplate = new ec2.LaunchTemplate(this, 'Launch template', {\n      requireImdsv2: true,\n    });\n\n    const launchTemplateConfigs: imagebuilder.CfnDistributionConfiguration.LaunchTemplateConfigurationProperty[] = [{\n      launchTemplateId: launchTemplate.launchTemplateId,\n      setDefaultVersion: true,\n    }];\n    const fastLaunchConfigs: imagebuilder.CfnDistributionConfiguration.FastLaunchConfigurationProperty[] = [];\n\n    if (this.fastLaunchOptions?.enabled ?? false) {\n      if (!this.os.is(Os.WINDOWS)) {\n        throw new Error('Fast launch is only supported for Windows');\n      }\n\n      // create a separate launch template for fast launch so:\n      //  - settings don't affect the runners\n      //  - enabling fast launch on an existing builder works (without a new launch template, EC2 Image Builder will use the first version of the launch template, which doesn't have instance or VPC config)\n      //  - setting vpc + subnet on the main launch template will cause RunInstances to fail\n      //  - EC2 Image Builder seems to get confused with which launch template version to base any new version on, so a new template is always best\n      const fastLaunchTemplate = new ec2.CfnLaunchTemplate(this, 'Fast Launch Template', {\n        launchTemplateData: {\n          metadataOptions: {\n            httpTokens: 'required',\n          },\n          instanceType: this.instanceType.toString(),\n          networkInterfaces: [{\n            subnetId: this.vpc?.selectSubnets(this.subnetSelection).subnetIds[0],\n            deviceIndex: 0,\n            groups: this.securityGroups.map(sg => sg.securityGroupId),\n          }],\n          tagSpecifications: [\n            {\n              resourceType: 'instance',\n              tags: [{\n                key: 'Name',\n                value: `${this.node.path}/Fast Launch Instance`,\n              }],\n            },\n            {\n              resourceType: 'volume',\n              tags: [{\n                key: 'Name',\n                value: `${this.node.path}/Fast Launch Instance`,\n              }],\n            },\n          ],\n        },\n        tagSpecifications: [{\n          resourceType: 'launch-template',\n          tags: [{\n            key: 'Name',\n            value: `${this.node.path}/Fast Launch Template`,\n          }],\n        }],\n      });\n\n      launchTemplateConfigs.push({\n        launchTemplateId: fastLaunchTemplate.attrLaunchTemplateId,\n        setDefaultVersion: true,\n      });\n      fastLaunchConfigs.push({\n        enabled: true,\n        launchTemplate: {\n          launchTemplateId: fastLaunchTemplate.attrLaunchTemplateId,\n        },\n        maxParallelLaunches: this.fastLaunchOptions?.maxParallelLaunches ?? 6,\n        snapshotConfiguration: {\n          targetResourceCount: this.fastLaunchOptions?.targetResourceCount ?? 1,\n        },\n      });\n    }\n\n    const stackName = cdk.Stack.of(this).stackName;\n    const builderName = this.node.path;\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'AMI Distribution', {\n      name: uniqueImageBuilderName(this),\n      // description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          amiDistributionConfiguration: {\n            Name: `${cdk.Names.uniqueResourceName(this, {\n              maxLength: 100,\n              separator: '-',\n              allowedSpecialCharacters: '_-',\n            })}-{{ imagebuilder:buildDate }}`,\n            AmiTags: {\n              'Name': this.node.id,\n              'GitHubRunners:Stack': stackName,\n              'GitHubRunners:Builder': builderName,\n            },\n          },\n          launchTemplateConfigurations: launchTemplateConfigs,\n          fastLaunchConfigurations: fastLaunchConfigs.length > 0 ? fastLaunchConfigs : undefined,\n        },\n      ],\n    });\n\n    const recipe = new AmiRecipe(this, 'Ami Recipe', {\n      platform: this.platform(),\n      components: this.bindComponents(),\n      architecture: this.architecture,\n      baseAmi: this.baseAmi,\n    });\n\n    const log = this.createLog('Ami Log', recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilder'),\n    ]);\n    this.createImage(infra, dist, log, recipe.arn, undefined);\n    this.createPipeline(infra, dist, log, recipe.arn, undefined);\n\n    this.boundAmi = {\n      launchTemplate: launchTemplate,\n      architecture: this.architecture,\n      os: this.os,\n      logGroup: log,\n      runnerVersion: RunnerVersion.specific('unknown'),\n    };\n\n    this.amiCleaner(recipe, stackName, builderName);\n\n    return this.boundAmi;\n  }\n\n  private amiCleaner(recipe: AmiRecipe, stackName: string, builderName: string) {\n    const deleter = singletonLambda(DeleteAmiFunction, this, 'delete-ami', {\n      description: 'Delete old GitHub Runner AMIs',\n      initialPolicy: [\n        new iam.PolicyStatement({\n          actions: ['ec2:DescribeImages'],\n          resources: ['*'],\n        }),\n        new iam.PolicyStatement({\n          actions: ['ec2:DeregisterImage', 'ec2:DeleteSnapshot'],\n          resources: ['*'],\n          conditions: {\n            StringEquals: {\n              'aws:ResourceTag/GitHubRunners:Stack': stackName,\n            },\n          },\n        }),\n      ],\n      timeout: cdk.Duration.minutes(5),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    // delete all AMIs when this construct is removed\n    new CustomResource(this, 'AMI Deleter', {\n      serviceToken: deleter.functionArn,\n      resourceType: 'Custom::AmiDeleter',\n      properties: {\n        StackName: stackName,\n        BuilderName: builderName,\n      },\n    });\n\n    // delete old AMIs + IB resources daily\n    new imagebuilder.CfnLifecyclePolicy(this, 'Lifecycle Policy AMI', {\n      name: uniqueImageBuilderName(this),\n      description: `Delete old GitHub Runner AMIs for ${this.node.path}`,\n      executionRole: new iam.Role(this, 'Lifecycle Policy AMI Role', {\n        assumedBy: new iam.ServicePrincipal('imagebuilder.amazonaws.com'),\n        inlinePolicies: {\n          ib: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['tag:GetResources', 'imagebuilder:DeleteImage'],\n                resources: ['*'], // Image Builder doesn't support scoping this :(\n              }),\n            ],\n          }),\n          ami: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['ec2:DescribeImages', 'ec2:DescribeImageAttribute'],\n                resources: ['*'],\n              }),\n              new iam.PolicyStatement({\n                actions: ['ec2:DeregisterImage', 'ec2:DeleteSnapshot'],\n                resources: ['*'],\n                conditions: {\n                  StringEquals: {\n                    'aws:ResourceTag/GitHubRunners:Stack': stackName,\n                    'aws:ResourceTag/GitHubRunners:Builder': builderName,\n                  },\n                },\n              }),\n            ],\n          }),\n        },\n      }).roleArn,\n      policyDetails: [{\n        action: {\n          type: 'DELETE',\n          includeResources: {\n            amis: true,\n            snapshots: true,\n          },\n        },\n        filter: {\n          type: 'COUNT',\n          value: 2,\n        },\n      }],\n      resourceType: 'AMI_IMAGE',\n      resourceSelection: {\n        recipes: [\n          {\n            name: recipe.name,\n            semanticVersion: recipe.version, // docs say it's optional, but it's not\n          },\n        ],\n      },\n    });\n  }\n\n  private bindComponents(): ImageBuilderComponent[] {\n    if (this.boundComponents.length == 0) {\n      this.boundComponents.push(...this.components.map((c, i) => c._asAwsImageBuilderComponent(this, `Component ${i} ${c.name}`, this.os, this.architecture)));\n    }\n\n    return this.boundComponents;\n  }\n}\n\n/**\n * @internal\n */\nexport class AwsImageBuilderFailedBuildNotifier implements cdk.IAspect {\n  public static createFilteringTopic(scope: Construct, targetTopic: sns.Topic) {\n    const topic = new sns.Topic(scope, 'Image Builder Builds');\n    const filter = new FilterFailedBuildsFunction(scope, 'Image Builder Builds Filter', {\n      logRetention: logs.RetentionDays.ONE_MONTH,\n      environment: {\n        TARGET_TOPIC_ARN: targetTopic.topicArn,\n      },\n    });\n\n    topic.addSubscription(new subs.LambdaSubscription(filter));\n    targetTopic.grantPublish(filter);\n\n    return topic;\n  }\n\n  constructor(private topic: sns.ITopic) {\n  }\n\n  public visit(node: IConstruct): void {\n    if (node instanceof AwsImageBuilderRunnerImageBuilder) {\n      const builder = node as AwsImageBuilderRunnerImageBuilder;\n      const infraNode = builder.node.tryFindChild('Infrastructure');\n      if (infraNode) {\n        const infra = infraNode as imagebuilder.CfnInfrastructureConfiguration;\n        infra.snsTopicArn = this.topic.topicArn;\n      } else {\n        cdk.Annotations.of(builder).addWarning('Unused builder cannot get notifications of failed builds');\n      }\n    }\n  }\n}\n"]}
@@ -56,4 +56,4 @@ export declare class ContainerRecipe extends ImageBuilderObjectBase {
56
56
  *
57
57
  * @internal
58
58
  */
59
- export declare function defaultBaseDockerImage(os: Os): "mcr.microsoft.com/windows/servercore:ltsc2019-amd64" | "public.ecr.aws/lts/ubuntu:22.04" | "public.ecr.aws/amazonlinux/amazonlinux:2";
59
+ export declare function defaultBaseDockerImage(os: Os): "mcr.microsoft.com/windows/servercore:ltsc2019-amd64" | "public.ecr.aws/lts/ubuntu:22.04" | "public.ecr.aws/amazonlinux/amazonlinux:2" | "public.ecr.aws/amazonlinux/amazonlinux:2023";