@btc-embedded/cdk-extensions 0.22.23 → 0.22.24

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.
Files changed (52) hide show
  1. package/.jsii +26 -26
  2. package/CHANGELOG.md +14 -0
  3. package/assets/cli/catnip.js +1 -1
  4. package/lib/constructs/EventPipe.js +1 -1
  5. package/lib/constructs/ExportedService.js +1 -1
  6. package/lib/constructs/S3Bucket.js +1 -1
  7. package/lib/constructs/SecureRestApi.js +1 -1
  8. package/lib/constructs/SecureRestApiV2.js +1 -1
  9. package/lib/constructs/api-keys/ApiKeyClientAuthorization.js +1 -1
  10. package/lib/constructs/api-keys/ApiKeyManagement.js +1 -1
  11. package/lib/constructs/api-keys/ApiKeyPreTokenHandler.js +1 -1
  12. package/lib/constructs/api-keys/ApiKeyStore.js +1 -1
  13. package/lib/extensions/ApiGatewayExtension.js +1 -1
  14. package/lib/extensions/ApplicationContainer.js +1 -1
  15. package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
  16. package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +1 -1
  17. package/lib/extensions/CloudMapExtension.js +1 -1
  18. package/lib/extensions/DeactivatableServiceExtension.js +1 -1
  19. package/lib/extensions/DeploymentConfigExtension.js +1 -1
  20. package/lib/extensions/DocumentDbAccessExtension.js +1 -1
  21. package/lib/extensions/DomainEventMessagingExtension.js +1 -1
  22. package/lib/extensions/EfsMountExtension.js +8 -2
  23. package/lib/extensions/ExtraContainerExtension.js +1 -1
  24. package/lib/extensions/HTTPApiExtension.js +1 -1
  25. package/lib/extensions/LogExtension.js +1 -1
  26. package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
  27. package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
  28. package/lib/extensions/OpenIdExtension.js +1 -1
  29. package/lib/extensions/OpenTelemetryExtension.js +1 -1
  30. package/lib/extensions/PostgresDbAccessExtension.js +1 -1
  31. package/lib/extensions/SharedVolumeExtension.js +1 -1
  32. package/lib/extensions/TcpKeepAliveExtension.js +1 -1
  33. package/lib/platform/ApiGateway.js +1 -1
  34. package/lib/platform/ApiGatewayVpcLink.js +2 -2
  35. package/lib/platform/ApplicationLoadBalancer.js +1 -1
  36. package/lib/platform/ApplicationLoadBalancerV2.js +2 -2
  37. package/lib/platform/AuroraPostgresDB.js +2 -2
  38. package/lib/platform/BTCLogGroup.js +1 -1
  39. package/lib/platform/CognitoUserPool.js +2 -2
  40. package/lib/platform/DefaultUserPoolClients.js +1 -1
  41. package/lib/platform/DocumentDB.js +2 -2
  42. package/lib/platform/EcsCluster.js +1 -1
  43. package/lib/platform/EfsFileSystem.js +5 -15
  44. package/lib/platform/HostedZone.js +1 -1
  45. package/lib/platform/PrivateDnsNamespace.js +1 -1
  46. package/lib/platform/ResourceServer.js +1 -1
  47. package/lib/platform/Vpc.js +1 -1
  48. package/lib/platform/VpcV2.js +1 -1
  49. package/lib/stacks/ApplicationStack.js +1 -1
  50. package/lib/utils/BasePlatformStackResolver.js +1 -1
  51. package/lib/utils/StackParameter.js +1 -1
  52. package/package.json +1 -1
package/.jsii CHANGED
@@ -14783,7 +14783,7 @@
14783
14783
  "kind": "enum",
14784
14784
  "locationInModule": {
14785
14785
  "filename": "src/platform/EfsFileSystem.ts",
14786
- "line": 45
14786
+ "line": 43
14787
14787
  },
14788
14788
  "members": [
14789
14789
  {
@@ -14825,7 +14825,7 @@
14825
14825
  },
14826
14826
  "locationInModule": {
14827
14827
  "filename": "src/platform/EfsFileSystem.ts",
14828
- "line": 210
14828
+ "line": 208
14829
14829
  },
14830
14830
  "parameters": [
14831
14831
  {
@@ -14854,7 +14854,7 @@
14854
14854
  "kind": "class",
14855
14855
  "locationInModule": {
14856
14856
  "filename": "src/platform/EfsFileSystem.ts",
14857
- "line": 157
14857
+ "line": 155
14858
14858
  },
14859
14859
  "methods": [
14860
14860
  {
@@ -14865,7 +14865,7 @@
14865
14865
  },
14866
14866
  "locationInModule": {
14867
14867
  "filename": "src/platform/EfsFileSystem.ts",
14868
- "line": 165
14868
+ "line": 163
14869
14869
  },
14870
14870
  "name": "fromBasePlatform",
14871
14871
  "parameters": [
@@ -14910,7 +14910,7 @@
14910
14910
  },
14911
14911
  "locationInModule": {
14912
14912
  "filename": "src/platform/EfsFileSystem.ts",
14913
- "line": 105
14913
+ "line": 98
14914
14914
  },
14915
14915
  "name": "allowConnection",
14916
14916
  "overrides": "@btc-embedded/cdk-extensions.IEfsFileSystem",
@@ -14929,7 +14929,7 @@
14929
14929
  },
14930
14930
  "locationInModule": {
14931
14931
  "filename": "src/platform/EfsFileSystem.ts",
14932
- "line": 101
14932
+ "line": 94
14933
14933
  },
14934
14934
  "name": "fileSystem",
14935
14935
  "overrides": "@btc-embedded/cdk-extensions.IEfsFileSystem",
@@ -14945,7 +14945,7 @@
14945
14945
  },
14946
14946
  "locationInModule": {
14947
14947
  "filename": "src/platform/EfsFileSystem.ts",
14948
- "line": 97
14948
+ "line": 90
14949
14949
  },
14950
14950
  "name": "fileSystemId",
14951
14951
  "overrides": "@btc-embedded/cdk-extensions.IEfsFileSystem",
@@ -14961,7 +14961,7 @@
14961
14961
  },
14962
14962
  "locationInModule": {
14963
14963
  "filename": "src/platform/EfsFileSystem.ts",
14964
- "line": 67
14964
+ "line": 65
14965
14965
  },
14966
14966
  "name": "grantAccess",
14967
14967
  "overrides": "@btc-embedded/cdk-extensions.IEfsFileSystem",
@@ -14989,7 +14989,7 @@
14989
14989
  },
14990
14990
  "locationInModule": {
14991
14991
  "filename": "src/platform/EfsFileSystem.ts",
14992
- "line": 64
14992
+ "line": 62
14993
14993
  },
14994
14994
  "name": "filesystem",
14995
14995
  "protected": true,
@@ -15003,7 +15003,7 @@
15003
15003
  },
15004
15004
  "locationInModule": {
15005
15005
  "filename": "src/platform/EfsFileSystem.ts",
15006
- "line": 65
15006
+ "line": 63
15007
15007
  },
15008
15008
  "name": "securityGroup",
15009
15009
  "protected": true,
@@ -15025,7 +15025,7 @@
15025
15025
  "kind": "interface",
15026
15026
  "locationInModule": {
15027
15027
  "filename": "src/platform/EfsFileSystem.ts",
15028
- "line": 113
15028
+ "line": 111
15029
15029
  },
15030
15030
  "name": "EfsFileSystemLookupOptions",
15031
15031
  "properties": [
@@ -15038,7 +15038,7 @@
15038
15038
  "immutable": true,
15039
15039
  "locationInModule": {
15040
15040
  "filename": "src/platform/EfsFileSystem.ts",
15041
- "line": 122
15041
+ "line": 120
15042
15042
  },
15043
15043
  "name": "filesystemName",
15044
15044
  "type": {
@@ -15054,7 +15054,7 @@
15054
15054
  "immutable": true,
15055
15055
  "locationInModule": {
15056
15056
  "filename": "src/platform/EfsFileSystem.ts",
15057
- "line": 117
15057
+ "line": 115
15058
15058
  },
15059
15059
  "name": "basePlatformStackName",
15060
15060
  "optional": true,
@@ -15075,7 +15075,7 @@
15075
15075
  "kind": "interface",
15076
15076
  "locationInModule": {
15077
15077
  "filename": "src/platform/EfsFileSystem.ts",
15078
- "line": 22
15078
+ "line": 20
15079
15079
  },
15080
15080
  "name": "EfsFileSystemProps",
15081
15081
  "properties": [
@@ -15089,7 +15089,7 @@
15089
15089
  "immutable": true,
15090
15090
  "locationInModule": {
15091
15091
  "filename": "src/platform/EfsFileSystem.ts",
15092
- "line": 31
15092
+ "line": 29
15093
15093
  },
15094
15094
  "name": "name",
15095
15095
  "type": {
@@ -15105,7 +15105,7 @@
15105
15105
  "immutable": true,
15106
15106
  "locationInModule": {
15107
15107
  "filename": "src/platform/EfsFileSystem.ts",
15108
- "line": 26
15108
+ "line": 24
15109
15109
  },
15110
15110
  "name": "vpc",
15111
15111
  "type": {
@@ -15122,7 +15122,7 @@
15122
15122
  "immutable": true,
15123
15123
  "locationInModule": {
15124
15124
  "filename": "src/platform/EfsFileSystem.ts",
15125
- "line": 35
15125
+ "line": 33
15126
15126
  },
15127
15127
  "name": "automaticBackups",
15128
15128
  "optional": true,
@@ -15140,7 +15140,7 @@
15140
15140
  "immutable": true,
15141
15141
  "locationInModule": {
15142
15142
  "filename": "src/platform/EfsFileSystem.ts",
15143
- "line": 39
15143
+ "line": 37
15144
15144
  },
15145
15145
  "name": "removalPolicy",
15146
15146
  "optional": true,
@@ -15191,7 +15191,7 @@
15191
15191
  },
15192
15192
  "locationInModule": {
15193
15193
  "filename": "src/extensions/EfsMountExtension.ts",
15194
- "line": 78
15194
+ "line": 87
15195
15195
  },
15196
15196
  "name": "useService",
15197
15197
  "overrides": "@aws-cdk-containers/ecs-service-extensions.ServiceExtension",
@@ -17506,7 +17506,7 @@
17506
17506
  "kind": "interface",
17507
17507
  "locationInModule": {
17508
17508
  "filename": "src/platform/EfsFileSystem.ts",
17509
- "line": 128
17509
+ "line": 126
17510
17510
  },
17511
17511
  "methods": [
17512
17512
  {
@@ -17517,7 +17517,7 @@
17517
17517
  },
17518
17518
  "locationInModule": {
17519
17519
  "filename": "src/platform/EfsFileSystem.ts",
17520
- "line": 140
17520
+ "line": 138
17521
17521
  },
17522
17522
  "name": "allowConnection",
17523
17523
  "parameters": [
@@ -17540,7 +17540,7 @@
17540
17540
  },
17541
17541
  "locationInModule": {
17542
17542
  "filename": "src/platform/EfsFileSystem.ts",
17543
- "line": 150
17543
+ "line": 148
17544
17544
  },
17545
17545
  "name": "fileSystem",
17546
17546
  "returns": {
@@ -17557,7 +17557,7 @@
17557
17557
  },
17558
17558
  "locationInModule": {
17559
17559
  "filename": "src/platform/EfsFileSystem.ts",
17560
- "line": 145
17560
+ "line": 143
17561
17561
  },
17562
17562
  "name": "fileSystemId",
17563
17563
  "returns": {
@@ -17574,7 +17574,7 @@
17574
17574
  },
17575
17575
  "locationInModule": {
17576
17576
  "filename": "src/platform/EfsFileSystem.ts",
17577
- "line": 134
17577
+ "line": 132
17578
17578
  },
17579
17579
  "name": "grantAccess",
17580
17580
  "parameters": [
@@ -20942,6 +20942,6 @@
20942
20942
  "usedFeatures": [
20943
20943
  "class-covariant-overrides"
20944
20944
  ],
20945
- "version": "0.22.23",
20946
- "fingerprint": "H0sBOsk0cgnXhy9C+mvWkWOVIMGf3LjvR1qF/2r0UjM="
20945
+ "version": "0.22.24",
20946
+ "fingerprint": "uC4bcrSuk36ebf6AVpbpiRdGvgwObHJjnAfczoxoAY0="
20947
20947
  }
package/CHANGELOG.md CHANGED
@@ -1,4 +1,18 @@
1
1
 
2
+ ## [0.22.23](https://github.com/btc-embedded/cdk-extensions/compare/v0.22.22...v0.22.23) (2026-03-09)
3
+
4
+
5
+ ### Features
6
+
7
+ * support creating extensions without using basePlatform imports ([0eb6723](https://github.com/btc-embedded/cdk-extensions/commit/0eb672360e5c379c11fc9990729604ae5040a182))
8
+
9
+
10
+ ### Bug Fixes
11
+
12
+ * fixed documentation ([1a136b4](https://github.com/btc-embedded/cdk-extensions/commit/1a136b46bbbd5b469d42de0cfc54d09d8f1cee89))
13
+ * fixed linter issues ([e5d0626](https://github.com/btc-embedded/cdk-extensions/commit/e5d0626f26343798d92d9c8894033d8d3677dbd1))
14
+ * fixed tests ([d48e17a](https://github.com/btc-embedded/cdk-extensions/commit/d48e17a9a2ceac0cf2d1a25202214d55add1561a))
15
+
2
16
  ## [0.22.22](https://github.com/btc-embedded/cdk-extensions/compare/v0.22.21...v0.22.22) (2026-03-05)
3
17
 
4
18
  ## [0.22.21](https://github.com/btc-embedded/cdk-extensions/compare/v0.22.20...v0.22.21) (2026-03-05)
@@ -248,7 +248,7 @@ Reference: https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-sso.ht
248
248
  `),Js={insert:"+ ",delete:"- ",replace:"! ",equal:" "},br=!1,cn=[],_o=new s(null,ee,Z).getGroupedOpcodes(),yr=0,En=_o.length;yr<En;yr++)if(rt=_o[yr],!br){if(br=!0,We=z?` ${z}`:"",Li=Y?` ${Y}`:"",cn.push(`*** ${G}${We}${Me}`),cn.push(`--- ${H}${Li}${Me}`),[_t,Nn]=[rt[0],rt[rt.length-1]],cn.push("***************"+Me),Ue=l(_t[1],Nn[2]),cn.push(`*** ${Ue} ****${Me}`),o((function(){var Co,os,Us;for(Us=[],os=0,Co=rt.length;os<Co;os++)[dr,ve,ve,ve,ve]=rt[os],Us.push(dr==="replace"||dr==="delete");return Us})())){for(Lr=0,Ss=rt.length;Lr<Ss;Lr++)if([dr,wt,nn,ve,ve]=rt[Lr],dr!=="insert")for(Ho=ee.slice(wt,nn),rs=0,xr=Ho.length;rs<xr;rs++)Ln=Ho[rs],cn.push(Js[dr]+Ln)}if(qe=l(_t[3],Nn[4]),cn.push(`--- ${qe} ----${Me}`),o((function(){var Co,os,Us;for(Us=[],os=0,Co=rt.length;os<Co;os++)[dr,ve,ve,ve,ve]=rt[os],Us.push(dr==="replace"||dr==="insert");return Us})())){for(Wr=0,Ni=rt.length;Wr<Ni;Wr++)if([dr,ve,ve,rn,vr]=rt[Wr],dr!=="delete")for(ss=Z.slice(rn,vr),Fs=0,sn=ss.length;Fs<sn;Fs++)Ln=ss[Fs],cn.push(Js[dr]+Ln)}}return cn},k=function(ee,Z,G,H=n){return new t(G,H).compare(ee,Z)},j=function(ee,Z){var G,H,z,Y,oe,Me,ve;if(ve={1:"- ",2:"+ "}[Z],!ve)throw new Error(`unknow delta choice (must be 1 or 2): ${Z}`);for(oe=[" ",ve],Y=[],G=0,H=ee.length;G<H;G++)z=ee[G],Me=z.slice(0,2),J.call(oe,Me)>=0&&Y.push(z.slice(2));return Y},Ra._arrayCmp=i,Ra.SequenceMatcher=s,Ra.getCloseMatches=A,Ra._countLeading=c,Ra.Differ=t,Ra.IS_LINE_JUNK=r,Ra.IS_CHARACTER_JUNK=n,Ra._formatRangeUnified=p,Ra.unifiedDiff=W,Ra._formatRangeContext=l,Ra.contextDiff=y,Ra.ndiff=k,Ra.restore=j}).call(Ra)});var X1t=F((E1s,J1t)=>{J1t.exports=Y1t()});var bPe=F((y1s,Z1t)=>{var eKr=function(t){let e=typeof t;return t==null?"null":e==="object"&&t.constructor===Array?"array":e==="object"&&t instanceof Date?"date":e},xPe=function(t,e){let n=typeof t;if(n==="array")return t.map(r=>xPe(r,e));if(n==="object"){for(let r in t)t[r]=xPe(t[r],e);return t}else return n==="number"&&Number.isFinite(t)&&!Number.isInteger(t)?+t.toFixed(e):t};Z1t.exports={extendedTypeOf:eKr,roundObj:xPe}});var rFt=F((_1s,nFt)=>{var tFt={};nFt.exports=tFt;var eFt={reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],inverse:[7,27],hidden:[8,28],strikethrough:[9,29],black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],gray:[90,39],grey:[90,39],brightRed:[91,39],brightGreen:[92,39],brightYellow:[93,39],brightBlue:[94,39],brightMagenta:[95,39],brightCyan:[96,39],brightWhite:[97,39],bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgGray:[100,49],bgGrey:[100,49],bgBrightRed:[101,49],bgBrightGreen:[102,49],bgBrightYellow:[103,49],bgBrightBlue:[104,49],bgBrightMagenta:[105,49],bgBrightCyan:[106,49],bgBrightWhite:[107,49],blackBG:[40,49],redBG:[41,49],greenBG:[42,49],yellowBG:[43,49],blueBG:[44,49],magentaBG:[45,49],cyanBG:[46,49],whiteBG:[47,49]};Object.keys(eFt).forEach(function(t){var e=eFt[t],n=tFt[t]=[];n.open="\x1B["+e[0]+"m",n.close="\x1B["+e[1]+"m"})});var oFt=F((C1s,sFt)=>{"use strict";sFt.exports=function(t,e){e=e||process.argv;var n=e.indexOf("--"),r=/^-{1,2}/.test(t)?"":"--",s=e.indexOf(r+t);return s!==-1&&(n===-1?!0:s<n)}});var aFt=F((R1s,iFt)=>{"use strict";var tKr=require("os"),kl=oFt(),Ta=process.env,OI=void 0;kl("no-color")||kl("no-colors")||kl("color=false")?OI=!1:(kl("color")||kl("colors")||kl("color=true")||kl("color=always"))&&(OI=!0);"FORCE_COLOR"in Ta&&(OI=Ta.FORCE_COLOR.length===0||parseInt(Ta.FORCE_COLOR,10)!==0);function nKr(t){return t===0?!1:{level:t,hasBasic:!0,has256:t>=2,has16m:t>=3}}function rKr(t){if(OI===!1)return 0;if(kl("color=16m")||kl("color=full")||kl("color=truecolor"))return 3;if(kl("color=256"))return 2;if(t&&!t.isTTY&&OI!==!0)return 0;var e=OI?1:0;if(process.platform==="win32"){var n=tKr.release().split(".");return Number(process.versions.node.split(".")[0])>=8&&Number(n[0])>=10&&Number(n[2])>=10586?Number(n[2])>=14931?3:2:1}if("CI"in Ta)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI"].some(function(s){return s in Ta})||Ta.CI_NAME==="codeship"?1:e;if("TEAMCITY_VERSION"in Ta)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(Ta.TEAMCITY_VERSION)?1:0;if("TERM_PROGRAM"in Ta){var r=parseInt((Ta.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(Ta.TERM_PROGRAM){case"iTerm.app":return r>=3?3:2;case"Hyper":return 3;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(Ta.TERM)?2:/^screen|^xterm|^vt100|^rxvt|color|ansi|cygwin|linux/i.test(Ta.TERM)||"COLORTERM"in Ta?1:(Ta.TERM==="dumb",e)}function DPe(t){var e=rKr(t);return nKr(e)}iFt.exports={supportsColor:DPe,stdout:DPe(process.stdout),stderr:DPe(process.stderr)}});var uFt=F((T1s,cFt)=>{cFt.exports=function(e,n){var r="";e=e||"Run the trap, drop the bass",e=e.split("");var s={a:["@","\u0104","\u023A","\u0245","\u0394","\u039B","\u0414"],b:["\xDF","\u0181","\u0243","\u026E","\u03B2","\u0E3F"],c:["\xA9","\u023B","\u03FE"],d:["\xD0","\u018A","\u0500","\u0501","\u0502","\u0503"],e:["\xCB","\u0115","\u018E","\u0258","\u03A3","\u03BE","\u04BC","\u0A6C"],f:["\u04FA"],g:["\u0262"],h:["\u0126","\u0195","\u04A2","\u04BA","\u04C7","\u050A"],i:["\u0F0F"],j:["\u0134"],k:["\u0138","\u04A0","\u04C3","\u051E"],l:["\u0139"],m:["\u028D","\u04CD","\u04CE","\u0520","\u0521","\u0D69"],n:["\xD1","\u014B","\u019D","\u0376","\u03A0","\u048A"],o:["\xD8","\xF5","\xF8","\u01FE","\u0298","\u047A","\u05DD","\u06DD","\u0E4F"],p:["\u01F7","\u048E"],q:["\u09CD"],r:["\xAE","\u01A6","\u0210","\u024C","\u0280","\u042F"],s:["\xA7","\u03DE","\u03DF","\u03E8"],t:["\u0141","\u0166","\u0373"],u:["\u01B1","\u054D"],v:["\u05D8"],w:["\u0428","\u0460","\u047C","\u0D70"],x:["\u04B2","\u04FE","\u04FC","\u04FD"],y:["\xA5","\u04B0","\u04CB"],z:["\u01B5","\u0240"]};return e.forEach(function(o){o=o.toLowerCase();var i=s[o]||[" "],a=Math.floor(Math.random()*i.length);typeof s[o]<"u"?r+=s[o][a]:r+=o}),r}});var dFt=F((I1s,lFt)=>{lFt.exports=function(e,n){e=e||" he is here ";var r={up:["\u030D","\u030E","\u0304","\u0305","\u033F","\u0311","\u0306","\u0310","\u0352","\u0357","\u0351","\u0307","\u0308","\u030A","\u0342","\u0313","\u0308","\u034A","\u034B","\u034C","\u0303","\u0302","\u030C","\u0350","\u0300","\u0301","\u030B","\u030F","\u0312","\u0313","\u0314","\u033D","\u0309","\u0363","\u0364","\u0365","\u0366","\u0367","\u0368","\u0369","\u036A","\u036B","\u036C","\u036D","\u036E","\u036F","\u033E","\u035B","\u0346","\u031A"],down:["\u0316","\u0317","\u0318","\u0319","\u031C","\u031D","\u031E","\u031F","\u0320","\u0324","\u0325","\u0326","\u0329","\u032A","\u032B","\u032C","\u032D","\u032E","\u032F","\u0330","\u0331","\u0332","\u0333","\u0339","\u033A","\u033B","\u033C","\u0345","\u0347","\u0348","\u0349","\u034D","\u034E","\u0353","\u0354","\u0355","\u0356","\u0359","\u035A","\u0323"],mid:["\u0315","\u031B","\u0300","\u0301","\u0358","\u0321","\u0322","\u0327","\u0328","\u0334","\u0335","\u0336","\u035C","\u035D","\u035E","\u035F","\u0360","\u0362","\u0338","\u0337","\u0361"," \u0489"]},s=[].concat(r.up,r.down,r.mid);function o(c){var l=Math.floor(Math.random()*c);return l}function i(c){var l=!1;return s.filter(function(p){l=p===c}),l}function a(c,l){var p="",d,S;l=l||{},l.up=typeof l.up<"u"?l.up:!0,l.mid=typeof l.mid<"u"?l.mid:!0,l.down=typeof l.down<"u"?l.down:!0,l.size=typeof l.size<"u"?l.size:"maxi",c=c.split("");for(S in c)if(!i(S)){switch(p=p+c[S],d={up:0,down:0,mid:0},l.size){case"mini":d.up=o(8),d.mid=o(2),d.down=o(8);break;case"maxi":d.up=o(16)+3,d.mid=o(4)+1,d.down=o(64)+3;break;default:d.up=o(8)+1,d.mid=o(6)/2,d.down=o(8)+1;break}var y=["up","mid","down"];for(var C in y)for(var A=y[C],b=0;b<=d[A];b++)l[A]&&(p=p+r[A][o(r[A].length)])}return p}return a(e,n)}});var mFt=F((P1s,pFt)=>{pFt.exports=function(t){return function(e,n,r){if(e===" ")return e;switch(n%3){case 0:return t.red(e);case 1:return t.white(e);case 2:return t.blue(e)}}}});var gFt=F((A1s,fFt)=>{fFt.exports=function(t){return function(e,n,r){return n%2===0?e:t.inverse(e)}}});var SFt=F((v1s,hFt)=>{hFt.exports=function(t){var e=["red","yellow","green","blue","magenta"];return function(n,r,s){return n===" "?n:t[e[r++%e.length]](n)}}});var yFt=F((x1s,EFt)=>{EFt.exports=function(t){var e=["underline","inverse","grey","yellow","red","green","blue","white","cyan","magenta","brightYellow","brightRed","brightGreen","brightBlue","brightWhite","brightCyan","brightMagenta"];return function(n,r,s){return n===" "?n:t[e[Math.round(Math.random()*(e.length-2))]](n)}}});var PFt=F((D1s,IFt)=>{var Yt={};IFt.exports=Yt;Yt.themes={};var sKr=require("util"),N_=Yt.styles=rFt(),CFt=Object.defineProperties,oKr=new RegExp(/[\r\n]+/g);Yt.supportsColor=aFt().supportsColor;typeof Yt.enabled>"u"&&(Yt.enabled=Yt.supportsColor()!==!1);Yt.enable=function(){Yt.enabled=!0};Yt.disable=function(){Yt.enabled=!1};Yt.stripColors=Yt.strip=function(t){return(""+t).replace(/\x1B\[\d+m/g,"")};var b1s=Yt.stylize=function(e,n){if(!Yt.enabled)return e+"";var r=N_[n];return!r&&n in Yt?Yt[n](e):r.open+e+r.close},iKr=/[|\\{}()[\]^$+*?.]/g,aKr=function(t){if(typeof t!="string")throw new TypeError("Expected a string");return t.replace(iKr,"\\$&")};function RFt(t){var e=function n(){return uKr.apply(n,arguments)};return e._styles=t,e.__proto__=cKr,e}var TFt=(function(){var t={};return N_.grey=N_.gray,Object.keys(N_).forEach(function(e){N_[e].closeRe=new RegExp(aKr(N_[e].close),"g"),t[e]={get:function(){return RFt(this._styles.concat(e))}}}),t})(),cKr=CFt(function(){},TFt);function uKr(){var t=Array.prototype.slice.call(arguments),e=t.map(function(i){return i!=null&&i.constructor===String?i:sKr.inspect(i)}).join(" ");if(!Yt.enabled||!e)return e;for(var n=e.indexOf(`
249
249
  `)!=-1,r=this._styles,s=r.length;s--;){var o=N_[r[s]];e=o.open+e.replace(o.closeRe,o.open)+o.close,n&&(e=e.replace(oKr,function(i){return o.close+i+o.open}))}return e}Yt.setTheme=function(t){if(typeof t=="string"){console.log("colors.setTheme now only accepts an object, not a string. If you are trying to set a theme from a file, it is now your (the caller's) responsibility to require the file. The old syntax looked like colors.setTheme(__dirname + '/../themes/generic-logging.js'); The new syntax looks like colors.setTheme(require(__dirname + '/../themes/generic-logging.js'));");return}for(var e in t)(function(n){Yt[n]=function(r){if(typeof t[n]=="object"){var s=r;for(var o in t[n])s=Yt[t[n][o]](s);return s}return Yt[t[n]](r)}})(e)};function lKr(){var t={};return Object.keys(TFt).forEach(function(e){t[e]={get:function(){return RFt([e])}}}),t}var dKr=function(e,n){var r=n.split("");return r=r.map(e),r.join("")};Yt.trap=uFt();Yt.zalgo=dFt();Yt.maps={};Yt.maps.america=mFt()(Yt);Yt.maps.zebra=gFt()(Yt);Yt.maps.rainbow=SFt()(Yt);Yt.maps.random=yFt()(Yt);for(_Ft in Yt.maps)(function(t){Yt[t]=function(e){return dKr(Yt.maps[t],e)}})(_Ft);var _Ft;CFt(Yt,lKr())});var vFt=F((w1s,AFt)=>{var pKr=PFt();AFt.exports=pKr});var wFt=F(($1s,DFt)=>{var xFt=vFt(),{extendedTypeOf:bFt}=bPe(),mKr={" "(t){return t},"+":xFt.green,"-":xFt.red},KS=function(t,e,n,r,s,o){let i,a=e?`${e}: `:"",c=o+" ",l=p=>{let d=t.maxElisions===void 0?1/0:t.maxElisions;if(p<d)for(let S=0;S<p;S++)r(" ",c+"...");else r(" ",c+`... (${p} entries)`)};switch(bFt(n)){case"object":if("__old"in n&&"__new"in n&&Object.keys(n).length===2)return KS(t,e,n.__old,r,"-",o),KS(t,e,n.__new,r,"+",o);r(s,`${o}${a}{`);for(let p of Object.keys(n)){let d;i=n[p],(d=p.match(/^(.*)__deleted$/))?KS(t,d[1],i,r,"-",c):(d=p.match(/^(.*)__added$/))?KS(t,d[1],i,r,"+",c):KS(t,p,i,r,s,c)}return r(s,`${o}}`);case"array":{r(s,`${o}${a}[`);let p=!0;for(let d of n)(bFt(d)!=="array"||!(d.length===2||d.length===1&&d[0]===" ")||typeof d[0]!="string"||d[0].length!==1||![" ","-","+","~"].includes(d[0]))&&(p=!1);if(p){let d,S=0;for([d,i]of n)if(d===" "&&i==null)S++;else{if(S>0&&l(S),S=0,![" ","~","+","-"].includes(d))throw new Error(`Unexpected op '${d}' in ${JSON.stringify(n,null,2)}`);d==="~"&&(d=" "),KS(t,"",i,r,d,c)}S>0&&l(S)}else for(i of n)KS(t,"",i,r,s,c);return r(s,`${o}]`)}default:if(n===0||n===null||n===!1||n===""||n)return r(s,o+a+JSON.stringify(n))}},wPe=(t,e,n)=>KS(e,"",t,n," ",""),fKr=function(t,e={}){let n=[];return wPe(t,e,(r,s)=>n.push(`${r}${s}`)),n},gKr=function(t,e={}){let n=[];return wPe(t,e,function(r,s){return e.color==null||e.color?n.push(((e.theme!=null?e.theme[r]:void 0)!=null?e.theme!=null?e.theme[r]:void 0:mKr[r])(`${r}${s}`)+`
250
250
  `):n.push(`${r}${s}
251
- `)}),n.join("")};DFt.exports={colorize:gKr,colorizeToArray:fKr,colorizeToCallback:wPe}});var kFt=F((O1s,LFt)=>{var{SequenceMatcher:hKr}=X1t(),{extendedTypeOf:g7,roundObj:$Ft}=bPe(),{colorize:OFt,colorizeToCallback:SKr}=wFt(),$Pe=class{constructor(e){e.outputKeys=e.outputKeys||[],e.excludeKeys=e.excludeKeys||[],this.options=e}isScalar(e){return typeof e!="object"||e===null}objectDiff(e,n){let r={},s=0,o=!0;for(let[i,a]of Object.entries(e))if(!this.options.outputNewOnly){let c="__deleted";!(i in n)&&!this.options.excludeKeys.includes(i)&&(r[`${i}${c}`]=a,s-=30,o=!1)}for(let[i,a]of Object.entries(n)){let c=this.options.outputNewOnly?"":"__added";!(i in e)&&!this.options.excludeKeys.includes(i)&&(r[`${i}${c}`]=a,s-=30,o=!1)}for(let[i,a]of Object.entries(e))if(i in n){if(this.options.excludeKeys.includes(i))continue;s+=20;let c=n[i],l=this.diff(a,c);l.equal?(this.options.full||this.options.outputKeys.includes(i))&&(r[i]=a):(r[i]=l.result,o=!1),s+=Math.min(20,Math.max(-10,l.score/5))}return o?(s=100*Math.max(Object.keys(e).length,.5),this.options.full||(r=void 0)):s=Math.max(0,s),{score:s,result:r,equal:o}}findMatchingObject(e,n,r){let s=null;for(let[o,{item:i,index:a}]of Object.entries(r))if(o!=="__next"){let c=Math.abs(a-n);if(g7(e)===g7(i)){let{score:l}=this.diff(e,i);(!s||l>s.score||l===s.score&&c<s.indexDistance)&&(s={score:l,key:o,indexDistance:c})}}return s}scalarize(e,n,r){let s=[];if(r){let i={};for(let a=0;a<e.length;a++){let c=e[a];if(this.isScalar(c))continue;let l=this.findMatchingObject(c,a,r);l&&(!i[l.key]||l.score>i[l.key].score)&&(i[l.key]={score:l.score,index:a})}for(let[a,c]of Object.entries(i))s[c.index]=a}let o=[];for(let i=0;i<e.length;i++){let a=e[i];if(this.isScalar(a))o.push(a);else{let c=s[i]||"__$!SCALAR"+n.__next++;n[c]={item:a,index:i},o.push(c)}}return o}isScalarized(e,n){return typeof e=="string"&&e in n}descalarize(e,n){return this.isScalarized(e,n)?n[e].item:e}arrayDiff(e,n){let r={__next:1},s=this.scalarize(e,r),o={__next:r.__next},i=this.scalarize(n,o,r);this.options.sort&&(s.sort(),i.sort());let a=new hKr(null,s,i).getOpcodes(),c=[],l=0,p=!0;for(let[d,S,y,C,A]of a){let b,$,k,j,W,J,ee,Z;switch(d==="equal"||this.options.keysOnly&&d==="replace"||(p=!1),d){case"equal":for(b=S,j=y,k=S<=j;k?b<j:b>j;k?b++:b--){let G=s[b];if(this.isScalarized(G,r)){if(!this.isScalarized(G,o))throw new Error(`internal bug: isScalarized(item, originals1) != isScalarized(item, originals2) for item ${JSON.stringify(G)}`);let H=this.descalarize(G,r),z=this.descalarize(G,o),Y=this.diff(H,z);Y.equal?this.options.full||this.options.keepUnchangedValues?c.push([" ",H]):c.push([" "]):(c.push(["~",Y.result]),p=!1)}else this.options.full||this.options.keepUnchangedValues?c.push([" ",G]):c.push([" "]);l+=10}break;case"delete":for(b=S,J=y,W=S<=J;W?b<J:b>J;W?b++:b--)c.push(["-",this.descalarize(s[b],r)]),l-=5;break;case"insert":for($=C,Z=A,ee=C<=Z;ee?$<Z:$>Z;ee?$++:$--)c.push(["+",this.descalarize(i[$],o)]),l-=5;break;case"replace":if(this.options.keysOnly){let G,H;for(b=S,H=y,G=S<=H;G?b<H:b>H;G?b++:b--){let z=this.diff(this.descalarize(s[b],r),this.descalarize(i[b-S+C],o));z.equal?c.push([" "]):(c.push(["~",z.result]),p=!1)}}else{let G,H,z,Y;for(b=S,H=y,G=S<=H;G?b<H:b>H;G?b++:b--)c.push(["-",this.descalarize(s[b],r)]),l-=5;for($=C,Y=A,z=C<=Y;z?$<Y:$>Y;z?$++:$--)c.push(["+",this.descalarize(i[$],o)]),l-=5}break}}return p||a.length===0?(this.options.full?c=e:c=void 0,l=100):l=Math.max(0,l),{score:l,result:c,equal:p}}diff(e,n){let r=g7(e),s=g7(n);if(r===s)switch(r){case"object":return this.objectDiff(e,n);case"array":return this.arrayDiff(e,n)}let o=100,i=e,a;return this.options.keysOnly?(a=!0,i=void 0):(r==="date"&&s==="date"?a=e.getTime()===n.getTime():a=e===n,a?this.options.full||(i=void 0):(o=0,this.options.outputNewOnly?i=n:i={__old:e,__new:n})),{score:o,result:i,equal:a}}};function NFt(t,e,n={}){return n.precision!==void 0&&(t=$Ft(t,n.precision),e=$Ft(e,n.precision)),new $Pe(n).diff(t,e).result}function EKr(t,e,n={}){return OFt(NFt(t,e,n),n)}LFt.exports={diff:NFt,diffString:EKr,colorize:OFt,colorizeToCallback:SKr}});var GFt=F((V1s,wKr)=>{wKr.exports={name:"@btc-embedded/cdk-extensions",description:"A collection of useful CDK extensions and common logic",repository:{type:"git",url:"https://github.com/btc-embedded/cdk-extensions.git"},bin:{catnip:"assets/cli/catnip.js"},scripts:{build:"npx projen build",bump:"npx projen bump",bundle:"npx projen bundle","bundle:cli/catnip":"npx projen bundle:cli/catnip","bundle:constructs/api-keys/lambdas/api-client-authorization.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-client-authorization.lambda","bundle:constructs/api-keys/lambdas/api-client-authorization.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-client-authorization.lambda:watch","bundle:constructs/api-keys/lambdas/api-key-creation.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-key-creation.lambda","bundle:constructs/api-keys/lambdas/api-key-creation.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-key-creation.lambda:watch","bundle:constructs/api-keys/lambdas/api-key-update.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-key-update.lambda","bundle:constructs/api-keys/lambdas/api-key-update.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-key-update.lambda:watch","bundle:constructs/api-keys/lambdas/pre-token.lambda":"npx projen bundle:constructs/api-keys/lambdas/pre-token.lambda","bundle:constructs/api-keys/lambdas/pre-token.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/pre-token.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda","bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda:watch",clobber:"npx projen clobber",compat:"npx projen compat",compile:"npx projen compile",default:"npx projen default",docgen:"npx projen docgen",eject:"npx projen eject",eslint:"npx projen eslint","eslint:ci":"npx projen eslint:ci",integ:"npx projen integ","integ:update":"npx projen integ:update",package:"npx projen package","package-all":"npx projen package-all","package:js":"npx projen package:js","post-compile":"npx projen post-compile","post-upgrade":"npx projen post-upgrade","pre-compile":"npx projen pre-compile","publish:git":"npx projen publish:git",release:"npx projen release",test:"npx projen test","test:watch":"npx projen test:watch",typecheck:"npx projen typecheck",unbump:"npx projen unbump","update-docs":"npx projen update-docs",upgrade:"npx projen upgrade",watch:"npx projen watch","yalc:watch":"npx projen yalc:watch",projen:"npx projen"},author:{name:"BTC Embedded Systems AG",url:"https://www.btc-embedded.com",organization:!0},devDependencies:{"@aws-cdk-containers/ecs-service-extensions":"2.0.1-alpha.535","@aws-cdk/integ-runner":"latest","@aws-cdk/integ-tests-alpha":"latest","@aws-sdk/client-cloudformation":"^3.993.0","@aws-sdk/client-cloudwatch-logs":"^3.993.0","@aws-sdk/client-ecs":"^3.993.0","@aws-sdk/client-ssm":"^3.999.0","@aws-sdk/credential-providers":"^3.993.0","@types/aws-api-gateway-client":"^0.3.3","@types/jest":"^30.0.0","@types/json-diff":"^1.0.3","@types/node":"^24.10.9","@types/url-template":"^3.0.0","@typescript-eslint/eslint-plugin":"^8","@typescript-eslint/parser":"^8","aws-api-gateway-client":"^0.3.7","aws-cdk-lib":"2.232.1","aws-sdk-client-mock":"^4.1.0","cdk-nag":"^2.37.55",commander:"^14.0.3","commit-and-tag-version":"^12",constructs:"10.0.5",esbuild:"^0.27.1",eslint:"^9","eslint-config-prettier":"^10.1.8","eslint-formatter-gitlab":"^7.0.1","eslint-import-resolver-typescript":"^4.4.4","eslint-plugin-import":"^2.32.0","eslint-plugin-prettier":"^5.5.5",jest:"^30.2.0","jest-junit":"^16",jsii:"~5.9.0","jsii-diff":"^1.125.0","jsii-docgen":"^10.5.0","jsii-pacmak":"^1.125.0","jsii-rosetta":"~5.9.0","json-diff":"^1.0.6",nodemon:"^3.1.11",prettier:"^3.8.0",projen:"^0.99.3","ts-jest":"^29.4.6","ts-node":"^10.9.2",typedoc:"^0.28.16","typedoc-plugin-markdown":"^4.9.0",typescript:"^5.9.3","url-template":"^3.1.1",yalc:"^1.0.0-pre.53"},peerDependencies:{"@aws-cdk-containers/ecs-service-extensions":">=2.0.1-alpha.535","aws-cdk-lib":"^2.232.1",constructs:"^10.0.5"},dependencies:{"@aws-lambda-powertools/logger":"^2.30.2","@aws-lambda-powertools/parameters":"^2.30.2","@aws-lambda-powertools/parser":"^2.30.2","@aws-sdk/client-cognito-identity-provider":"^3.965.0","@aws-sdk/client-dynamodb":"^3.948.0","@aws-sdk/client-secrets-manager":"^3.971.0","@aws-sdk/lib-dynamodb":"^3.948.0","@types/aws-lambda":"^8.10.159",yaml:"^2.8.2",zod:"~3"},bundledDependencies:["@aws-lambda-powertools/logger","@aws-lambda-powertools/parameters","@aws-lambda-powertools/parser","@aws-sdk/client-cognito-identity-provider","@aws-sdk/client-dynamodb","@aws-sdk/client-secrets-manager","@aws-sdk/lib-dynamodb","@types/aws-lambda","yaml","zod"],resolutions:{"@smithy/types":"^4.12.0"},keywords:["cdk"],main:"lib/index.js",license:"Apache-2.0",version:"0.22.23",jest:{coverageProvider:"v8",maxWorkers:4,collectCoverageFrom:["src/**/*.ts"],coveragePathIgnorePatterns:["/node_modules/","\\.generated\\.[jt]s$","<rootDir>/test/","\\.warnings\\.jsii\\.js$"],testMatch:["<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)","<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)","<rootDir>/@(projenrc)/**/*(*.)@(spec|test).ts?(x)","<rootDir>/@(projenrc)/**/__tests__/**/*.ts?(x)"],clearMocks:!0,collectCoverage:!0,coverageReporters:["json","lcov","clover","cobertura","text"],coverageDirectory:"coverage",testPathIgnorePatterns:["/node_modules/"],watchPathIgnorePatterns:["/node_modules/"],reporters:["default",["jest-junit",{outputDirectory:"test-reports"}]],transform:{"^.+\\.[t]sx?$":["ts-jest",{tsconfig:"tsconfig.dev.json",diagnostics:!1}]}},types:"lib/index.d.ts",stability:"experimental",jsii:{outdir:"dist",targets:{},tsc:{outDir:"lib",rootDir:"src"},excludeTypescript:["src/cli/**"]},"//":'~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen".'}});var WPe=P(jPe(),1),{program:BKr,createCommand:HKr,createArgument:VKr,createOption:jKr,CommanderError:WKr,InvalidArgumentError:zKr,InvalidOptionArgumentError:KKr,Command:zPe,Argument:QKr,Option:YKr,Help:JKr}=WPe.default;var UMt=P(AE()),qMt=P(S3()),GMt=P(cpe()),BMt=P(Gb()),HMt=P(LSe()),VMt=P(uPe()),jMt=P(Fre());function xI(t){return{...t.region&&{region:t.region},...t.profile&&{credentials:(0,jMt.fromIni)({profile:t.profile})}}}function HS(t){return new UMt.CloudFormationClient(xI(t))}function bI(t){return new BMt.ECSClient(xI(t))}function t7(t){return new qMt.CloudWatchLogsClient(xI(t))}function WMt(t){return new GMt.CognitoIdentityProviderClient(xI(t))}function zMt(t){return new HMt.SecretsManagerClient(xI(t))}function KMt(t){return new VMt.SSMClient(xI(t))}function lPe(t){return{cfClient:HS(t),ecsClient:bI(t),logsClient:t7(t)}}var DI=P(Gb());var EN=P(S3());async function*SN(t,e={}){let n,r=0;for(;;){if(e.maxPages!==void 0&&r>=e.maxPages)return;let s=await t(n);if(r+=1,yield{...s,page:r},!s.nextToken)return;n=s.nextToken}}async function*$i(t,e={}){for await(let n of SN(t,e))for(let r of n.items)yield r}var zzr=50,Kzr=10;async function QMt(t,e,n,r,s=Kzr){let o=[];for await(let i of SN(async a=>{let c=await t.send(new EN.DescribeLogStreamsCommand({logGroupName:e,orderBy:"LastEventTime",descending:!0,limit:zzr,nextToken:a}));return{items:c.logStreams??[],nextToken:c.nextToken}},{maxPages:s})){let a=i.items;o.push(a.map(l=>l.logStreamName).filter(l=>l!==void 0));let c=a.find(l=>r?l.logStreamName?.endsWith(`/${r}/${n}`):l.logStreamName?.includes(n));if(c?.logStreamName)return c.logStreamName}return o.flatMap(i=>i).find(i=>i.includes(n))}async function dPe(t,e,n){let r=await t.send(new EN.GetLogEventsCommand({logGroupName:e.logGroup,logStreamName:e.logStreamName,limit:n,startFromHead:!1}));return{state:{key:e.key,serviceName:e.serviceName,containerName:e.containerName,logGroup:e.logGroup,logStreamName:e.logStreamName,nextToken:r.nextForwardToken},events:r.events??[]}}async function YMt(t,e){let n=await t.send(new EN.GetLogEventsCommand({logGroupName:e.logGroup,logStreamName:e.logStreamName,nextToken:e.nextToken}));return{events:n.events??[],nextToken:n.nextForwardToken}}function JMt(t){return new Map(t.map(e=>[e.key,e]))}function Qzr(t){let e=t.split("/");return e.length>=3?e[e.length-2]:void 0}async function Yzr(t,e,n){let r=[];for await(let s of $i(async o=>{let i=await t.send(new DI.ListTasksCommand({cluster:e,serviceName:n,desiredStatus:"RUNNING",nextToken:o}));return{items:i.taskArns??[],nextToken:i.nextToken}}))r.push(s);return r}async function XMt(t,e){let n=e.split("/").pop()??e,r=Qzr(e),o=(await t.send(new DI.DescribeServicesCommand({...r&&{cluster:r},services:[e]}))).services?.[0];if(!o)return{context:void 0,warning:`[${n}] Could not retrieve service details, skipping.`};let i=o.clusterArn??r;if(!i)return{context:void 0,warning:`[${n}] Could not determine cluster, skipping.`};let a=o.taskDefinition;if(!a)return{context:void 0,warning:`[${n}] Missing task definition, skipping.`};let l=((await t.send(new DI.DescribeTaskDefinitionCommand({taskDefinition:a}))).taskDefinition?.containerDefinitions??[]).flatMap(p=>{let d=p.logConfiguration?.options?.["awslogs-group"];return!p.name||!d||p.logConfiguration?.logDriver!=="awslogs"?[]:[{containerName:p.name,logGroup:d}]});return l.length===0?{context:void 0,warning:`[${n}] No awslogs container configuration found, skipping.`}:{context:{serviceArn:e,serviceName:n,clusterArn:i,logConfigs:l},warning:void 0}}async function pPe(t,e,n){let r=await Yzr(t,n.clusterArn,n.serviceArn),s=[],o=new Set;for(let i of r){let a=i.split("/").pop()??i;for(let{containerName:c,logGroup:l}of n.logConfigs){let p=await QMt(e,l,a,c);if(!p)continue;let d=`${l}::${p}`;o.has(d)||(o.add(d),s.push({key:d,serviceName:n.serviceName,containerName:c,logGroup:l,logStreamName:p}))}}return s}var ZMt=P(AE());async function e1t(t,e){let n=[];for await(let r of $i(async s=>{let o=await t.send(new ZMt.ListStackResourcesCommand({StackName:e,NextToken:s}));return{items:o.StackResourceSummaries??[],nextToken:o.NextToken}}))r.ResourceType==="AWS::ECS::Service"&&r.PhysicalResourceId&&n.push(r.PhysicalResourceId);return n}var Jzr=2e3,Xzr=1e4;function Zzr(t,e,n){if(!e)return t;let r=t.filter(s=>s.includes(e));if(r.length===0)throw new Error(`No ECS services matching '${e}' found in stack '${n}'.`);return r}function e6r(t,e){let n=[];for(let r of t)r.warning&&e.displayServiceWarning(r.warning),r.context&&n.push(r.context);return n}function mPe(t,e,n,r){t.displayLogEvents({serviceName:e.serviceName,containerName:e.containerName,events:n,mode:r})}async function t6r(t,e,n,r,s,o){let i=new Map;for(let a of t){let c=await pPe(e.ecsClient,e.logsClient,a);if(c.length===0){n.displayNoRunningStreams(a.serviceName);continue}(await Promise.all(c.map(async p=>{try{return{key:p.key,...await dPe(e.logsClient,p,o)}}catch(d){n.displayPrimeError(p,r.toErrorMessage(d));return}}))).filter(p=>p!==void 0).forEach(p=>{mPe(n,p.state,p.events,s),i.set(p.key,p.state)})}return i}async function n6r(t,e,n,r,s,o){(await Promise.all(Array.from(t.values()).filter(()=>o()).map(async a=>{try{let c=await YMt(e.logsClient,a);return mPe(n,a,c.events,s),{key:a.key,nextToken:c.nextToken}}catch(c){n.displayPollError(a,r.toErrorMessage(c));return}}))).filter(a=>a!==void 0).forEach(a=>{let c=t.get(a.key);c&&(c.nextToken=a.nextToken)})}async function r6r(t,e,n,r,s,o,i){let a=await Promise.all(t.map(async d=>{try{return await pPe(n.ecsClient,n.logsClient,d)}catch(S){return r.displayReconcileError(d.serviceName,s.toErrorMessage(S)),[]}})),c=JMt(a.flatMap(d=>d)),l=Array.from(c.entries()).filter(([d])=>!e.has(d));(await Promise.all(l.map(async([d,S])=>{try{return{key:d,stream:S,...await dPe(n.logsClient,S,i)}}catch(y){r.displayPrimeNewStreamError(S,s.toErrorMessage(y));return}}))).filter(d=>d!==void 0).forEach(d=>{mPe(r,d.state,d.events,o),e.set(d.key,d.state),r.displayStreamStarted(d.stream)}),Array.from(e.keys()).filter(d=>!c.has(d)).forEach(d=>{let S=e.get(d);e.delete(d),S&&r.displayStreamEnded(S)})}async function t1t(t,e,n,r,s=()=>!0){n.displayCommandContext({commandName:"ecs-logs",stackName:t.stackName,region:t.region});let o=await e1t(e.cfClient,t.stackName);if(o.length===0)throw new Error(`No ECS services found in stack '${t.stackName}'.`);let i=Zzr(o,t.service,t.stackName);t.output==="raw"&&i.length>1&&n.displayInterleavingWarning();let a=await Promise.all(i.map(d=>XMt(e.ecsClient,d))),c=e6r(a,n),l=await t6r(c,e,n,r,t.output,t.tail);if(!t.follow)return;l.size===0&&n.displayNoStreamsToFollow();let p=Date.now();for(;s()&&(await r.sleep(Jzr),!!s());)await n6r(l,e,n,r,t.output,s),!(Date.now()-p<Xzr)&&(await r6r(c,l,e,n,r,t.output,t.tail),p=Date.now())}var yN="\x1B[0m",n7="\x1B[1m",s6r="\x1B[2m",o6r="\x1B[31m",i6r="\x1B[36m";function _N(){return process.env.NO_COLOR!==void 0?!1:!!process.stdout.isTTY}function wI(t){let e=` \u{1F431} catnip \u2014 ${t} `,n=Math.max(e.length+2,44),r="\u2550".repeat(n);if(!_N()){console.log(`\u2554${r}\u2557`),console.log(`\u2551${e.padEnd(n)}\u2551`),console.log(`\u255A${r}\u255D`);return}console.log(`${i6r}${n7}\u2554${r}\u2557`),console.log(`\u2551${e.padEnd(n)}\u2551`),console.log(`\u255A${r}\u255D${yN}`)}function df(t){if(!_N()){console.log(`
251
+ `)}),n.join("")};DFt.exports={colorize:gKr,colorizeToArray:fKr,colorizeToCallback:wPe}});var kFt=F((O1s,LFt)=>{var{SequenceMatcher:hKr}=X1t(),{extendedTypeOf:g7,roundObj:$Ft}=bPe(),{colorize:OFt,colorizeToCallback:SKr}=wFt(),$Pe=class{constructor(e){e.outputKeys=e.outputKeys||[],e.excludeKeys=e.excludeKeys||[],this.options=e}isScalar(e){return typeof e!="object"||e===null}objectDiff(e,n){let r={},s=0,o=!0;for(let[i,a]of Object.entries(e))if(!this.options.outputNewOnly){let c="__deleted";!(i in n)&&!this.options.excludeKeys.includes(i)&&(r[`${i}${c}`]=a,s-=30,o=!1)}for(let[i,a]of Object.entries(n)){let c=this.options.outputNewOnly?"":"__added";!(i in e)&&!this.options.excludeKeys.includes(i)&&(r[`${i}${c}`]=a,s-=30,o=!1)}for(let[i,a]of Object.entries(e))if(i in n){if(this.options.excludeKeys.includes(i))continue;s+=20;let c=n[i],l=this.diff(a,c);l.equal?(this.options.full||this.options.outputKeys.includes(i))&&(r[i]=a):(r[i]=l.result,o=!1),s+=Math.min(20,Math.max(-10,l.score/5))}return o?(s=100*Math.max(Object.keys(e).length,.5),this.options.full||(r=void 0)):s=Math.max(0,s),{score:s,result:r,equal:o}}findMatchingObject(e,n,r){let s=null;for(let[o,{item:i,index:a}]of Object.entries(r))if(o!=="__next"){let c=Math.abs(a-n);if(g7(e)===g7(i)){let{score:l}=this.diff(e,i);(!s||l>s.score||l===s.score&&c<s.indexDistance)&&(s={score:l,key:o,indexDistance:c})}}return s}scalarize(e,n,r){let s=[];if(r){let i={};for(let a=0;a<e.length;a++){let c=e[a];if(this.isScalar(c))continue;let l=this.findMatchingObject(c,a,r);l&&(!i[l.key]||l.score>i[l.key].score)&&(i[l.key]={score:l.score,index:a})}for(let[a,c]of Object.entries(i))s[c.index]=a}let o=[];for(let i=0;i<e.length;i++){let a=e[i];if(this.isScalar(a))o.push(a);else{let c=s[i]||"__$!SCALAR"+n.__next++;n[c]={item:a,index:i},o.push(c)}}return o}isScalarized(e,n){return typeof e=="string"&&e in n}descalarize(e,n){return this.isScalarized(e,n)?n[e].item:e}arrayDiff(e,n){let r={__next:1},s=this.scalarize(e,r),o={__next:r.__next},i=this.scalarize(n,o,r);this.options.sort&&(s.sort(),i.sort());let a=new hKr(null,s,i).getOpcodes(),c=[],l=0,p=!0;for(let[d,S,y,C,A]of a){let b,$,k,j,W,J,ee,Z;switch(d==="equal"||this.options.keysOnly&&d==="replace"||(p=!1),d){case"equal":for(b=S,j=y,k=S<=j;k?b<j:b>j;k?b++:b--){let G=s[b];if(this.isScalarized(G,r)){if(!this.isScalarized(G,o))throw new Error(`internal bug: isScalarized(item, originals1) != isScalarized(item, originals2) for item ${JSON.stringify(G)}`);let H=this.descalarize(G,r),z=this.descalarize(G,o),Y=this.diff(H,z);Y.equal?this.options.full||this.options.keepUnchangedValues?c.push([" ",H]):c.push([" "]):(c.push(["~",Y.result]),p=!1)}else this.options.full||this.options.keepUnchangedValues?c.push([" ",G]):c.push([" "]);l+=10}break;case"delete":for(b=S,J=y,W=S<=J;W?b<J:b>J;W?b++:b--)c.push(["-",this.descalarize(s[b],r)]),l-=5;break;case"insert":for($=C,Z=A,ee=C<=Z;ee?$<Z:$>Z;ee?$++:$--)c.push(["+",this.descalarize(i[$],o)]),l-=5;break;case"replace":if(this.options.keysOnly){let G,H;for(b=S,H=y,G=S<=H;G?b<H:b>H;G?b++:b--){let z=this.diff(this.descalarize(s[b],r),this.descalarize(i[b-S+C],o));z.equal?c.push([" "]):(c.push(["~",z.result]),p=!1)}}else{let G,H,z,Y;for(b=S,H=y,G=S<=H;G?b<H:b>H;G?b++:b--)c.push(["-",this.descalarize(s[b],r)]),l-=5;for($=C,Y=A,z=C<=Y;z?$<Y:$>Y;z?$++:$--)c.push(["+",this.descalarize(i[$],o)]),l-=5}break}}return p||a.length===0?(this.options.full?c=e:c=void 0,l=100):l=Math.max(0,l),{score:l,result:c,equal:p}}diff(e,n){let r=g7(e),s=g7(n);if(r===s)switch(r){case"object":return this.objectDiff(e,n);case"array":return this.arrayDiff(e,n)}let o=100,i=e,a;return this.options.keysOnly?(a=!0,i=void 0):(r==="date"&&s==="date"?a=e.getTime()===n.getTime():a=e===n,a?this.options.full||(i=void 0):(o=0,this.options.outputNewOnly?i=n:i={__old:e,__new:n})),{score:o,result:i,equal:a}}};function NFt(t,e,n={}){return n.precision!==void 0&&(t=$Ft(t,n.precision),e=$Ft(e,n.precision)),new $Pe(n).diff(t,e).result}function EKr(t,e,n={}){return OFt(NFt(t,e,n),n)}LFt.exports={diff:NFt,diffString:EKr,colorize:OFt,colorizeToCallback:SKr}});var GFt=F((V1s,wKr)=>{wKr.exports={name:"@btc-embedded/cdk-extensions",description:"A collection of useful CDK extensions and common logic",repository:{type:"git",url:"https://github.com/btc-embedded/cdk-extensions.git"},bin:{catnip:"assets/cli/catnip.js"},scripts:{build:"npx projen build",bump:"npx projen bump",bundle:"npx projen bundle","bundle:cli/catnip":"npx projen bundle:cli/catnip","bundle:constructs/api-keys/lambdas/api-client-authorization.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-client-authorization.lambda","bundle:constructs/api-keys/lambdas/api-client-authorization.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-client-authorization.lambda:watch","bundle:constructs/api-keys/lambdas/api-key-creation.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-key-creation.lambda","bundle:constructs/api-keys/lambdas/api-key-creation.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-key-creation.lambda:watch","bundle:constructs/api-keys/lambdas/api-key-update.lambda":"npx projen bundle:constructs/api-keys/lambdas/api-key-update.lambda","bundle:constructs/api-keys/lambdas/api-key-update.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/api-key-update.lambda:watch","bundle:constructs/api-keys/lambdas/pre-token.lambda":"npx projen bundle:constructs/api-keys/lambdas/pre-token.lambda","bundle:constructs/api-keys/lambdas/pre-token.lambda:watch":"npx projen bundle:constructs/api-keys/lambdas/pre-token.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-client-authorization-runner.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda","bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner-unauthorized.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-management-runner.lambda:watch","bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda":"npx projen bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda","bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda:watch":"npx projen bundle:test/constructs/api-keys/integration/api-key-pre-token-handler-runner.lambda:watch",clobber:"npx projen clobber",compat:"npx projen compat",compile:"npx projen compile",default:"npx projen default",docgen:"npx projen docgen",eject:"npx projen eject",eslint:"npx projen eslint","eslint:ci":"npx projen eslint:ci",integ:"npx projen integ","integ:update":"npx projen integ:update",package:"npx projen package","package-all":"npx projen package-all","package:js":"npx projen package:js","post-compile":"npx projen post-compile","post-upgrade":"npx projen post-upgrade","pre-compile":"npx projen pre-compile","publish:git":"npx projen publish:git",release:"npx projen release",test:"npx projen test","test:watch":"npx projen test:watch",typecheck:"npx projen typecheck",unbump:"npx projen unbump","update-docs":"npx projen update-docs",upgrade:"npx projen upgrade",watch:"npx projen watch","yalc:watch":"npx projen yalc:watch",projen:"npx projen"},author:{name:"BTC Embedded Systems AG",url:"https://www.btc-embedded.com",organization:!0},devDependencies:{"@aws-cdk-containers/ecs-service-extensions":"2.0.1-alpha.535","@aws-cdk/integ-runner":"latest","@aws-cdk/integ-tests-alpha":"latest","@aws-sdk/client-cloudformation":"^3.993.0","@aws-sdk/client-cloudwatch-logs":"^3.993.0","@aws-sdk/client-ecs":"^3.993.0","@aws-sdk/client-ssm":"^3.999.0","@aws-sdk/credential-providers":"^3.993.0","@types/aws-api-gateway-client":"^0.3.3","@types/jest":"^30.0.0","@types/json-diff":"^1.0.3","@types/node":"^24.10.9","@types/url-template":"^3.0.0","@typescript-eslint/eslint-plugin":"^8","@typescript-eslint/parser":"^8","aws-api-gateway-client":"^0.3.7","aws-cdk-lib":"2.232.1","aws-sdk-client-mock":"^4.1.0","cdk-nag":"^2.37.55",commander:"^14.0.3","commit-and-tag-version":"^12",constructs:"10.0.5",esbuild:"^0.27.1",eslint:"^9","eslint-config-prettier":"^10.1.8","eslint-formatter-gitlab":"^7.0.1","eslint-import-resolver-typescript":"^4.4.4","eslint-plugin-import":"^2.32.0","eslint-plugin-prettier":"^5.5.5",jest:"^30.2.0","jest-junit":"^16",jsii:"~5.9.0","jsii-diff":"^1.125.0","jsii-docgen":"^10.5.0","jsii-pacmak":"^1.125.0","jsii-rosetta":"~5.9.0","json-diff":"^1.0.6",nodemon:"^3.1.11",prettier:"^3.8.0",projen:"^0.99.3","ts-jest":"^29.4.6","ts-node":"^10.9.2",typedoc:"^0.28.16","typedoc-plugin-markdown":"^4.9.0",typescript:"^5.9.3","url-template":"^3.1.1",yalc:"^1.0.0-pre.53"},peerDependencies:{"@aws-cdk-containers/ecs-service-extensions":">=2.0.1-alpha.535","aws-cdk-lib":"^2.232.1",constructs:"^10.0.5"},dependencies:{"@aws-lambda-powertools/logger":"^2.30.2","@aws-lambda-powertools/parameters":"^2.30.2","@aws-lambda-powertools/parser":"^2.30.2","@aws-sdk/client-cognito-identity-provider":"^3.965.0","@aws-sdk/client-dynamodb":"^3.948.0","@aws-sdk/client-secrets-manager":"^3.971.0","@aws-sdk/lib-dynamodb":"^3.948.0","@types/aws-lambda":"^8.10.159",yaml:"^2.8.2",zod:"~3"},bundledDependencies:["@aws-lambda-powertools/logger","@aws-lambda-powertools/parameters","@aws-lambda-powertools/parser","@aws-sdk/client-cognito-identity-provider","@aws-sdk/client-dynamodb","@aws-sdk/client-secrets-manager","@aws-sdk/lib-dynamodb","@types/aws-lambda","yaml","zod"],resolutions:{"@smithy/types":"^4.12.0"},keywords:["cdk"],main:"lib/index.js",license:"Apache-2.0",version:"0.22.24",jest:{coverageProvider:"v8",maxWorkers:4,collectCoverageFrom:["src/**/*.ts"],coveragePathIgnorePatterns:["/node_modules/","\\.generated\\.[jt]s$","<rootDir>/test/","\\.warnings\\.jsii\\.js$"],testMatch:["<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)","<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)","<rootDir>/@(projenrc)/**/*(*.)@(spec|test).ts?(x)","<rootDir>/@(projenrc)/**/__tests__/**/*.ts?(x)"],clearMocks:!0,collectCoverage:!0,coverageReporters:["json","lcov","clover","cobertura","text"],coverageDirectory:"coverage",testPathIgnorePatterns:["/node_modules/"],watchPathIgnorePatterns:["/node_modules/"],reporters:["default",["jest-junit",{outputDirectory:"test-reports"}]],transform:{"^.+\\.[t]sx?$":["ts-jest",{tsconfig:"tsconfig.dev.json",diagnostics:!1}]}},types:"lib/index.d.ts",stability:"experimental",jsii:{outdir:"dist",targets:{},tsc:{outDir:"lib",rootDir:"src"},excludeTypescript:["src/cli/**"]},"//":'~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen".'}});var WPe=P(jPe(),1),{program:BKr,createCommand:HKr,createArgument:VKr,createOption:jKr,CommanderError:WKr,InvalidArgumentError:zKr,InvalidOptionArgumentError:KKr,Command:zPe,Argument:QKr,Option:YKr,Help:JKr}=WPe.default;var UMt=P(AE()),qMt=P(S3()),GMt=P(cpe()),BMt=P(Gb()),HMt=P(LSe()),VMt=P(uPe()),jMt=P(Fre());function xI(t){return{...t.region&&{region:t.region},...t.profile&&{credentials:(0,jMt.fromIni)({profile:t.profile})}}}function HS(t){return new UMt.CloudFormationClient(xI(t))}function bI(t){return new BMt.ECSClient(xI(t))}function t7(t){return new qMt.CloudWatchLogsClient(xI(t))}function WMt(t){return new GMt.CognitoIdentityProviderClient(xI(t))}function zMt(t){return new HMt.SecretsManagerClient(xI(t))}function KMt(t){return new VMt.SSMClient(xI(t))}function lPe(t){return{cfClient:HS(t),ecsClient:bI(t),logsClient:t7(t)}}var DI=P(Gb());var EN=P(S3());async function*SN(t,e={}){let n,r=0;for(;;){if(e.maxPages!==void 0&&r>=e.maxPages)return;let s=await t(n);if(r+=1,yield{...s,page:r},!s.nextToken)return;n=s.nextToken}}async function*$i(t,e={}){for await(let n of SN(t,e))for(let r of n.items)yield r}var zzr=50,Kzr=10;async function QMt(t,e,n,r,s=Kzr){let o=[];for await(let i of SN(async a=>{let c=await t.send(new EN.DescribeLogStreamsCommand({logGroupName:e,orderBy:"LastEventTime",descending:!0,limit:zzr,nextToken:a}));return{items:c.logStreams??[],nextToken:c.nextToken}},{maxPages:s})){let a=i.items;o.push(a.map(l=>l.logStreamName).filter(l=>l!==void 0));let c=a.find(l=>r?l.logStreamName?.endsWith(`/${r}/${n}`):l.logStreamName?.includes(n));if(c?.logStreamName)return c.logStreamName}return o.flatMap(i=>i).find(i=>i.includes(n))}async function dPe(t,e,n){let r=await t.send(new EN.GetLogEventsCommand({logGroupName:e.logGroup,logStreamName:e.logStreamName,limit:n,startFromHead:!1}));return{state:{key:e.key,serviceName:e.serviceName,containerName:e.containerName,logGroup:e.logGroup,logStreamName:e.logStreamName,nextToken:r.nextForwardToken},events:r.events??[]}}async function YMt(t,e){let n=await t.send(new EN.GetLogEventsCommand({logGroupName:e.logGroup,logStreamName:e.logStreamName,nextToken:e.nextToken}));return{events:n.events??[],nextToken:n.nextForwardToken}}function JMt(t){return new Map(t.map(e=>[e.key,e]))}function Qzr(t){let e=t.split("/");return e.length>=3?e[e.length-2]:void 0}async function Yzr(t,e,n){let r=[];for await(let s of $i(async o=>{let i=await t.send(new DI.ListTasksCommand({cluster:e,serviceName:n,desiredStatus:"RUNNING",nextToken:o}));return{items:i.taskArns??[],nextToken:i.nextToken}}))r.push(s);return r}async function XMt(t,e){let n=e.split("/").pop()??e,r=Qzr(e),o=(await t.send(new DI.DescribeServicesCommand({...r&&{cluster:r},services:[e]}))).services?.[0];if(!o)return{context:void 0,warning:`[${n}] Could not retrieve service details, skipping.`};let i=o.clusterArn??r;if(!i)return{context:void 0,warning:`[${n}] Could not determine cluster, skipping.`};let a=o.taskDefinition;if(!a)return{context:void 0,warning:`[${n}] Missing task definition, skipping.`};let l=((await t.send(new DI.DescribeTaskDefinitionCommand({taskDefinition:a}))).taskDefinition?.containerDefinitions??[]).flatMap(p=>{let d=p.logConfiguration?.options?.["awslogs-group"];return!p.name||!d||p.logConfiguration?.logDriver!=="awslogs"?[]:[{containerName:p.name,logGroup:d}]});return l.length===0?{context:void 0,warning:`[${n}] No awslogs container configuration found, skipping.`}:{context:{serviceArn:e,serviceName:n,clusterArn:i,logConfigs:l},warning:void 0}}async function pPe(t,e,n){let r=await Yzr(t,n.clusterArn,n.serviceArn),s=[],o=new Set;for(let i of r){let a=i.split("/").pop()??i;for(let{containerName:c,logGroup:l}of n.logConfigs){let p=await QMt(e,l,a,c);if(!p)continue;let d=`${l}::${p}`;o.has(d)||(o.add(d),s.push({key:d,serviceName:n.serviceName,containerName:c,logGroup:l,logStreamName:p}))}}return s}var ZMt=P(AE());async function e1t(t,e){let n=[];for await(let r of $i(async s=>{let o=await t.send(new ZMt.ListStackResourcesCommand({StackName:e,NextToken:s}));return{items:o.StackResourceSummaries??[],nextToken:o.NextToken}}))r.ResourceType==="AWS::ECS::Service"&&r.PhysicalResourceId&&n.push(r.PhysicalResourceId);return n}var Jzr=2e3,Xzr=1e4;function Zzr(t,e,n){if(!e)return t;let r=t.filter(s=>s.includes(e));if(r.length===0)throw new Error(`No ECS services matching '${e}' found in stack '${n}'.`);return r}function e6r(t,e){let n=[];for(let r of t)r.warning&&e.displayServiceWarning(r.warning),r.context&&n.push(r.context);return n}function mPe(t,e,n,r){t.displayLogEvents({serviceName:e.serviceName,containerName:e.containerName,events:n,mode:r})}async function t6r(t,e,n,r,s,o){let i=new Map;for(let a of t){let c=await pPe(e.ecsClient,e.logsClient,a);if(c.length===0){n.displayNoRunningStreams(a.serviceName);continue}(await Promise.all(c.map(async p=>{try{return{key:p.key,...await dPe(e.logsClient,p,o)}}catch(d){n.displayPrimeError(p,r.toErrorMessage(d));return}}))).filter(p=>p!==void 0).forEach(p=>{mPe(n,p.state,p.events,s),i.set(p.key,p.state)})}return i}async function n6r(t,e,n,r,s,o){(await Promise.all(Array.from(t.values()).filter(()=>o()).map(async a=>{try{let c=await YMt(e.logsClient,a);return mPe(n,a,c.events,s),{key:a.key,nextToken:c.nextToken}}catch(c){n.displayPollError(a,r.toErrorMessage(c));return}}))).filter(a=>a!==void 0).forEach(a=>{let c=t.get(a.key);c&&(c.nextToken=a.nextToken)})}async function r6r(t,e,n,r,s,o,i){let a=await Promise.all(t.map(async d=>{try{return await pPe(n.ecsClient,n.logsClient,d)}catch(S){return r.displayReconcileError(d.serviceName,s.toErrorMessage(S)),[]}})),c=JMt(a.flatMap(d=>d)),l=Array.from(c.entries()).filter(([d])=>!e.has(d));(await Promise.all(l.map(async([d,S])=>{try{return{key:d,stream:S,...await dPe(n.logsClient,S,i)}}catch(y){r.displayPrimeNewStreamError(S,s.toErrorMessage(y));return}}))).filter(d=>d!==void 0).forEach(d=>{mPe(r,d.state,d.events,o),e.set(d.key,d.state),r.displayStreamStarted(d.stream)}),Array.from(e.keys()).filter(d=>!c.has(d)).forEach(d=>{let S=e.get(d);e.delete(d),S&&r.displayStreamEnded(S)})}async function t1t(t,e,n,r,s=()=>!0){n.displayCommandContext({commandName:"ecs-logs",stackName:t.stackName,region:t.region});let o=await e1t(e.cfClient,t.stackName);if(o.length===0)throw new Error(`No ECS services found in stack '${t.stackName}'.`);let i=Zzr(o,t.service,t.stackName);t.output==="raw"&&i.length>1&&n.displayInterleavingWarning();let a=await Promise.all(i.map(d=>XMt(e.ecsClient,d))),c=e6r(a,n),l=await t6r(c,e,n,r,t.output,t.tail);if(!t.follow)return;l.size===0&&n.displayNoStreamsToFollow();let p=Date.now();for(;s()&&(await r.sleep(Jzr),!!s());)await n6r(l,e,n,r,t.output,s),!(Date.now()-p<Xzr)&&(await r6r(c,l,e,n,r,t.output,t.tail),p=Date.now())}var yN="\x1B[0m",n7="\x1B[1m",s6r="\x1B[2m",o6r="\x1B[31m",i6r="\x1B[36m";function _N(){return process.env.NO_COLOR!==void 0?!1:!!process.stdout.isTTY}function wI(t){let e=` \u{1F431} catnip \u2014 ${t} `,n=Math.max(e.length+2,44),r="\u2550".repeat(n);if(!_N()){console.log(`\u2554${r}\u2557`),console.log(`\u2551${e.padEnd(n)}\u2551`),console.log(`\u255A${r}\u255D`);return}console.log(`${i6r}${n7}\u2554${r}\u2557`),console.log(`\u2551${e.padEnd(n)}\u2551`),console.log(`\u255A${r}\u255D${yN}`)}function df(t){if(!_N()){console.log(`
252
252
  ${t}`);return}console.log(`
253
253
  ${n7}${t}${yN}`)}function VS(t){if(!_N()){process.stderr.write(`Error: ${t}
254
254
  `);return}process.stderr.write(`${o6r}${n7}Error:${yN} ${t}
@@ -145,5 +145,5 @@ class EventPipe extends construct_1.Construct {
145
145
  }
146
146
  exports.EventPipe = EventPipe;
147
147
  _a = JSII_RTTI_SYMBOL_1;
148
- EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.22.23" };
148
+ EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.22.24" };
149
149
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventPipe.js","sourceRoot":"","sources":["../../src/constructs/EventPipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Annotations } from \"aws-cdk-lib\";\nimport { Role, ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { ILogGroup } from \"aws-cdk-lib/aws-logs\";\nimport { CfnPipe } from \"aws-cdk-lib/aws-pipes\";\nimport { IQueue } from \"aws-cdk-lib/aws-sqs\";\nimport { IStateMachine } from \"aws-cdk-lib/aws-stepfunctions\";\nimport { Construct } from \"constructs/lib/construct\";\nimport { BTCLogGroup } from \"../platform\";\nimport { isDeactivatedConstruct } from \"../utils/deactivatedConstruct\";\n\n/**\n * Properties for pipe construction.\n */\nexport interface EventPipeProps {\n  /**\n   * The source SQS queue. No other source types are supported at the moment.\n   */\n  readonly source: IQueue;\n\n  /**\n   * The target SQS queue or target step function.\n   */\n  readonly target: TargetQueue | TargetStepFunction;\n\n  /**\n   * The role used by the event pipe. If omitted, a new role is created.\n   */\n  readonly role?: Role;\n\n  /**\n   * An optional filter for the pipe.\n   */\n  readonly filter?: PipeFilter;\n\n  /**\n   * Set the log level for the pipe. Creates a new log group, if enabled.\n   * Default: Disabled.\n   */\n  readonly logLevel?: LogLevel;\n\n  /**\n   * Use an existing log group. If none is given and logging is enabled, a new log group will be created.\n   */\n  readonly logGroup?: ILogGroup;\n}\n\nexport enum LogLevel {\n  /**\n   * Deactivate logging. No log group will be created.\n   */\n  OFF = \"OFF\",\n  /**\n   * Only log errors.\n   */\n  ERROR = \"ERROR\",\n  /**\n   * Log errors and informational messages.\n   */\n  INFO = \"INFO\",\n  /**\n   * Log very verbose.\n   */\n  TRACE = \"TRACE\",\n}\n\n/**\n * The invocation type of the step function.\n */\nexport enum InvocationType {\n  /**\n   * (default) - Invoke synchronously. For more information, see\n   * [StartSyncExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartSyncExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   * > `REQUEST_RESPONSE` is not supported for `STANDARD` state machine workflows.\n   */\n  REQUEST_RESPONSE,\n  /**\n   * Invoke asynchronously. For more information, see\n   * [StartExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   */\n  FIRE_AND_FORGET,\n}\n\n/**\n * The input template.\n * Note that some values in the resulting code should not have quotes around the value, e.g. if an object\n * shall be added. To reflect this, add curly brackets around the value, e.g. `{{<$.body>}}`.\n */\nexport interface InputTemplate {\n  /**\n   * @jsii ignore\n   */\n  readonly [key: string]: string;\n}\n\n/**\n * SQS queue as pipe target.\n */\nexport interface TargetQueue {\n  readonly queue: IQueue;\n}\n\n/**\n * StepFunction as pipe target.\n */\nexport interface TargetStepFunction {\n  readonly stepFunction: IStateMachine;\n  readonly parameters?: TargetStepFunctionParameters;\n}\n\n/**\n * Parameters for a step function target.\n */\nexport interface TargetStepFunctionParameters {\n  readonly inputTemplate?: InputTemplate;\n  readonly invocationType?: InvocationType;\n}\n\n/**\n * Base type for filter rules. Not all available rules are currently implemented.\n */\nexport type FilterRule =\n  | PrefixFilterRule\n  | SuffixFilterRule\n  | AnythingButFilterRule\n  | FilterEqualsIgnoreCase;\n\n/**\n * Rule that a property has to start with a prefix.\n */\nexport interface PrefixFilterRule {\n  readonly prefix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that a property has to end with a suffix.\n */\nexport interface SuffixFilterRule {\n  readonly suffix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that allows all values except the given ones.\n */\nexport interface AnythingButFilterRule {\n  /**\n   * @jsii ignore\n   */\n  readonly \"anything-but\": string[] | FilterRule;\n}\n\n/**\n * Rule that matches a string, ignoring the case.\n */\nexport interface FilterEqualsIgnoreCase {\n  /**\n   * @jsii ignore\n   */\n  readonly \"equals-ignore-case\": string | string[];\n}\n\n/**\n * A filter for messages in the pipe.\n */\nexport interface PipeFilter {\n  /**\n   * The rules for each attribute of the body.\n   * @jsii ignore\n   */\n  readonly [key: string]: FilterRule[];\n}\n\n/**\n * A wrapper for the L1 event pipe with the ability to deactivate it within the stack.\n */\nexport class EventPipe extends Construct {\n  public readonly role: Role;\n\n  constructor(scope: Construct, id: string, props: EventPipeProps) {\n    super(scope, id);\n\n    let targetStepFunction =\n      \"stepFunction\" in props.target ? props.target.stepFunction : undefined;\n    let targetStepFunctionParameters =\n      \"parameters\" in props.target ? props.target.parameters : undefined;\n\n    let targetQueue = \"queue\" in props.target ? props.target.queue : undefined;\n\n    let sqsTarget = targetQueue !== undefined;\n\n    let targetArn = sqsTarget\n      ? targetQueue!.queueArn\n      : targetStepFunction!.stateMachineArn;\n\n    let desiredState = \"RUNNING\";\n    if (isDeactivatedConstruct(id)) {\n      Annotations.of(this).addInfo(`${id} is set do be deactivated.`);\n      desiredState = \"STOPPED\";\n    }\n\n    this.role =\n      props.role ||\n      new Role(this, \"EventPipeRole\", {\n        assumedBy: new ServicePrincipal(\"pipes.amazonaws.com\"),\n      });\n\n    let filterCriteria = props.filter\n      ? {\n          filters: [\n            {\n              pattern: JSON.stringify({\n                body: {\n                  ...props.filter,\n                },\n              }),\n            },\n          ],\n        }\n      : undefined;\n\n    let targetParameters: CfnPipe.PipeTargetParametersProperty = {};\n    if (targetQueue) {\n      targetParameters = {\n        sqsQueueParameters: {\n          messageGroupId: \"default\",\n        },\n      };\n    } else {\n      targetParameters = {\n        stepFunctionStateMachineParameters: {\n          invocationType: targetStepFunctionParameters?.invocationType\n            ? InvocationType[targetStepFunctionParameters.invocationType]\n            : InvocationType[InvocationType.REQUEST_RESPONSE],\n        },\n        ...(targetStepFunctionParameters?.inputTemplate && {\n          inputTemplate: JSON.stringify(\n            targetStepFunctionParameters.inputTemplate,\n          ).replace(/\"\\{\\{(.+?)\\}\\}\"/, \"$1\"),\n        }),\n      };\n    }\n\n    let sourceParameters = {\n      sqsQueueParameters: {\n        batchSize: 1,\n      },\n      ...(filterCriteria && { filterCriteria: filterCriteria }),\n    };\n\n    const logGroup = this.loggingEnabled(props)\n      ? (props.logGroup ??\n        new BTCLogGroup(this, \"EventPipeLogGroup\", {\n          logType: \"event-pipe\",\n        }))\n      : undefined;\n\n    const pipeConfiguration = this.loggingEnabled(props)\n      ? {\n          logConfiguration: {\n            cloudwatchLogsLogDestination: {\n              logGroupArn: logGroup!.logGroupArn,\n            },\n            level: props.logLevel,\n          },\n        }\n      : {};\n\n    new CfnPipe(this, \"EventPipe\", {\n      ...pipeConfiguration,\n      roleArn: this.role.roleArn,\n      source: props.source.queueArn,\n      target: targetArn,\n      sourceParameters: sourceParameters,\n      targetParameters: targetParameters,\n      desiredState: desiredState,\n    });\n\n    props.source.grantConsumeMessages(this.role);\n    targetQueue?.grantSendMessages(this.role);\n    targetStepFunction?.grantStartExecution(this.role);\n    logGroup?.grantWrite(this.role);\n  }\n\n  private loggingEnabled(props: EventPipeProps): boolean {\n    return props.logLevel !== undefined && props.logLevel !== LogLevel.OFF;\n  }\n}\n"]}
@@ -135,5 +135,5 @@ class ExportedService extends ExportedServiceBase {
135
135
  }
136
136
  exports.ExportedService = ExportedService;
137
137
  _a = JSII_RTTI_SYMBOL_1;
138
- ExportedService[_a] = { fqn: "@btc-embedded/cdk-extensions.ExportedService", version: "0.22.23" };
138
+ ExportedService[_a] = { fqn: "@btc-embedded/cdk-extensions.ExportedService", version: "0.22.24" };
139
139
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExportedService.js","sourceRoot":"","sources":["../../src/constructs/ExportedService.ts"],"names":[],"mappings":"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","sourcesContent":["import { Service } from \"@aws-cdk-containers/ecs-service-extensions\";\nimport {\n  IConnectable,\n  ISecurityGroup,\n  Port,\n  SecurityGroup,\n} from \"aws-cdk-lib/aws-ec2\";\nimport { Construct } from \"constructs\";\nimport { StackParameter } from \"../utils\";\nimport { kebabCase } from \"../utils/common\";\n\n/**\n * Options for importing an ExportedService from another stack.\n */\nexport interface ExportedServiceLookupOptions {\n  /**\n   * The name of the stack where the service was exported.\n   */\n  readonly stackName: string;\n\n  /**\n   * The name of the exported ECS service.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The port on which the service is listening.\n   */\n  readonly port: number;\n}\n\n/**\n * Public interface for an ExportedService.\n */\nexport interface IExportedService extends IConnectable {\n  /**\n   * The security group of the exported ECS service.\n   */\n  readonly securityGroup: ISecurityGroup;\n\n  /**\n   * Get the internal API URL of the service.\n   */\n  apiUrl(): string;\n\n  /**\n   * Allow an ECS service to connect to this exported service.\n   */\n  allowFrom(service: Service, description?: string): void;\n}\n\n/**\n * Properties for creating a new ExportedService.\n */\nexport interface ExportedServiceProps {\n  /**\n   * The name of the ECS service being exported.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The security group of the ECS service.\n   */\n  readonly securityGroup: ISecurityGroup;\n\n  /**\n   * The namespace name where the service is registered (CloudMap namespace).\n   */\n  readonly namespaceName: string;\n}\n\n/**\n * Base class for an ECS service that can be used across stack boundaries.\n *\n * This abstract class provides common functionality for working with exported\n * ECS services, including API URL generation and connection management.\n */\nabstract class ExportedServiceBase\n  extends Construct\n  implements IExportedService\n{\n  protected readonly serviceName: string;\n  protected readonly namespaceName: string;\n  protected readonly port: number;\n  public readonly securityGroup: ISecurityGroup;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    serviceName: string,\n    namespaceName: string,\n    port: number,\n    securityGroup: ISecurityGroup,\n  ) {\n    super(scope, id);\n    this.serviceName = serviceName;\n    this.namespaceName = namespaceName;\n    this.port = port;\n    this.securityGroup = securityGroup;\n  }\n\n  /**\n   * Get the internal API URL of the service.\n   *\n   * The URL format is: http://<service-name>.<namespace>:<port>/\n   *\n   * @returns The internal API URL\n   */\n  public apiUrl(): string {\n    return `http://${this.serviceName}.${this.namespaceName}:${this.port}/`;\n  }\n\n  /**\n   * Get the connections object for this service.\n   *\n   * This allows the ExportedService to be used with the standard CDK IConnectable\n   * pattern for security group management.\n   */\n  get connections() {\n    return this.securityGroup.connections;\n  }\n\n  /**\n   * Allow an ECS service to connect to this exported service.\n   *\n   * This method adds a security group ingress rule allowing traffic from the\n   * given service to this exported service on its configured port.\n   *\n   * @param service - The ECS service to allow connections from\n   * @param description - Optional description for the security group rule\n   */\n  public allowFrom(\n    service: Service,\n    description: string = \"Allow connection from ECS service\",\n  ): void {\n    this.securityGroup.connections.allowFrom(\n      service.ecsService,\n      Port.tcp(this.port),\n      description,\n    );\n  }\n}\n\n/**\n * Represents an ECS service exported from another CDK stack.\n *\n * This construct enables cross-stack service connectivity by transporting service\n * metadata (security group ID and namespace) across stack boundaries using StackParameter.\n * The port must be specified when importing the service.\n *\n * On the provider side (where the service is defined), use ExportedService\n * within the CloudMapExtension to expose the service. On the consumer side,\n * use ExportedService.fromAttributes() to import the service with the port.\n *\n * @example\n * // Provider side\n * const exportedService = new ExportedService(this, \"ExportedService\", {\n *   serviceName: 'my-service',\n *   securityGroup: service.connections.securityGroups[0],\n *   namespaceName: 'my-namespace',\n * });\n *\n * @example\n * // Consumer side\n * const exportedService = ExportedService.fromAttributes(scope, id, {\n *   stackName: 'my-service-stack',\n *   serviceName: 'my-service',\n *   port: 8080,\n * });\n *\n * exportedService.allowFrom(myService);\n * const url = exportedService.apiUrl();\n */\nexport class ExportedService extends ExportedServiceBase {\n  /**\n   * Import an ExportedService from another stack.\n   *\n   * This method imports the service metadata (security group and namespace)\n   * that was exported by the provider stack and constructs an IExportedService\n   * instance that can be used for establishing connections.\n   *\n   * @param scope - The scope in which to define the construct\n   * @param id - The construct ID\n   * @param attrs - The exported service lookup options (stackName, serviceName, and port)\n   * @returns An IExportedService instance\n   */\n  public static fromAttributes(\n    scope: Construct,\n    id: string,\n    attrs: ExportedServiceLookupOptions,\n  ): IExportedService {\n    const normalizedServiceName = kebabCase(attrs.serviceName);\n    const stackParameters = ExportedService.createStackParameters(\n      normalizedServiceName,\n    );\n\n    const securityGroupId = stackParameters.securityGroupParameter.import(\n      scope,\n      attrs.stackName,\n    );\n    const namespaceName = stackParameters.namespaceParameter.import(\n      scope,\n      attrs.stackName,\n    );\n\n    const securityGroup = SecurityGroup.fromSecurityGroupId(\n      scope,\n      \"ImportedSecurityGroup\",\n      securityGroupId,\n      { allowAllOutbound: true },\n    );\n\n    class Import extends ExportedServiceBase {\n      constructor() {\n        super(\n          scope,\n          id,\n          normalizedServiceName,\n          namespaceName,\n          attrs.port,\n          securityGroup,\n        );\n      }\n    }\n\n    return new Import();\n  }\n  private static createStackParameters(serviceName: string) {\n    return {\n      securityGroupParameter: new StackParameter({\n        prefix: [\"exported-service\", serviceName],\n        key: \"security-group-id\",\n        description: \"Security Group ID of the exported ECS service\",\n      }),\n      namespaceParameter: new StackParameter({\n        prefix: [\"exported-service\", serviceName],\n        key: \"namespace\",\n        description: \"CloudMap namespace of the exported ECS service\",\n      }),\n    };\n  }\n\n  private readonly stackParameters: ReturnType<\n    typeof ExportedService.createStackParameters\n  >;\n\n  constructor(scope: Construct, id: string, props: ExportedServiceProps) {\n    const normalizedServiceName = kebabCase(props.serviceName);\n    super(\n      scope,\n      id,\n      normalizedServiceName,\n      props.namespaceName,\n      0, // Default port - actual port is specified on consumer side\n      props.securityGroup,\n    );\n\n    this.stackParameters = ExportedService.createStackParameters(\n      normalizedServiceName,\n    );\n\n    // Export service metadata for cross-stack consumption\n    this.stackParameters.securityGroupParameter.export(\n      this,\n      props.securityGroup.securityGroupId,\n    );\n    this.stackParameters.namespaceParameter.export(this, props.namespaceName);\n  }\n}\n"]}
@@ -35,5 +35,5 @@ class S3Bucket extends aws_s3_1.Bucket {
35
35
  }
36
36
  exports.S3Bucket = S3Bucket;
37
37
  _a = JSII_RTTI_SYMBOL_1;
38
- S3Bucket[_a] = { fqn: "@btc-embedded/cdk-extensions.S3Bucket", version: "0.22.23" };
38
+ S3Bucket[_a] = { fqn: "@btc-embedded/cdk-extensions.S3Bucket", version: "0.22.24" };
39
39
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUzNCdWNrZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uc3RydWN0cy9TM0J1Y2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUFtRTtBQUNuRSwrQ0FBeUQ7QUFFekQsb0NBQTRDO0FBRTVDLFNBQVMsV0FBVyxDQUNsQixLQUFnQixFQUNoQixFQUFVLEVBQ1YsS0FBbUI7SUFFbkIsSUFBSSxJQUFBLHdCQUFnQixHQUFFLEVBQUUsQ0FBQztRQUN2Qix5QkFBVyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQzNCLEdBQUcsRUFBRSx5RUFBeUUsQ0FDL0UsQ0FBQztRQUNGLE9BQU87WUFDTCxHQUFHLEtBQUs7WUFDUixhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO1lBQ3BDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsY0FBYyxFQUFFO2dCQUNkO29CQUNFLFVBQVUsRUFBRSxzQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7b0JBQzVCLG1DQUFtQyxFQUFFLHNCQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDdEQ7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0lBQ0QsT0FBTyxFQUFFLEdBQUcsS0FBSyxFQUFFLENBQUM7QUFDdEIsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxNQUFhLFFBQVMsU0FBUSxlQUFNO0lBQ2xDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBbUI7UUFDM0QsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsV0FBVyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNsRCxDQUFDOztBQUhILDRCQUlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQW5ub3RhdGlvbnMsIER1cmF0aW9uLCBSZW1vdmFsUG9saWN5IH0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBCdWNrZXQsIEJ1Y2tldFByb3BzIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1zM1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IGlzRGV2ZWxvcGVyU3RhY2sgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuZnVuY3Rpb24gYWRqdXN0UHJvcHMoXG4gIHNjb3BlOiBDb25zdHJ1Y3QsXG4gIGlkOiBzdHJpbmcsXG4gIHByb3BzPzogQnVja2V0UHJvcHMsXG4pOiBCdWNrZXRQcm9wcyB7XG4gIGlmIChpc0RldmVsb3BlclN0YWNrKCkpIHtcbiAgICBBbm5vdGF0aW9ucy5vZihzY29wZSkuYWRkSW5mbyhcbiAgICAgIGAke2lkfSBpcyBkZXBsb3llZCBpbiBhIGRldmVsb3BlciB2YXJpYW50LiBGaWxlcyB3aWxsIGJlIHJldGFpbmVkIGZvciAzIGRheXMuYCxcbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuREVTVFJPWSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiB0cnVlLFxuICAgICAgbGlmZWN5Y2xlUnVsZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGV4cGlyYXRpb246IER1cmF0aW9uLmRheXMoMyksXG4gICAgICAgICAgYWJvcnRJbmNvbXBsZXRlTXVsdGlwYXJ0VXBsb2FkQWZ0ZXI6IER1cmF0aW9uLmRheXMoMSksXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHsgLi4ucHJvcHMgfTtcbn1cblxuLyoqXG4gKiBXcmFwcGVyIGZvciB0aGUge0BsaW5rIEJ1Y2tldH0gY29uc3RydWN0cyB0aGF0IGFkZHMgYWRkaXRpb25hbCBwcm9wZXJ0aWVzLCBpZiBhIGRldmVsb3BlclxuICogc3RhY2sgaXMgZGV0ZWN0ZWQuIFdpbGwgY2F1c2UgZmlsZXMgdG8gZXhwaXJlIGFmdGVyIHRyZWUgZGF5cyBhbmQgYWxsb3dzIHRvIGRlbGV0ZSB0aGVcbiAqIGJ1Y2tldCBhbmQgYWxsIGl0cyBjb250ZW50cywgaWYgdGhlIHN0YWNrIGlzIGRlbGV0ZWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBTM0J1Y2tldCBleHRlbmRzIEJ1Y2tldCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogQnVja2V0UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIGFkanVzdFByb3BzKHNjb3BlLCBpZCwgcHJvcHMpKTtcbiAgfVxufVxuIl19
@@ -55,5 +55,5 @@ class SecureRestApi extends construct_1.Construct {
55
55
  }
56
56
  exports.SecureRestApi = SecureRestApi;
57
57
  _a = JSII_RTTI_SYMBOL_1;
58
- SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.22.23" };
58
+ SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.22.24" };
59
59
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrREFJb0M7QUFDcEMsK0VBRzRDO0FBQzVDLHlEQUFtRDtBQUNuRCx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELDBDQUFrQztBQUNsQyxvQ0FBMEM7QUF1QjFDOztHQUVHO0FBQ0gsTUFBYSxhQUFjLFNBQVEscUJBQVM7SUFRMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF5QjtRQUNqRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLG9CQUFvQjtRQUNwQixJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUM5QyxDQUFDO1FBRUQsTUFBTSwwQkFBMEIsR0FBRyxJQUFJLHNCQUFjLENBQUM7WUFDcEQsTUFBTSxFQUFFLFNBQVM7WUFDakIsR0FBRyxFQUFFLGNBQWM7U0FDcEIsQ0FBQyxDQUFDO1FBRUgsTUFBTSxpQkFBaUIsR0FBRywwQkFBMEIsQ0FBQyxNQUFNLENBQ3pELElBQUksRUFDSixLQUFLLENBQUMscUJBQXFCLENBQzVCLENBQUM7UUFDRixNQUFNLFdBQVcsR0FBRyxzQkFBUSxDQUFDLGNBQWMsQ0FDekMsSUFBSSxFQUNKLGFBQWEsRUFDYixpQkFBaUIsQ0FDbEIsQ0FBQztRQUVGLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxjQUFHLENBQUMsZ0JBQWdCLENBQ25DLElBQUksRUFDSixRQUFRLEVBQ1IsS0FBSyxDQUFDLHFCQUFxQixDQUM1QixDQUFDO1FBQ0YsTUFBTSxVQUFVLEdBQ2QsS0FBSyxDQUFDLFVBQVU7WUFDaEIsd0JBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtnQkFDeEMsVUFBVSxFQUFFLElBQUk7YUFDakIsQ0FBQyxDQUFDO1FBQ0wsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLEtBQUssQ0FBQyxZQUFZLElBQUksVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBRWpFLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxvQ0FBVyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDdEQsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO1lBQzNCLFVBQVUsRUFBRSw4Q0FBcUIsQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO1NBQ3RELENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLDJDQUEwQixDQUNyRCxJQUFJLEVBQ0osbUJBQW1CLEVBQ25CO1lBQ0UsZ0JBQWdCLEVBQUUsQ0FBQyxXQUFXLENBQUM7U0FDaEMsQ0FDRixDQUFDO1FBRUYsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLHdCQUFPLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUMxQyxHQUFHLEtBQUssQ0FBQyxZQUFZO1lBQ3JCLG9CQUFvQixFQUFFO2dCQUNwQixHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsb0JBQW9CO2dCQUMxQyxVQUFVLEVBQUUsSUFBSSxDQUFDLGlCQUFpQjthQUNuQztZQUNELFVBQVUsRUFBRTtnQkFDVixHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsVUFBVTtnQkFDaEMsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO2dCQUMzQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7YUFDOUI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDOztBQW5FSCxzQ0FvRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb2duaXRvVXNlclBvb2xzQXV0aG9yaXplcixcbiAgUmVzdEFwaSxcbiAgUmVzdEFwaVByb3BzLFxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWFwaWdhdGV3YXlcIjtcbmltcG9ydCB7XG4gIENlcnRpZmljYXRlLFxuICBDZXJ0aWZpY2F0ZVZhbGlkYXRpb24sXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY2VydGlmaWNhdGVtYW5hZ2VyXCI7XG5pbXBvcnQgeyBVc2VyUG9vbCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY29nbml0b1wiO1xuaW1wb3J0IHsgSG9zdGVkWm9uZSwgSUhvc3RlZFpvbmUgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXJvdXRlNTNcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzL2xpYi9jb25zdHJ1Y3RcIjtcbmltcG9ydCB7IFZwYyB9IGZyb20gXCIuLi9wbGF0Zm9ybVwiO1xuaW1wb3J0IHsgU3RhY2tQYXJhbWV0ZXIgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTZWN1cmVSZXN0QXBpUHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIEJhc2UgcGxhdGZvcm0gU3RhY2tcbiAgICovXG4gIHJlYWRvbmx5IGJhc2VQbGF0Zm9ybVN0YWNrTmFtZT86IHN0cmluZztcbiAgLyoqXG4gICAqIFN1YmRvbWFpbiB0aGF0IGlzIHVzZWQgZm9yIFJFU1QgQVBJIHByb3BzXG4gICAqL1xuICByZWFkb25seSBhcGlTdWJEb21haW46IHN0cmluZztcbiAgLyoqXG4gICAqIGhvc3RlZCB6b25lIGZvciB0aGUgc3ViZG9tYWluXG4gICAqIEFuIG9wdGlvbmFsIHBhcmFtZXRlclxuICAgKiBAZGVmYXVsdCAtIGZxZG4gb3V0cHV0IG9mIGJhc2UgcGxhdGZvcm0gc3RhY2sgaXMgdXNlZCB0byBpbXBvcnQgdGhlIGhvc3RlZCB6b25lXG4gICAqL1xuICByZWFkb25seSBob3N0ZWRab25lPzogSUhvc3RlZFpvbmU7XG5cbiAgLyoqXG4gICAqIFByb3BzIGZvcndhcmRlZCB0byB0aGUgUmVzdEFwaSBjb25zdHJ1Y3QuXG4gICAqL1xuICByZWFkb25seSByZXN0QXBpUHJvcHM6IFJlc3RBcGlQcm9wcztcbn1cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIHtAbGluayBTZWN1cmVSZXN0QXBpVjJ9IGluc3RlYWRcbiAqL1xuZXhwb3J0IGNsYXNzIFNlY3VyZVJlc3RBcGkgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvL3B1YmxpYyByZXN0QXBpRG9tYWluTmFtZTogRG9tYWluTmFtZTtcbiAgcHVibGljIGRvbWFpbk5hbWU6IHN0cmluZztcbiAgcHVibGljIGRlZmF1bHRBdXRob3JpemVyOiBDb2duaXRvVXNlclBvb2xzQXV0aG9yaXplcjtcbiAgcHJpdmF0ZSBjZXJ0aWZpY2F0ZTogQ2VydGlmaWNhdGU7XG5cbiAgcHVibGljIHJlc3RBcGk6IFJlc3RBcGk7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNlY3VyZVJlc3RBcGlQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgLy92YWxpZGF0ZSB0aGUgcHJvcHNcbiAgICBpZiAoIXByb3BzLmFwaVN1YkRvbWFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiYXBpU3ViRG9tYWluIGlzIHJlcXVpcmVkXCIpO1xuICAgIH1cblxuICAgIGNvbnN0IGNvZ25pdG9Vc2VyUG9vbElkUGFyYW1ldGVyID0gbmV3IFN0YWNrUGFyYW1ldGVyKHtcbiAgICAgIHByZWZpeDogXCJjb2duaXRvXCIsXG4gICAgICBrZXk6IFwidXNlci1wb29sLWlkXCIsXG4gICAgfSk7XG5cbiAgICBjb25zdCBjb2duaXRvVXNlclBvb2xJZCA9IGNvZ25pdG9Vc2VyUG9vbElkUGFyYW1ldGVyLmltcG9ydChcbiAgICAgIHRoaXMsXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgKTtcbiAgICBjb25zdCB1c2VyUG9vbFJlZiA9IFVzZXJQb29sLmZyb21Vc2VyUG9vbElkKFxuICAgICAgdGhpcyxcbiAgICAgIFwiVXNlclBvb2xSZWZcIixcbiAgICAgIGNvZ25pdG9Vc2VyUG9vbElkLFxuICAgICk7XG5cbiAgICBjb25zdCB7IGZxZG4gfSA9IFZwYy5mcm9tQmFzZVBsYXRmb3JtKFxuICAgICAgdGhpcyxcbiAgICAgIFwiVnBjUmVmXCIsXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgKTtcbiAgICBjb25zdCBob3N0ZWRab25lID1cbiAgICAgIHByb3BzLmhvc3RlZFpvbmUgPz9cbiAgICAgIEhvc3RlZFpvbmUuZnJvbUxvb2t1cCh0aGlzLCBcIkhvc3RlZFpvbmVcIiwge1xuICAgICAgICBkb21haW5OYW1lOiBmcWRuLFxuICAgICAgfSk7XG4gICAgdGhpcy5kb21haW5OYW1lID0gYCR7cHJvcHMuYXBpU3ViRG9tYWlufS4ke2hvc3RlZFpvbmUuem9uZU5hbWV9YDtcblxuICAgIHRoaXMuY2VydGlmaWNhdGUgPSBuZXcgQ2VydGlmaWNhdGUodGhpcywgXCJDZXJ0aWZpY2F0ZVwiLCB7XG4gICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICB2YWxpZGF0aW9uOiBDZXJ0aWZpY2F0ZVZhbGlkYXRpb24uZnJvbURucyhob3N0ZWRab25lKSxcbiAgICB9KTtcblxuICAgIHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIgPSBuZXcgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIoXG4gICAgICB0aGlzLFxuICAgICAgXCJkZWZhdWx0QXV0aG9yaXplclwiLFxuICAgICAge1xuICAgICAgICBjb2duaXRvVXNlclBvb2xzOiBbdXNlclBvb2xSZWZdLFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgdGhpcy5yZXN0QXBpID0gbmV3IFJlc3RBcGkodGhpcywgXCJSZXN0QXBpXCIsIHtcbiAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcyxcbiAgICAgIGRlZmF1bHRNZXRob2RPcHRpb25zOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kZWZhdWx0TWV0aG9kT3B0aW9ucyxcbiAgICAgICAgYXV0aG9yaXplcjogdGhpcy5kZWZhdWx0QXV0aG9yaXplcixcbiAgICAgIH0sXG4gICAgICBkb21haW5OYW1lOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kb21haW5OYW1lLFxuICAgICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICAgIGNlcnRpZmljYXRlOiB0aGlzLmNlcnRpZmljYXRlLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -52,5 +52,5 @@ class SecureRestApiV2 extends construct_1.Construct {
52
52
  }
53
53
  exports.SecureRestApiV2 = SecureRestApiV2;
54
54
  _a = JSII_RTTI_SYMBOL_1;
55
- SecureRestApiV2[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApiV2", version: "0.22.23" };
55
+ SecureRestApiV2[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApiV2", version: "0.22.24" };
56
56
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaVYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0cnVjdHMvU2VjdXJlUmVzdEFwaVYyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsK0RBTW9DO0FBQ3BDLCtFQUc0QztBQUM1Qyx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELDBDQUFtRDtBQTJCbkQsTUFBYSxlQUFnQixTQUFRLHFCQUFTO0lBSzVDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMkI7UUFDbkUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsSUFBSSxHQUFHLGNBQUcsQ0FBQyxnQkFBZ0IsQ0FDOUIsSUFBSSxFQUNKLFFBQVEsRUFDUixLQUFLLENBQUMscUJBQXFCLENBQzVCLENBQUMsSUFBSSxDQUFDO1FBRVAsTUFBTSxVQUFVLEdBQ2QsS0FBSyxDQUFDLFVBQVU7WUFDaEIsd0JBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtnQkFDeEMsVUFBVSxFQUFFLElBQUksQ0FBQyxJQUFJO2FBQ3RCLENBQUMsQ0FBQztRQUVMLE1BQU0sVUFBVSxHQUFHLEdBQUcsS0FBSyxDQUFDLFlBQVksSUFBSSxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFbEUsTUFBTSxXQUFXLEdBQUcsSUFBSSxvQ0FBVyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDdkQsVUFBVTtZQUNWLFVBQVUsRUFBRSw4Q0FBcUIsQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO1NBQ3RELENBQUMsQ0FBQztRQUVILE1BQU0sT0FBTyxHQUFHLDBCQUFlLENBQUMsZ0JBQWdCLENBQzlDLElBQUksRUFDSixTQUFTLEVBQ1QsS0FBSyxDQUFDLHFCQUFxQixDQUM1QixDQUFDO1FBRUYsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLENBQUMsZ0NBQWdDLEVBQUUsQ0FBQztRQUU3RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksd0JBQU8sQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQzFDLEdBQUcsS0FBSyxDQUFDLFlBQVk7WUFDckIsb0JBQW9CLEVBQUU7Z0JBQ3BCLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxvQkFBb0I7Z0JBQzFDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTthQUM1QjtZQUNELFVBQVUsRUFBRTtnQkFDVixHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsVUFBVTtnQkFDaEMsVUFBVTtnQkFDVixXQUFXO2FBQ1o7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU0sU0FBUyxDQUNkLFVBQWtCLEVBQ2xCLE1BQW9CLEVBQ3BCLE9BQXVCO1FBRXZCLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUM7WUFDekUsQ0FBQyxDQUFDO2dCQUNFLGVBQWUsSUFBSSxDQUFDLElBQUksV0FBVztnQkFDbkMsZUFBZSxJQUFJLENBQUMsSUFBSSxZQUFZO2FBQ3JDO1lBQ0gsQ0FBQyxDQUFDLENBQUMsZUFBZSxJQUFJLENBQUMsSUFBSSxZQUFZLENBQUMsQ0FBQztRQUUzQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsTUFBTSxFQUFFO1lBQ3JELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixtQkFBbUI7WUFDbkIsR0FBRyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFsRUgsMENBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIsXG4gIEludGVncmF0aW9uLFxuICBNZXRob2RPcHRpb25zLFxuICBSZXN0QXBpLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IEhvc3RlZFpvbmUsIElIb3N0ZWRab25lIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1yb3V0ZTUzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0cy9saWIvY29uc3RydWN0XCI7XG5pbXBvcnQgeyBDb2duaXRvVXNlclBvb2wsIFZwYyB9IGZyb20gXCIuLi9wbGF0Zm9ybVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNlY3VyZVJlc3RBcGlQcm9wc1YyIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBCYXNlIHBsYXRmb3JtIFN0YWNrXG4gICAqL1xuICByZWFkb25seSBiYXNlUGxhdGZvcm1TdGFja05hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFN1YmRvbWFpbiB0aGF0IGlzIHVzZWQgZm9yIFJFU1QgQVBJIHByb3BzXG4gICAqL1xuICByZWFkb25seSBhcGlTdWJEb21haW46IHN0cmluZztcblxuICAvKipcbiAgICogaG9zdGVkIHpvbmUgZm9yIHRoZSBzdWJkb21haW4uXG4gICAqIEFuIG9wdGlvbmFsIHBhcmFtZXRlclxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGZxZG4gb3V0cHV0IG9mIGJhc2UgcGxhdGZvcm0gc3RhY2sgaXMgdXNlZCB0byBpbXBvcnQgdGhlIGhvc3RlZCB6b25lXG4gICAqL1xuICByZWFkb25seSBob3N0ZWRab25lPzogSUhvc3RlZFpvbmU7XG5cbiAgLyoqXG4gICAqIFByb3BzIGZvcndhcmRlZCB0byB0aGUgUmVzdEFwaSBjb25zdHJ1Y3QuXG4gICAqL1xuICByZWFkb25seSByZXN0QXBpUHJvcHM6IFJlc3RBcGlQcm9wcztcbn1cblxuZXhwb3J0IGNsYXNzIFNlY3VyZVJlc3RBcGlWMiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgYXV0aG9yaXplcjogQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXI7XG4gIHByaXZhdGUgcmVhZG9ubHkgZnFkbjogc3RyaW5nO1xuICBwcml2YXRlIHJlYWRvbmx5IHJlc3RBcGk6IFJlc3RBcGk7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNlY3VyZVJlc3RBcGlQcm9wc1YyKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMuZnFkbiA9IFZwYy5mcm9tQmFzZVBsYXRmb3JtKFxuICAgICAgdGhpcyxcbiAgICAgIFwiVnBjUmVmXCIsXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgKS5mcWRuO1xuXG4gICAgY29uc3QgaG9zdGVkWm9uZSA9XG4gICAgICBwcm9wcy5ob3N0ZWRab25lID8/XG4gICAgICBIb3N0ZWRab25lLmZyb21Mb29rdXAodGhpcywgXCJIb3N0ZWRab25lXCIsIHtcbiAgICAgICAgZG9tYWluTmFtZTogdGhpcy5mcWRuLFxuICAgICAgfSk7XG5cbiAgICBjb25zdCBkb21haW5OYW1lID0gYCR7cHJvcHMuYXBpU3ViRG9tYWlufS4ke2hvc3RlZFpvbmUuem9uZU5hbWV9YDtcblxuICAgIGNvbnN0IGNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZSxcbiAgICAgIHZhbGlkYXRpb246IENlcnRpZmljYXRlVmFsaWRhdGlvbi5mcm9tRG5zKGhvc3RlZFpvbmUpLFxuICAgIH0pO1xuXG4gICAgY29uc3QgY29nbml0byA9IENvZ25pdG9Vc2VyUG9vbC5mcm9tQmFzZVBsYXRmb3JtKFxuICAgICAgdGhpcyxcbiAgICAgIFwiQ29nbml0b1wiLFxuICAgICAgcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLFxuICAgICk7XG5cbiAgICB0aGlzLmF1dGhvcml6ZXIgPSBjb2duaXRvLmNyZWF0ZUNvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyKCk7XG5cbiAgICB0aGlzLnJlc3RBcGkgPSBuZXcgUmVzdEFwaSh0aGlzLCBcIlJlc3RBcGlcIiwge1xuICAgICAgLi4ucHJvcHMucmVzdEFwaVByb3BzLFxuICAgICAgZGVmYXVsdE1ldGhvZE9wdGlvbnM6IHtcbiAgICAgICAgLi4ucHJvcHMucmVzdEFwaVByb3BzLmRlZmF1bHRNZXRob2RPcHRpb25zLFxuICAgICAgICBhdXRob3JpemVyOiB0aGlzLmF1dGhvcml6ZXIsXG4gICAgICB9LFxuICAgICAgZG9tYWluTmFtZToge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZG9tYWluTmFtZSxcbiAgICAgICAgZG9tYWluTmFtZSxcbiAgICAgICAgY2VydGlmaWNhdGUsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFkZE1ldGhvZChcbiAgICBodHRwTWV0aG9kOiBzdHJpbmcsXG4gICAgdGFyZ2V0PzogSW50ZWdyYXRpb24sXG4gICAgb3B0aW9ucz86IE1ldGhvZE9wdGlvbnMsXG4gICkge1xuICAgIGNvbnN0IGF1dGhvcml6YXRpb25TY29wZXMgPSBbYEdFVGAsIGBIRUFEYCwgYE9QVElPTlNgXS5pbmNsdWRlcyhodHRwTWV0aG9kKVxuICAgICAgPyBbXG4gICAgICAgICAgYGh0dHBzOi8vYXBpLiR7dGhpcy5mcWRufS9yZWFkX2FwaWAsXG4gICAgICAgICAgYGh0dHBzOi8vYXBpLiR7dGhpcy5mcWRufS93cml0ZV9hcGlgLFxuICAgICAgICBdXG4gICAgICA6IFtgaHR0cHM6Ly9hcGkuJHt0aGlzLmZxZG59L3dyaXRlX2FwaWBdO1xuXG4gICAgcmV0dXJuIHRoaXMucmVzdEFwaS5yb290LmFkZE1ldGhvZChodHRwTWV0aG9kLCB0YXJnZXQsIHtcbiAgICAgIGF1dGhvcml6ZXI6IHRoaXMuYXV0aG9yaXplcixcbiAgICAgIGF1dGhvcml6YXRpb25TY29wZXMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -52,5 +52,5 @@ class ApiKeyClientAuthorization extends constructs_1.Construct {
52
52
  }
53
53
  exports.ApiKeyClientAuthorization = ApiKeyClientAuthorization;
54
54
  _a = JSII_RTTI_SYMBOL_1;
55
- ApiKeyClientAuthorization[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyClientAuthorization", version: "0.22.23" };
55
+ ApiKeyClientAuthorization[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyClientAuthorization", version: "0.22.24" };
56
56
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpS2V5Q2xpZW50QXV0aG9yaXphdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb25zdHJ1Y3RzL2FwaS1rZXlzL0FwaUtleUNsaWVudEF1dGhvcml6YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBdUM7QUFDdkMsbUVBTXNDO0FBQ3RDLDZGQUFrRjtBQUVsRiwyQ0FBdUM7QUFDdkMsbUdBQTZGO0FBRTdGLE1BQU0sMEJBQTBCLEdBQUcsT0FBTyxDQUFDO0FBNkMzQzs7O0dBR0c7QUFDSCxNQUFhLHlCQUEwQixTQUFRLHNCQUFTO0lBR3REOzs7OztPQUtHO0lBQ0gsWUFDRSxLQUFnQixFQUNoQixFQUFVLEVBQ1YsS0FBcUM7UUFFckMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixNQUFNLG1CQUFtQixHQUFHLElBQUksa0VBQThCLENBQzVELElBQUksRUFDSix1QkFBdUIsRUFDdkI7WUFDRSxPQUFPLEVBQUUsc0JBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1NBQzlCLENBQ0YsQ0FBQztRQUVGLG1CQUFtQixDQUFDLGNBQWMsQ0FDaEMsZ0JBQWdCLEVBQ2hCLEtBQUssQ0FBQyxnQkFBZ0IsQ0FDdkIsQ0FBQztRQUNGLG1CQUFtQixDQUFDLGNBQWMsQ0FDaEMsd0JBQXdCLEVBQ3hCLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxTQUFTLENBQ3JDLENBQUM7UUFDRixtQkFBbUIsQ0FBQyxjQUFjLENBQUMsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzNFLG1CQUFtQixDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTlELEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxTQUFTLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUUxRCxNQUFNLGlCQUFpQixHQUFHLElBQUkscURBQXFCLENBQ2pELG1CQUFtQixFQUNuQixtQkFBbUIsQ0FDcEIsQ0FBQztRQUVGLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxpQkFBaUIsSUFBSSwwQkFBMEIsQ0FBQztRQUVuRSxJQUFJLDRCQUFTLENBQUMsSUFBSSxFQUFFLG9CQUFvQixFQUFFO1lBQ3hDLE9BQU8sRUFBRSxLQUFLLENBQUMsb0JBQW9CO1lBQ25DLFdBQVcsRUFBRSxpQkFBaUI7WUFDOUIsUUFBUSxFQUFFLCtCQUFZLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxFQUFFLEVBQUUsNkJBQVUsQ0FBQyxJQUFJLENBQUM7WUFDeEQsVUFBVSxFQUFFLElBQUkscUNBQWtCLEVBQUU7U0FDckMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGdCQUFnQjtZQUNuQixDQUFDLEtBQUssQ0FBQyx1QkFBdUI7Z0JBQzVCLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxZQUFZLEVBQUUsU0FBUztvQkFDaEQsS0FBSyxDQUFDLG9CQUFvQixDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsSUFBSSxFQUFFLENBQUM7SUFDNUQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDL0IsQ0FBQzs7QUE5REgsOERBK0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCB7XG4gIEh0dHBNZXRob2QsXG4gIEh0dHBOb25lQXV0aG9yaXplcixcbiAgSHR0cFJvdXRlLFxuICBIdHRwUm91dGVLZXksXG4gIElIdHRwQXBpLFxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWFwaWdhdGV3YXl2MlwiO1xuaW1wb3J0IHsgSHR0cExhbWJkYUludGVncmF0aW9uIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5djItaW50ZWdyYXRpb25zXCI7XG5pbXBvcnQgeyBJU2VjcmV0IH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1zZWNyZXRzbWFuYWdlclwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IEFwaUNsaWVudEF1dGhvcml6YXRpb25GdW5jdGlvbiB9IGZyb20gXCIuL2xhbWJkYXMvYXBpLWNsaWVudC1hdXRob3JpemF0aW9uLWZ1bmN0aW9uXCI7XG5cbmNvbnN0IERFRkFVTFRfQVVUSE9SSVpBVElPTl9QQVRIID0gXCJ0b2tlblwiO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgdG8gaW5zdGFudGlhdGUgdGhlIHtAbGluayBBcGlLZXlDbGllbnRBdXRob3JpemF0aW9ufSBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXBpS2V5Q2xpZW50QXV0aG9yaXphdGlvblByb3BzIHtcbiAgLyoqXG4gICAqIEFuIGV4aXN0aW5nIEh0dHBBcGkgdG8gYXR0YWNoIHRoZSBlbmRwb2ludCB0by4gVGhlIGRlZmF1bHQgYXV0aG9yaXplciB3aWxsIHdlIGlnbm9yZWRcbiAgICogYW5kIG5vIGF1dGhvcml6YXRpb24gd2lsbCBiZSByZXF1aXJlZCBmb3IgdGhlIGVuZHBvaW50LlxuICAgKi9cbiAgcmVhZG9ubHkgYXV0aG9yaXphdGlvbkh0dHBBcGk6IElIdHRwQXBpO1xuXG4gIC8qKlxuICAgKiBBbiBvcHRpb25hbCBiYXNlIFVSTCBmb3IgdGhlIHtAbGluayBJSHR0cEFwaX0gaW4gY2FzZSBpdCBjYW5ub3QgYmUgcmV0cmlldmVkLlxuICAgKi9cbiAgcmVhZG9ubHkgYXV0aG9yaXphdGlvbkh0dHBBcGlVcmw/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBJRCBvZiB0aGUgQVBJIGNsaWVudC4gQ3JlZGVudGlhbHMgcmVxdWlyZWQgZm9yIGF1dGhvcml6YXRpb24gd2lsbCBiZSBmZXRjaGVkIGZvclxuICAgKiB0aGlzIGNsaWVudC5cbiAgICovXG4gIHJlYWRvbmx5IHVzZXJQb29sQ2xpZW50SWQ6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHNlY3JldCBjb250YWluaW5nIHRoZSB1c2VyIHBvb2wgY2xpZW50IHNlY3JldC5cbiAgICovXG4gIHJlYWRvbmx5IHVzZXJQb29sQ2xpZW50U2VjcmV0OiBJU2VjcmV0O1xuXG4gIC8qKlxuICAgKiBUaGUgaXNzdWVyIFVSTCBmb3IgdGhlIHVzZXIgcG9vbC4gVXNlZCB0byBleHRyYWN0IHRoZSBPQXV0aCBVUkwuXG4gICAqL1xuICByZWFkb25seSBvaWRjSXNzdWVyVXJsOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBzY29wZSB0byBiZSB1c2VkIGZvciByZXRyaWV2aW5nIHRoZSB0b2tlbi5cbiAgICovXG4gIHJlYWRvbmx5IHNjb3BlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFBhdGggKHdpdGhvdXQgcHJlY2VkaW5nIGFuZCB0cmFpbGluZyBzbGFzaCkgdG8gYmUgdXNlZCB0byByZXRyaWV2ZSB0aGUgdG9rZW4uXG4gICAqIFdpbGwgZGVmYXVsdCB0byBgdG9rZW5gIGlmIG5vdCBzZXQuXG4gICAqL1xuICByZWFkb25seSBhdXRob3JpemF0aW9uUGF0aD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgdGhhdCBwcm92aWRlcyBhIGN1c3RvbSBPQXV0aCBVUkwgZm9yIGF1dGhvcml6aW5nIGFuIEFQSSBjbGllbnQgYnkgb25seSBwYXNzaW5nIGFcbiAqIHZhbGlkIGNsaWVudCBpZC4gSXQgd2lsbCBhZGQgYSBuZXcgZW5kcG9pbnQgdG8gYW4gZXhpc3RpbmcgSHR0cEFwaSBhcyBgL2F1dGhvcml6ZS97aWR9YC5cbiAqL1xuZXhwb3J0IGNsYXNzIEFwaUtleUNsaWVudEF1dGhvcml6YXRpb24gZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwcml2YXRlIGF1dGhvcml6YXRpb25Vcmw6IHN0cmluZztcblxuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGluc3RhbmNlIG9mIHRoZSBjb21wb25lbnQuXG4gICAqIEBwYXJhbSBzY29wZSBUaGUgc2NvcGUgdG8gYmUgdXNlZC5cbiAgICogQHBhcmFtIGlkIFRoZSBJRCB1c2VkIGZvciB0aGUgY29tcG9uZW50IGluc3RhbmNlLlxuICAgKiBAcGFyYW0gcHJvcHMgVGhlIHtAbGluayBBcGlLZXlDbGllbnRBdXRob3JpemF0aW9uUHJvcHN9IHJlcXVpcmVkIGZvciBjcmVhdGluZyB0aGUgaW5zdGFuY2UuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IEFwaUtleUNsaWVudEF1dGhvcml6YXRpb25Qcm9wcyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IGNsaWVudEF1dGhvcml6YXRpb24gPSBuZXcgQXBpQ2xpZW50QXV0aG9yaXphdGlvbkZ1bmN0aW9uKFxuICAgICAgdGhpcyxcbiAgICAgIFwiQXV0aG9yaXphdGlvbkZ1bmN0aW9uXCIsXG4gICAgICB7XG4gICAgICAgIHRpbWVvdXQ6IER1cmF0aW9uLnNlY29uZHMoNDUpLFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgY2xpZW50QXV0aG9yaXphdGlvbi5hZGRFbnZpcm9ubWVudChcbiAgICAgIFwiT0lEQ19DTElFTlRfSURcIixcbiAgICAgIHByb3BzLnVzZXJQb29sQ2xpZW50SWQsXG4gICAgKTtcbiAgICBjbGllbnRBdXRob3JpemF0aW9uLmFkZEVudmlyb25tZW50KFxuICAgICAgXCJPSURDX0NMSUVOVF9TRUNSRVRfQVJOXCIsXG4gICAgICBwcm9wcy51c2VyUG9vbENsaWVudFNlY3JldC5zZWNyZXRBcm4sXG4gICAgKTtcbiAgICBjbGllbnRBdXRob3JpemF0aW9uLmFkZEVudmlyb25tZW50KFwiT0lEQ19JU1NVRVJfVVJMXCIsIHByb3BzLm9pZGNJc3N1ZXJVcmwpO1xuICAgIGNsaWVudEF1dGhvcml6YXRpb24uYWRkRW52aXJvbm1lbnQoXCJPSURDX1NDT1BFXCIsIHByb3BzLnNjb3BlKTtcblxuICAgIHByb3BzLnVzZXJQb29sQ2xpZW50U2VjcmV0LmdyYW50UmVhZChjbGllbnRBdXRob3JpemF0aW9uKTtcblxuICAgIGNvbnN0IGFwaUtleUludGVncmF0aW9uID0gbmV3IEh0dHBMYW1iZGFJbnRlZ3JhdGlvbihcbiAgICAgIFwiQXBpS2V5SW50ZWdyYXRpb25cIixcbiAgICAgIGNsaWVudEF1dGhvcml6YXRpb24sXG4gICAgKTtcblxuICAgIGNvbnN0IHBhdGggPSBwcm9wcy5hdXRob3JpemF0aW9uUGF0aCA/PyBERUZBVUxUX0FVVEhPUklaQVRJT05fUEFUSDtcblxuICAgIG5ldyBIdHRwUm91dGUodGhpcywgXCJBdXRob3JpemF0aW9uUm91dGVcIiwge1xuICAgICAgaHR0cEFwaTogcHJvcHMuYXV0aG9yaXphdGlvbkh0dHBBcGksXG4gICAgICBpbnRlZ3JhdGlvbjogYXBpS2V5SW50ZWdyYXRpb24sXG4gICAgICByb3V0ZUtleTogSHR0cFJvdXRlS2V5LndpdGgoYC8ke3BhdGh9YCwgSHR0cE1ldGhvZC5QT1NUKSxcbiAgICAgIGF1dGhvcml6ZXI6IG5ldyBIdHRwTm9uZUF1dGhvcml6ZXIoKSxcbiAgICB9KTtcblxuICAgIHRoaXMuYXV0aG9yaXphdGlvblVybCA9XG4gICAgICAocHJvcHMuYXV0aG9yaXphdGlvbkh0dHBBcGlVcmwgPz9cbiAgICAgICAgcHJvcHMuYXV0aG9yaXphdGlvbkh0dHBBcGkuZGVmYXVsdFN0YWdlPy5kb21haW5VcmwgK1xuICAgICAgICAgIHByb3BzLmF1dGhvcml6YXRpb25IdHRwQXBpLmFwaUVuZHBvaW50KSArIGAke3BhdGh9YDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGF1dGhvcml6YXRpb24gVVJMIHRvIGJlIHVzZWQgdG8gcmV0cmlldmUgdGhlIHRva2VuLlxuICAgKi9cbiAgZ2V0IHRva2VuVXJsKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aG9yaXphdGlvblVybDtcbiAgfVxufVxuIl19
@@ -210,5 +210,5 @@ class ApiKeyManagement extends constructs_1.Construct {
210
210
  }
211
211
  exports.ApiKeyManagement = ApiKeyManagement;
212
212
  _a = JSII_RTTI_SYMBOL_1;
213
- ApiKeyManagement[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyManagement", version: "0.22.23" };
213
+ ApiKeyManagement[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyManagement", version: "0.22.24" };
214
214
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApiKeyManagement.js","sourceRoot":"","sources":["../../../src/constructs/api-keys/ApiKeyManagement.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuthorizationType,\n  AwsIntegration,\n  EndpointType,\n  IRestApi,\n  LambdaIntegration,\n  RestApi,\n} from \"aws-cdk-lib/aws-apigateway\";\nimport { ITable } from \"aws-cdk-lib/aws-dynamodb\";\nimport {\n  Effect,\n  IRole,\n  ManagedPolicy,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from \"aws-cdk-lib/aws-iam\";\nimport { Construct } from \"constructs\";\nimport { ApiKeyAttribute, ApiKeyStore } from \"./ApiKeyStore\";\nimport { ApiKeyCreationFunction } from \"./lambdas/api-key-creation-function\";\nimport { ApiKeyUpdateFunction } from \"./lambdas/api-key-update-function\";\n\nconst MANAGEMENT_PATH = \"apiKeys\";\n\n/**\n * Properties to instantiate the {@link ApiKeyManagement} component.\n */\nexport interface ApiKeyManagementProps {\n  /**\n   * The {@link ApiKeyStore} component.\n   */\n  readonly apiKeys: ApiKeyStore;\n}\n\n/**\n * Component that provides a REST API to manage (create, modify, delete) API keys.\n */\nexport class ApiKeyManagement extends Construct {\n  private externalUrl: string;\n  private restApi: IRestApi;\n  private table: ITable;\n  private attributes: ApiKeyAttribute[];\n  /**\n   * Create a new instance of the component.\n   * @param scope The scope to be used.\n   * @param id The ID used for the component instance.\n   * @param props The {@link ApiKeyManagementProps} required for creating the instance.\n   */\n  constructor(scope: Construct, id: string, props: ApiKeyManagementProps) {\n    super(scope, id);\n\n    this.attributes = props.apiKeys.attributes;\n\n    this.table = props.apiKeys.apiKeyTable;\n\n    const restApi = new RestApi(this, \"ManagementApi\", {\n      restApiName: \"API Key Management\",\n      description: \"API for managing API keys\",\n      endpointConfiguration: {\n        types: [EndpointType.REGIONAL],\n      },\n    });\n\n    this.externalUrl = `${restApi.url}`;\n    this.restApi = restApi;\n\n    this.setUpResources();\n  }\n\n  /**\n   * Get the base URL to manage the keys.\n   */\n  public get baseUrl(): string {\n    return this.externalUrl;\n  }\n\n  /**\n   * Get the path relative to the base url to manage all keys.\n   */\n  public get keysManagementPath(): string {\n    return MANAGEMENT_PATH;\n  }\n\n  /**\n   * Get the path relative to the base url to manage a single key. Contains\n   * a placeholder {id} that has to replaced by the ID of the element to be managed.\n   */\n  public get keyManagementPath(): string {\n    return this.keysManagementPath + \"/{id}\";\n  }\n\n  /**\n   * Grant connection privileges to the passed role.\n   * @param role The role to allow access to the API.\n   */\n  public allowConnection(role: IRole): void {\n    const statement = new PolicyStatement();\n    statement.addResources(this.restApi.arnForExecuteApi());\n    statement.addActions(\"execute-api:Invoke\");\n    statement.effect = Effect.ALLOW;\n    role.addManagedPolicy(\n      new ManagedPolicy(role, \"ApiClientManagementAccessPolicy\", {\n        statements: [statement],\n      }),\n    );\n  }\n\n  /**\n   * Set up the available resources for the API.\n   */\n  private setUpResources(): void {\n    // Create IAM role for API Gateway to access DynamoDB\n    const apiGatewayRole = new Role(this, \"ApiGatewayDynamoDBRole\", {\n      assumedBy: new ServicePrincipal(\"apigateway.amazonaws.com\"),\n    });\n\n    this.table.grantReadWriteData(apiGatewayRole);\n\n    // Resource for actions on all keys\n    const apiKeysResource = this.restApi.root.addResource(MANAGEMENT_PATH);\n    // Resource for actions on a single key\n    const apiKeyResource = apiKeysResource.addResource(\"{id}\");\n\n    // Get all keys\n    apiKeysResource.addMethod(\n      \"GET\",\n      new AwsIntegration({\n        service: \"dynamodb\",\n        action: \"Scan\",\n        options: {\n          credentialsRole: apiGatewayRole,\n          requestTemplates: {\n            \"application/json\": JSON.stringify({\n              TableName: this.table.tableName,\n              ConsistentRead: true,\n            }),\n          },\n          integrationResponses: [\n            {\n              statusCode: \"200\",\n              responseTemplates: {\n                \"application/json\": `#set($inputRoot = $input.path('$'))\n                  {\n                    \"keys\": [\n                      #foreach($elem in $inputRoot.Items)\n                      {\n                        \"id\": \"$elem.id.S\",\n                        \"createdAt\": \"$elem.createdAt.S\"\n                        #foreach($attribute in ${JSON.stringify(this.attributes)})\n                          #if($elem[$attribute.apiName].S != '')\n                            ,\"$attribute.apiName\": \"$elem[$attribute.apiName].S\"\n                          #end\n                        #end\n                      }#if($foreach.hasNext),#end\n                      #end\n                    ]\n                  }`,\n              },\n            },\n          ],\n        },\n      }),\n      {\n        methodResponses: [{ statusCode: \"200\" }],\n        authorizationType: AuthorizationType.IAM,\n      },\n    );\n\n    // Get a single key\n    apiKeyResource.addMethod(\n      \"GET\",\n      new AwsIntegration({\n        service: \"dynamodb\",\n        action: \"GetItem\",\n        options: {\n          credentialsRole: apiGatewayRole,\n          requestTemplates: {\n            \"application/json\": JSON.stringify({\n              TableName: this.table.tableName,\n              Key: {\n                id: { S: \"$method.request.path.id\" },\n              },\n              ConsistentRead: true,\n            }),\n          },\n          integrationResponses: [\n            {\n              statusCode: \"200\",\n              responseTemplates: {\n                \"application/json\": `#set($inputRoot = $input.path('$'))\n                  #if($inputRoot.Item)\n                  {\n                    \"id\": \"$inputRoot.Item.id.S\",\n                    \"createdAt\": \"$inputRoot.Item.createdAt.S\"\n                    #foreach($attribute in ${JSON.stringify(this.attributes)})\n                      #if($inputRoot.Item[$attribute.apiName].S != '')\n                        ,\"$attribute.apiName\": \"$inputRoot.Item[$attribute.apiName].S\"\n                      #end\n                    #end\n                  }\n                  #else\n                  {}\n                  #end`,\n              },\n            },\n          ],\n        },\n      }),\n      {\n        methodResponses: [{ statusCode: \"200\" }],\n        authorizationType: AuthorizationType.IAM,\n      },\n    );\n\n    // Delete a key\n    apiKeyResource.addMethod(\n      \"DELETE\",\n      new AwsIntegration({\n        service: \"dynamodb\",\n        action: \"DeleteItem\",\n        options: {\n          credentialsRole: apiGatewayRole,\n          requestTemplates: {\n            \"application/json\": JSON.stringify({\n              TableName: this.table.tableName,\n              Key: {\n                id: { S: \"$method.request.path.id\" },\n              },\n            }),\n          },\n          integrationResponses: [\n            {\n              statusCode: \"200\",\n              responseTemplates: {\n                \"application/json\": '{\"message\": \"Item deleted successfully\"}',\n              },\n            },\n          ],\n        },\n      }),\n      {\n        methodResponses: [{ statusCode: \"200\" }],\n        authorizationType: AuthorizationType.IAM,\n      },\n    );\n\n    // Create a key\n    const creationHandler = new ApiKeyCreationFunction(\n      this,\n      \"CreationHandler\",\n      { environment: { TABLE_NAME: this.table.tableName } },\n    );\n\n    this.table.grantReadWriteData(creationHandler);\n\n    apiKeysResource.addMethod(\"POST\", new LambdaIntegration(creationHandler), {\n      methodResponses: [{ statusCode: \"200\" }],\n      authorizationType: AuthorizationType.IAM,\n    });\n\n    // Update a key\n    const updateHandler = new ApiKeyUpdateFunction(this, \"UpdateHandler\", {\n      environment: {\n        TABLE_NAME: this.table.tableName,\n        ATTRIBUTE_NAMES: this.attributes.map((f) => f.apiName).join(\",\"),\n      },\n    });\n\n    this.table.grantReadWriteData(updateHandler);\n\n    apiKeyResource.addMethod(\"POST\", new LambdaIntegration(updateHandler), {\n      methodResponses: [{ statusCode: \"200\" }],\n      authorizationType: AuthorizationType.IAM,\n    });\n  }\n}\n"]}
@@ -62,5 +62,5 @@ class ApiKeyPreTokenHandler extends constructs_1.Construct {
62
62
  }
63
63
  exports.ApiKeyPreTokenHandler = ApiKeyPreTokenHandler;
64
64
  _a = JSII_RTTI_SYMBOL_1;
65
- ApiKeyPreTokenHandler[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyPreTokenHandler", version: "0.22.23" };
65
+ ApiKeyPreTokenHandler[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiKeyPreTokenHandler", version: "0.22.24" };
66
66
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpS2V5UHJlVG9rZW5IYW5kbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnN0cnVjdHMvYXBpLWtleXMvQXBpS2V5UHJlVG9rZW5IYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsNkNBQThDO0FBRTlDLGlEQUF1RDtBQUN2RCxtRUFJc0M7QUFDdEMsMkNBQXVDO0FBRXZDLHFFQUFnRTtBQWlCaEU7O0dBRUc7QUFDSCxNQUFhLHFCQUFzQixTQUFRLHNCQUFTO0lBQ2xEOzs7OztPQUtHO0lBQ0gsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFpQztRQUN6RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDO1FBRXhDLE1BQU0sVUFBVSxHQUFHO1lBQ2pCLFVBQVUsRUFBRSxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVU7U0FDckMsQ0FBQztRQUVGLE1BQU0seUJBQXlCLEdBQUcsSUFBSSxxQ0FBZ0IsQ0FDcEQsSUFBSSxFQUNKLGtCQUFrQixFQUNsQjtZQUNFLE9BQU8sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7U0FDOUIsQ0FDRixDQUFDO1FBRUYseUJBQXlCLENBQUMsY0FBYyxDQUN0QyxxQkFBcUIsRUFDckIsS0FBSyxDQUFDLFNBQVMsQ0FDaEIsQ0FBQztRQUVGLHlCQUF5QixDQUFDLGNBQWMsQ0FDdEMsWUFBWSxFQUNaLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQzNCLENBQUM7UUFFRixnRUFBZ0U7UUFDaEUseUJBQXlCLENBQUMsYUFBYSxDQUFDLHlCQUF5QixFQUFFO1lBQ2pFLFNBQVMsRUFBRSxJQUFJLDBCQUFnQixDQUFDLDJCQUEyQixDQUFDO1lBQzVELFNBQVMsRUFBRSxLQUFLLENBQUMsUUFBUSxDQUFDLFdBQVc7U0FDdEMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLGFBQWEsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBRS9DLElBQUksb0NBQWlCLENBQUMsSUFBSSxFQUFFLGdCQUFnQixFQUFFO1lBQzVDLFlBQVksRUFBRSx3QkFBd0I7WUFDdEMsUUFBUSxFQUFFO2dCQUNSLE1BQU0sRUFBRSxtQkFBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNO2dCQUM5QixPQUFPLEVBQUUsZ0NBQWdDO2dCQUN6QyxNQUFNLEVBQUUsZ0JBQWdCO2dCQUN4QixVQUFVLEVBQUU7b0JBQ1YsVUFBVSxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsVUFBVTtvQkFDckMsWUFBWSxFQUFFO3dCQUNaLGtCQUFrQixFQUFFLHlCQUF5QixDQUFDLFdBQVc7d0JBQ3pELHdCQUF3QixFQUFFOzRCQUN4QixTQUFTLEVBQUUseUJBQXlCLENBQUMsV0FBVzs0QkFDaEQsYUFBYSxFQUFFLE1BQU07eUJBQ3RCO3FCQUNGO2lCQUNGO2dCQUNELGtCQUFrQixFQUFFLHFDQUFrQixDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQzthQUNyRTtZQUNELE1BQU0sRUFBRSwwQ0FBdUIsQ0FBQyxZQUFZLENBQUM7Z0JBQzNDLFNBQVMsRUFBRSwwQ0FBdUIsQ0FBQyxZQUFZO2FBQ2hELENBQUM7WUFDRixtQkFBbUIsRUFBRSxLQUFLO1NBQzNCLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBakVILHNEQWtFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uLCBTdGFjayB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHsgSVVzZXJQb29sIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jb2duaXRvXCI7XG5pbXBvcnQgeyBTZXJ2aWNlUHJpbmNpcGFsIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1pYW1cIjtcbmltcG9ydCB7XG4gIEF3c0N1c3RvbVJlc291cmNlLFxuICBBd3NDdXN0b21SZXNvdXJjZVBvbGljeSxcbiAgUGh5c2ljYWxSZXNvdXJjZUlkLFxufSBmcm9tIFwiYXdzLWNkay1saWIvY3VzdG9tLXJlc291cmNlc1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IEFwaUtleVN0b3JlIH0gZnJvbSBcIi4vQXBpS2V5U3RvcmVcIjtcbmltcG9ydCB7IFByZVRva2VuRnVuY3Rpb24gfSBmcm9tIFwiLi9sYW1iZGFzL3ByZS10b2tlbi1mdW5jdGlvblwiO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgdG8gaW5zdGFudGlhdGUgdGhlIHtAbGluayBBcGlLZXlQcmVUb2tlbkhhbmRsZXJ9IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcGlLZXlQcmVUb2tlbkhhbmRsZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgdXNlciBwb29sIHRvIGJlIHVzZWQuXG4gICAqL1xuICByZWFkb25seSB1c2VyUG9vbDogSVVzZXJQb29sO1xuXG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEFwaUtleVN0b3JlfSBjb21wb25lbnQuXG4gICAqL1xuICByZWFkb25seSBhcGlLZXlzOiBBcGlLZXlTdG9yZTtcbn1cblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBwcm92aWRlcyBwcmUtdG9rZW4gbGFtYmRhIHRoYXQgZW5oYW5jZXMgdGhlIENvZ25pdG8gYWNjZXNzIHRva2VuLlxuICovXG5leHBvcnQgY2xhc3MgQXBpS2V5UHJlVG9rZW5IYW5kbGVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIENyZWF0ZSBhIG5ldyBpbnN0YW5jZSBvZiB0aGUgY29tcG9uZW50LlxuICAgKiBAcGFyYW0gc2NvcGUgVGhlIHNjb3BlIHRvIGJlIHVzZWQuXG4gICAqIEBwYXJhbSBpZCBUaGUgSUQgdXNlZCBmb3IgdGhlIGNvbXBvbmVudCBpbnN0YW5jZS5cbiAgICogQHBhcmFtIHByb3BzIFRoZSB7QGxpbmsgQXBpS2V5UHJlVG9rZW5IYW5kbGVyUHJvcHN9IHJlcXVpcmVkIGZvciBjcmVhdGluZyB0aGUgaW5zdGFuY2UuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXBpS2V5UHJlVG9rZW5IYW5kbGVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgdGFibGUgPSBwcm9wcy5hcGlLZXlzLmFwaUtleVRhYmxlO1xuXG4gICAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICAgIGF0dHJpYnV0ZXM6IHByb3BzLmFwaUtleXMuYXR0cmlidXRlcyxcbiAgICB9O1xuXG4gICAgY29uc3QgcHJlVG9rZW5HZW5lcmF0aW9uVHJpZ2dlciA9IG5ldyBQcmVUb2tlbkZ1bmN0aW9uKFxuICAgICAgdGhpcyxcbiAgICAgIFwiUHJlVG9rZW5GdW5jdGlvblwiLFxuICAgICAge1xuICAgICAgICB0aW1lb3V0OiBEdXJhdGlvbi5zZWNvbmRzKDMwKSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIHByZVRva2VuR2VuZXJhdGlvblRyaWdnZXIuYWRkRW52aXJvbm1lbnQoXG4gICAgICBcIkRZTkFNT0RCX1RBQkxFX05BTUVcIixcbiAgICAgIHRhYmxlLnRhYmxlTmFtZSxcbiAgICApO1xuXG4gICAgcHJlVG9rZW5HZW5lcmF0aW9uVHJpZ2dlci5hZGRFbnZpcm9ubWVudChcbiAgICAgIFwiQVRUUklCVVRFU1wiLFxuICAgICAgSlNPTi5zdHJpbmdpZnkoYXR0cmlidXRlcyksXG4gICAgKTtcblxuICAgIC8vIEdyYW50IHRoZSBMYW1iZGEgZnVuY3Rpb24gcGVybWlzc2lvbiB0byBiZSBpbnZva2VkIGJ5IENvZ25pdG9cbiAgICBwcmVUb2tlbkdlbmVyYXRpb25UcmlnZ2VyLmFkZFBlcm1pc3Npb24oXCJDb2duaXRvSW52b2tlUGVybWlzc2lvblwiLCB7XG4gICAgICBwcmluY2lwYWw6IG5ldyBTZXJ2aWNlUHJpbmNpcGFsKFwiY29nbml0by1pZHAuYW1hem9uYXdzLmNvbVwiKSxcbiAgICAgIHNvdXJjZUFybjogcHJvcHMudXNlclBvb2wudXNlclBvb2xBcm4sXG4gICAgfSk7XG5cbiAgICB0YWJsZS5ncmFudFJlYWREYXRhKHByZVRva2VuR2VuZXJhdGlvblRyaWdnZXIpO1xuXG4gICAgbmV3IEF3c0N1c3RvbVJlc291cmNlKHRoaXMsIFwiVXBkYXRlVXNlclBvb2xcIiwge1xuICAgICAgcmVzb3VyY2VUeXBlOiBcIkN1c3RvbTo6VXBkYXRlVXNlclBvb2xcIixcbiAgICAgIG9uQ3JlYXRlOiB7XG4gICAgICAgIHJlZ2lvbjogU3RhY2sub2Yoc2NvcGUpLnJlZ2lvbixcbiAgICAgICAgc2VydmljZTogXCJDb2duaXRvSWRlbnRpdHlTZXJ2aWNlUHJvdmlkZXJcIixcbiAgICAgICAgYWN0aW9uOiBcInVwZGF0ZVVzZXJQb29sXCIsXG4gICAgICAgIHBhcmFtZXRlcnM6IHtcbiAgICAgICAgICBVc2VyUG9vbElkOiBwcm9wcy51c2VyUG9vbC51c2VyUG9vbElkLFxuICAgICAgICAgIExhbWJkYUNvbmZpZzoge1xuICAgICAgICAgICAgUHJlVG9rZW5HZW5lcmF0aW9uOiBwcmVUb2tlbkdlbmVyYXRpb25UcmlnZ2VyLmZ1bmN0aW9uQXJuLFxuICAgICAgICAgICAgUHJlVG9rZW5HZW5lcmF0aW9uQ29uZmlnOiB7XG4gICAgICAgICAgICAgIExhbWJkYUFybjogcHJlVG9rZW5HZW5lcmF0aW9uVHJpZ2dlci5mdW5jdGlvbkFybixcbiAgICAgICAgICAgICAgTGFtYmRhVmVyc2lvbjogXCJWM18wXCIsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHBoeXNpY2FsUmVzb3VyY2VJZDogUGh5c2ljYWxSZXNvdXJjZUlkLm9mKHByb3BzLnVzZXJQb29sLnVzZXJQb29sSWQpLFxuICAgICAgfSxcbiAgICAgIHBvbGljeTogQXdzQ3VzdG9tUmVzb3VyY2VQb2xpY3kuZnJvbVNka0NhbGxzKHtcbiAgICAgICAgcmVzb3VyY2VzOiBBd3NDdXN0b21SZXNvdXJjZVBvbGljeS5BTllfUkVTT1VSQ0UsXG4gICAgICB9KSxcbiAgICAgIGluc3RhbGxMYXRlc3RBd3NTZGs6IGZhbHNlLFxuICAgIH0pO1xuICB9XG59XG4iXX0=