image-scanner-with-trivy 1.4.3 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -7,7 +7,7 @@
7
7
  ]
8
8
  },
9
9
  "dependencies": {
10
- "aws-cdk-lib": "^2.95.1",
10
+ "aws-cdk-lib": "^2.178.1",
11
11
  "constructs": "^10.0.5"
12
12
  },
13
13
  "dependencyClosure": {
@@ -89,6 +89,36 @@
89
89
  }
90
90
  }
91
91
  },
92
+ "@aws-cdk/cloud-assembly-schema": {
93
+ "targets": {
94
+ "dotnet": {
95
+ "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png",
96
+ "namespace": "Amazon.CDK.CloudAssembly.Schema",
97
+ "packageId": "Amazon.CDK.CloudAssembly.Schema"
98
+ },
99
+ "go": {
100
+ "moduleName": "github.com/cdklabs/cloud-assembly-schema-go"
101
+ },
102
+ "java": {
103
+ "maven": {
104
+ "artifactId": "cdk-cloud-assembly-schema",
105
+ "groupId": "software.amazon.awscdk"
106
+ },
107
+ "package": "software.amazon.awscdk.cloudassembly.schema"
108
+ },
109
+ "js": {
110
+ "npm": "@aws-cdk/cloud-assembly-schema"
111
+ },
112
+ "python": {
113
+ "classifiers": [
114
+ "Framework :: AWS CDK",
115
+ "Framework :: AWS CDK :: 2"
116
+ ],
117
+ "distName": "aws-cdk.cloud-assembly-schema",
118
+ "module": "aws_cdk.cloud_assembly_schema"
119
+ }
120
+ }
121
+ },
92
122
  "aws-cdk-lib": {
93
123
  "submodules": {
94
124
  "aws-cdk-lib.alexa_ask": {
@@ -221,6 +251,32 @@
221
251
  }
222
252
  }
223
253
  },
254
+ "aws-cdk-lib.aws_apigatewayv2_authorizers": {
255
+ "targets": {
256
+ "dotnet": {
257
+ "namespace": "Amazon.CDK.AwsApigatewayv2Authorizers"
258
+ },
259
+ "java": {
260
+ "package": "software.amazon.awscdk.aws_apigatewayv2_authorizers"
261
+ },
262
+ "python": {
263
+ "module": "aws_cdk.aws_apigatewayv2_authorizers"
264
+ }
265
+ }
266
+ },
267
+ "aws-cdk-lib.aws_apigatewayv2_integrations": {
268
+ "targets": {
269
+ "dotnet": {
270
+ "namespace": "Amazon.CDK.AwsApigatewayv2Integrations"
271
+ },
272
+ "java": {
273
+ "package": "software.amazon.awscdk.aws_apigatewayv2_integrations"
274
+ },
275
+ "python": {
276
+ "module": "aws_cdk.aws_apigatewayv2_integrations"
277
+ }
278
+ }
279
+ },
224
280
  "aws-cdk-lib.aws_appconfig": {
225
281
  "targets": {
226
282
  "dotnet": {
@@ -286,6 +342,19 @@
286
342
  }
287
343
  }
288
344
  },
345
+ "aws-cdk-lib.aws_applicationsignals": {
346
+ "targets": {
347
+ "dotnet": {
348
+ "package": "Amazon.CDK.AWS.ApplicationSignals"
349
+ },
350
+ "java": {
351
+ "package": "software.amazon.awscdk.services.applicationsignals"
352
+ },
353
+ "python": {
354
+ "module": "aws_cdk.aws_applicationsignals"
355
+ }
356
+ }
357
+ },
289
358
  "aws-cdk-lib.aws_appmesh": {
290
359
  "targets": {
291
360
  "dotnet": {
@@ -338,6 +407,19 @@
338
407
  }
339
408
  }
340
409
  },
410
+ "aws-cdk-lib.aws_apptest": {
411
+ "targets": {
412
+ "dotnet": {
413
+ "package": "Amazon.CDK.AWS.AppTest"
414
+ },
415
+ "java": {
416
+ "package": "software.amazon.awscdk.services.apptest"
417
+ },
418
+ "python": {
419
+ "module": "aws_cdk.aws_apptest"
420
+ }
421
+ }
422
+ },
341
423
  "aws-cdk-lib.aws_aps": {
342
424
  "targets": {
343
425
  "dotnet": {
@@ -351,6 +433,19 @@
351
433
  }
352
434
  }
353
435
  },
436
+ "aws-cdk-lib.aws_arczonalshift": {
437
+ "targets": {
438
+ "dotnet": {
439
+ "package": "Amazon.CDK.AWS.ARCZonalShift"
440
+ },
441
+ "java": {
442
+ "package": "software.amazon.awscdk.services.arczonalshift"
443
+ },
444
+ "python": {
445
+ "module": "aws_cdk.aws_arczonalshift"
446
+ }
447
+ }
448
+ },
354
449
  "aws-cdk-lib.aws_athena": {
355
450
  "targets": {
356
451
  "dotnet": {
@@ -429,6 +524,19 @@
429
524
  }
430
525
  }
431
526
  },
527
+ "aws-cdk-lib.aws_b2bi": {
528
+ "targets": {
529
+ "dotnet": {
530
+ "package": "Amazon.CDK.AWS.B2BI"
531
+ },
532
+ "java": {
533
+ "package": "software.amazon.awscdk.services.b2bi"
534
+ },
535
+ "python": {
536
+ "module": "aws_cdk.aws_b2bi"
537
+ }
538
+ }
539
+ },
432
540
  "aws-cdk-lib.aws_backup": {
433
541
  "targets": {
434
542
  "dotnet": {
@@ -448,7 +556,7 @@
448
556
  "package": "Amazon.CDK.AWS.BackupGateway"
449
557
  },
450
558
  "java": {
451
- "package": "services.backupgateway"
559
+ "package": "software.amazon.awscdk.services.backupgateway"
452
560
  },
453
561
  "python": {
454
562
  "module": "aws_cdk.aws_backupgateway"
@@ -468,6 +576,32 @@
468
576
  }
469
577
  }
470
578
  },
579
+ "aws-cdk-lib.aws_bcmdataexports": {
580
+ "targets": {
581
+ "dotnet": {
582
+ "package": "Amazon.CDK.AWS.BCMDataExports"
583
+ },
584
+ "java": {
585
+ "package": "software.amazon.awscdk.services.bcmdataexports"
586
+ },
587
+ "python": {
588
+ "module": "aws_cdk.aws_bcmdataexports"
589
+ }
590
+ }
591
+ },
592
+ "aws-cdk-lib.aws_bedrock": {
593
+ "targets": {
594
+ "dotnet": {
595
+ "package": "Amazon.CDK.AWS.Bedrock"
596
+ },
597
+ "java": {
598
+ "package": "software.amazon.awscdk.services.bedrock"
599
+ },
600
+ "python": {
601
+ "module": "aws_cdk.aws_bedrock"
602
+ }
603
+ }
604
+ },
471
605
  "aws-cdk-lib.aws_billingconductor": {
472
606
  "targets": {
473
607
  "dotnet": {
@@ -552,13 +686,26 @@
552
686
  "package": "Amazon.CDK.AWS.CleanRooms"
553
687
  },
554
688
  "java": {
555
- "package": "services.cleanrooms"
689
+ "package": "software.amazon.awscdk.services.cleanrooms"
556
690
  },
557
691
  "python": {
558
692
  "module": "aws_cdk.aws_cleanrooms"
559
693
  }
560
694
  }
561
695
  },
696
+ "aws-cdk-lib.aws_cleanroomsml": {
697
+ "targets": {
698
+ "dotnet": {
699
+ "package": "Amazon.CDK.AWS.CleanRoomsML"
700
+ },
701
+ "java": {
702
+ "package": "software.amazon.awscdk.services.cleanroomsml"
703
+ },
704
+ "python": {
705
+ "module": "aws_cdk.aws_cleanroomsml"
706
+ }
707
+ }
708
+ },
562
709
  "aws-cdk-lib.aws_cloud9": {
563
710
  "targets": {
564
711
  "dotnet": {
@@ -690,6 +837,19 @@
690
837
  }
691
838
  }
692
839
  },
840
+ "aws-cdk-lib.aws_codeconnections": {
841
+ "targets": {
842
+ "dotnet": {
843
+ "package": "Amazon.CDK.AWS.CodeConnections"
844
+ },
845
+ "java": {
846
+ "package": "software.amazon.awscdk.services.codeconnections"
847
+ },
848
+ "python": {
849
+ "module": "aws_cdk.aws_codeconnections"
850
+ }
851
+ }
852
+ },
693
853
  "aws-cdk-lib.aws_codedeploy": {
694
854
  "targets": {
695
855
  "dotnet": {
@@ -859,6 +1019,19 @@
859
1019
  }
860
1020
  }
861
1021
  },
1022
+ "aws-cdk-lib.aws_connectcampaignsv2": {
1023
+ "targets": {
1024
+ "dotnet": {
1025
+ "package": "Amazon.CDK.AWS.ConnectCampaignsV2"
1026
+ },
1027
+ "java": {
1028
+ "package": "software.amazon.awscdk.services.connectcampaignsv2"
1029
+ },
1030
+ "python": {
1031
+ "module": "aws_cdk.aws_connectcampaignsv2"
1032
+ }
1033
+ }
1034
+ },
862
1035
  "aws-cdk-lib.aws_controltower": {
863
1036
  "targets": {
864
1037
  "dotnet": {
@@ -937,6 +1110,19 @@
937
1110
  }
938
1111
  }
939
1112
  },
1113
+ "aws-cdk-lib.aws_datazone": {
1114
+ "targets": {
1115
+ "dotnet": {
1116
+ "package": "Amazon.CDK.AWS.DataZone"
1117
+ },
1118
+ "java": {
1119
+ "package": "software.amazon.awscdk.services.datazone"
1120
+ },
1121
+ "python": {
1122
+ "module": "aws_cdk.aws_datazone"
1123
+ }
1124
+ }
1125
+ },
940
1126
  "aws-cdk-lib.aws_dax": {
941
1127
  "targets": {
942
1128
  "dotnet": {
@@ -950,6 +1136,19 @@
950
1136
  }
951
1137
  }
952
1138
  },
1139
+ "aws-cdk-lib.aws_deadline": {
1140
+ "targets": {
1141
+ "dotnet": {
1142
+ "package": "Amazon.CDK.AWS.Deadline"
1143
+ },
1144
+ "java": {
1145
+ "package": "software.amazon.awscdk.services.deadline"
1146
+ },
1147
+ "python": {
1148
+ "module": "aws_cdk.aws_deadline"
1149
+ }
1150
+ }
1151
+ },
953
1152
  "aws-cdk-lib.aws_detective": {
954
1153
  "targets": {
955
1154
  "dotnet": {
@@ -1288,6 +1487,19 @@
1288
1487
  }
1289
1488
  }
1290
1489
  },
1490
+ "aws-cdk-lib.aws_entityresolution": {
1491
+ "targets": {
1492
+ "dotnet": {
1493
+ "package": "Amazon.CDK.AWS.EntityResolution"
1494
+ },
1495
+ "java": {
1496
+ "package": "software.amazon.awscdk.services.entityresolution"
1497
+ },
1498
+ "python": {
1499
+ "module": "aws_cdk.aws_entityresolution"
1500
+ }
1501
+ }
1502
+ },
1291
1503
  "aws-cdk-lib.aws_events": {
1292
1504
  "targets": {
1293
1505
  "dotnet": {
@@ -1535,6 +1747,19 @@
1535
1747
  }
1536
1748
  }
1537
1749
  },
1750
+ "aws-cdk-lib.aws_healthimaging": {
1751
+ "targets": {
1752
+ "dotnet": {
1753
+ "package": "Amazon.CDK.AWS.HealthImaging"
1754
+ },
1755
+ "java": {
1756
+ "package": "software.amazon.awscdk.services.healthimaging"
1757
+ },
1758
+ "python": {
1759
+ "module": "aws_cdk.aws_healthimaging"
1760
+ }
1761
+ }
1762
+ },
1538
1763
  "aws-cdk-lib.aws_healthlake": {
1539
1764
  "targets": {
1540
1765
  "dotnet": {
@@ -1626,29 +1851,29 @@
1626
1851
  }
1627
1852
  }
1628
1853
  },
1629
- "aws-cdk-lib.aws_iot": {
1854
+ "aws-cdk-lib.aws_invoicing": {
1630
1855
  "targets": {
1631
1856
  "dotnet": {
1632
- "namespace": "Amazon.CDK.AWS.IoT"
1857
+ "package": "Amazon.CDK.AWS.Invoicing"
1633
1858
  },
1634
1859
  "java": {
1635
- "package": "software.amazon.awscdk.services.iot"
1860
+ "package": "software.amazon.awscdk.services.invoicing"
1636
1861
  },
1637
1862
  "python": {
1638
- "module": "aws_cdk.aws_iot"
1863
+ "module": "aws_cdk.aws_invoicing"
1639
1864
  }
1640
1865
  }
1641
1866
  },
1642
- "aws-cdk-lib.aws_iot1click": {
1867
+ "aws-cdk-lib.aws_iot": {
1643
1868
  "targets": {
1644
1869
  "dotnet": {
1645
- "namespace": "Amazon.CDK.AWS.IoT1Click"
1870
+ "namespace": "Amazon.CDK.AWS.IoT"
1646
1871
  },
1647
1872
  "java": {
1648
- "package": "software.amazon.awscdk.services.iot1click"
1873
+ "package": "software.amazon.awscdk.services.iot"
1649
1874
  },
1650
1875
  "python": {
1651
- "module": "aws_cdk.aws_iot1click"
1876
+ "module": "aws_cdk.aws_iot"
1652
1877
  }
1653
1878
  }
1654
1879
  },
@@ -1977,6 +2202,19 @@
1977
2202
  }
1978
2203
  }
1979
2204
  },
2205
+ "aws-cdk-lib.aws_launchwizard": {
2206
+ "targets": {
2207
+ "dotnet": {
2208
+ "package": "Amazon.CDK.AWS.LaunchWizard"
2209
+ },
2210
+ "java": {
2211
+ "package": "software.amazon.awscdk.services.launchwizard"
2212
+ },
2213
+ "python": {
2214
+ "module": "aws_cdk.aws_launchwizard"
2215
+ }
2216
+ }
2217
+ },
1980
2218
  "aws-cdk-lib.aws_lex": {
1981
2219
  "targets": {
1982
2220
  "dotnet": {
@@ -2185,6 +2423,19 @@
2185
2423
  }
2186
2424
  }
2187
2425
  },
2426
+ "aws-cdk-lib.aws_mediapackagev2": {
2427
+ "targets": {
2428
+ "dotnet": {
2429
+ "package": "Amazon.CDK.AWS.MediaPackageV2"
2430
+ },
2431
+ "java": {
2432
+ "package": "software.amazon.awscdk.services.mediapackagev2"
2433
+ },
2434
+ "python": {
2435
+ "module": "aws_cdk.aws_mediapackagev2"
2436
+ }
2437
+ }
2438
+ },
2188
2439
  "aws-cdk-lib.aws_mediastore": {
2189
2440
  "targets": {
2190
2441
  "dotnet": {
@@ -2263,6 +2514,19 @@
2263
2514
  }
2264
2515
  }
2265
2516
  },
2517
+ "aws-cdk-lib.aws_neptunegraph": {
2518
+ "targets": {
2519
+ "dotnet": {
2520
+ "package": "Amazon.CDK.AWS.NeptuneGraph"
2521
+ },
2522
+ "java": {
2523
+ "package": "software.amazon.awscdk.services.neptunegraph"
2524
+ },
2525
+ "python": {
2526
+ "module": "aws_cdk.aws_neptunegraph"
2527
+ }
2528
+ }
2529
+ },
2266
2530
  "aws-cdk-lib.aws_networkfirewall": {
2267
2531
  "targets": {
2268
2532
  "dotnet": {
@@ -2302,6 +2566,32 @@
2302
2566
  }
2303
2567
  }
2304
2568
  },
2569
+ "aws-cdk-lib.aws_notifications": {
2570
+ "targets": {
2571
+ "dotnet": {
2572
+ "package": "Amazon.CDK.AWS.Notifications"
2573
+ },
2574
+ "java": {
2575
+ "package": "software.amazon.awscdk.services.notifications"
2576
+ },
2577
+ "python": {
2578
+ "module": "aws_cdk.aws_notifications"
2579
+ }
2580
+ }
2581
+ },
2582
+ "aws-cdk-lib.aws_notificationscontacts": {
2583
+ "targets": {
2584
+ "dotnet": {
2585
+ "package": "Amazon.CDK.AWS.NotificationsContacts"
2586
+ },
2587
+ "java": {
2588
+ "package": "software.amazon.awscdk.services.notificationscontacts"
2589
+ },
2590
+ "python": {
2591
+ "module": "aws_cdk.aws_notificationscontacts"
2592
+ }
2593
+ }
2594
+ },
2305
2595
  "aws-cdk-lib.aws_oam": {
2306
2596
  "targets": {
2307
2597
  "dotnet": {
@@ -2399,7 +2689,7 @@
2399
2689
  "package": "Amazon.CDK.AWS.OSIS"
2400
2690
  },
2401
2691
  "java": {
2402
- "package": "services.osis"
2692
+ "package": "software.amazon.awscdk.services.osis"
2403
2693
  },
2404
2694
  "python": {
2405
2695
  "module": "aws_cdk.aws_osis"
@@ -2419,6 +2709,58 @@
2419
2709
  }
2420
2710
  }
2421
2711
  },
2712
+ "aws-cdk-lib.aws_paymentcryptography": {
2713
+ "targets": {
2714
+ "dotnet": {
2715
+ "package": "Amazon.CDK.AWS.PaymentCryptography"
2716
+ },
2717
+ "java": {
2718
+ "package": "software.amazon.awscdk.services.paymentcryptography"
2719
+ },
2720
+ "python": {
2721
+ "module": "aws_cdk.aws_paymentcryptography"
2722
+ }
2723
+ }
2724
+ },
2725
+ "aws-cdk-lib.aws_pcaconnectorad": {
2726
+ "targets": {
2727
+ "dotnet": {
2728
+ "package": "Amazon.CDK.AWS.PCAConnectorAD"
2729
+ },
2730
+ "java": {
2731
+ "package": "software.amazon.awscdk.services.pcaconnectorad"
2732
+ },
2733
+ "python": {
2734
+ "module": "aws_cdk.aws_pcaconnectorad"
2735
+ }
2736
+ }
2737
+ },
2738
+ "aws-cdk-lib.aws_pcaconnectorscep": {
2739
+ "targets": {
2740
+ "dotnet": {
2741
+ "package": "Amazon.CDK.AWS.PCAConnectorSCEP"
2742
+ },
2743
+ "java": {
2744
+ "package": "software.amazon.awscdk.services.pcaconnectorscep"
2745
+ },
2746
+ "python": {
2747
+ "module": "aws_cdk.aws_pcaconnectorscep"
2748
+ }
2749
+ }
2750
+ },
2751
+ "aws-cdk-lib.aws_pcs": {
2752
+ "targets": {
2753
+ "dotnet": {
2754
+ "package": "Amazon.CDK.AWS.PCS"
2755
+ },
2756
+ "java": {
2757
+ "package": "software.amazon.awscdk.services.pcs"
2758
+ },
2759
+ "python": {
2760
+ "module": "aws_cdk.aws_pcs"
2761
+ }
2762
+ }
2763
+ },
2422
2764
  "aws-cdk-lib.aws_personalize": {
2423
2765
  "targets": {
2424
2766
  "dotnet": {
@@ -2477,13 +2819,26 @@
2477
2819
  "package": "Amazon.CDK.AWS.Proton"
2478
2820
  },
2479
2821
  "java": {
2480
- "package": "services.proton"
2822
+ "package": "software.amazon.awscdk.services.proton"
2481
2823
  },
2482
2824
  "python": {
2483
2825
  "module": "aws_cdk.aws_proton"
2484
2826
  }
2485
2827
  }
2486
2828
  },
2829
+ "aws-cdk-lib.aws_qbusiness": {
2830
+ "targets": {
2831
+ "dotnet": {
2832
+ "package": "Amazon.CDK.AWS.QBusiness"
2833
+ },
2834
+ "java": {
2835
+ "package": "software.amazon.awscdk.services.qbusiness"
2836
+ },
2837
+ "python": {
2838
+ "module": "aws_cdk.aws_qbusiness"
2839
+ }
2840
+ }
2841
+ },
2487
2842
  "aws-cdk-lib.aws_qldb": {
2488
2843
  "targets": {
2489
2844
  "dotnet": {
@@ -2523,6 +2878,19 @@
2523
2878
  }
2524
2879
  }
2525
2880
  },
2881
+ "aws-cdk-lib.aws_rbin": {
2882
+ "targets": {
2883
+ "dotnet": {
2884
+ "package": "Amazon.CDK.AWS.Rbin"
2885
+ },
2886
+ "java": {
2887
+ "package": "software.amazon.awscdk.services.rbin"
2888
+ },
2889
+ "python": {
2890
+ "module": "aws_cdk.aws_rbin"
2891
+ }
2892
+ }
2893
+ },
2526
2894
  "aws-cdk-lib.aws_rds": {
2527
2895
  "targets": {
2528
2896
  "dotnet": {
@@ -2692,6 +3060,19 @@
2692
3060
  }
2693
3061
  }
2694
3062
  },
3063
+ "aws-cdk-lib.aws_route53profiles": {
3064
+ "targets": {
3065
+ "dotnet": {
3066
+ "package": "Amazon.CDK.AWS.Route53Profiles"
3067
+ },
3068
+ "java": {
3069
+ "package": "software.amazon.awscdk.services.route53profiles"
3070
+ },
3071
+ "python": {
3072
+ "module": "aws_cdk.aws_route53profiles"
3073
+ }
3074
+ }
3075
+ },
2695
3076
  "aws-cdk-lib.aws_route53recoverycontrol": {
2696
3077
  "targets": {
2697
3078
  "dotnet": {
@@ -2796,6 +3177,19 @@
2796
3177
  }
2797
3178
  }
2798
3179
  },
3180
+ "aws-cdk-lib.aws_s3express": {
3181
+ "targets": {
3182
+ "dotnet": {
3183
+ "package": "Amazon.CDK.AWS.S3Express"
3184
+ },
3185
+ "java": {
3186
+ "package": "software.amazon.awscdk.services.s3express"
3187
+ },
3188
+ "python": {
3189
+ "module": "aws_cdk.aws_s3express"
3190
+ }
3191
+ }
3192
+ },
2799
3193
  "aws-cdk-lib.aws_s3objectlambda": {
2800
3194
  "targets": {
2801
3195
  "dotnet": {
@@ -2822,6 +3216,19 @@
2822
3216
  }
2823
3217
  }
2824
3218
  },
3219
+ "aws-cdk-lib.aws_s3tables": {
3220
+ "targets": {
3221
+ "dotnet": {
3222
+ "package": "Amazon.CDK.AWS.S3Tables"
3223
+ },
3224
+ "java": {
3225
+ "package": "software.amazon.awscdk.services.s3tables"
3226
+ },
3227
+ "python": {
3228
+ "module": "aws_cdk.aws_s3tables"
3229
+ }
3230
+ }
3231
+ },
2825
3232
  "aws-cdk-lib.aws_sagemaker": {
2826
3233
  "targets": {
2827
3234
  "dotnet": {
@@ -2900,6 +3307,19 @@
2900
3307
  }
2901
3308
  }
2902
3309
  },
3310
+ "aws-cdk-lib.aws_securitylake": {
3311
+ "targets": {
3312
+ "dotnet": {
3313
+ "package": "Amazon.CDK.AWS.SecurityLake"
3314
+ },
3315
+ "java": {
3316
+ "package": "software.amazon.awscdk.services.securitylake"
3317
+ },
3318
+ "python": {
3319
+ "module": "aws_cdk.aws_securitylake"
3320
+ }
3321
+ }
3322
+ },
2903
3323
  "aws-cdk-lib.aws_servicecatalog": {
2904
3324
  "targets": {
2905
3325
  "dotnet": {
@@ -2971,7 +3391,7 @@
2971
3391
  "package": "Amazon.CDK.AWS.Shield"
2972
3392
  },
2973
3393
  "java": {
2974
- "package": "services.shield"
3394
+ "package": "software.amazon.awscdk.services.shield"
2975
3395
  },
2976
3396
  "python": {
2977
3397
  "module": "aws_cdk.aws_shield"
@@ -3082,6 +3502,19 @@
3082
3502
  }
3083
3503
  }
3084
3504
  },
3505
+ "aws-cdk-lib.aws_ssmquicksetup": {
3506
+ "targets": {
3507
+ "dotnet": {
3508
+ "package": "Amazon.CDK.AWS.SSMQuickSetup"
3509
+ },
3510
+ "java": {
3511
+ "package": "software.amazon.awscdk.services.ssmquicksetup"
3512
+ },
3513
+ "python": {
3514
+ "module": "aws_cdk.aws_ssmquicksetup"
3515
+ }
3516
+ }
3517
+ },
3085
3518
  "aws-cdk-lib.aws_sso": {
3086
3519
  "targets": {
3087
3520
  "dotnet": {
@@ -3192,7 +3625,7 @@
3192
3625
  "package": "Amazon.CDK.AWS.VerifiedPermissions"
3193
3626
  },
3194
3627
  "java": {
3195
- "package": "services.verifiedpermissions"
3628
+ "package": "software.amazon.awscdk.services.verifiedpermissions"
3196
3629
  },
3197
3630
  "python": {
3198
3631
  "module": "aws_cdk.aws_verifiedpermissions"
@@ -3290,32 +3723,46 @@
3290
3723
  }
3291
3724
  }
3292
3725
  },
3293
- "aws-cdk-lib.aws_xray": {
3726
+ "aws-cdk-lib.aws_workspacesthinclient": {
3294
3727
  "targets": {
3295
3728
  "dotnet": {
3296
- "namespace": "Amazon.CDK.AWS.XRay"
3729
+ "package": "Amazon.CDK.AWS.WorkSpacesThinClient"
3297
3730
  },
3298
3731
  "java": {
3299
- "package": "software.amazon.awscdk.services.xray"
3732
+ "package": "software.amazon.awscdk.services.workspacesthinclient"
3300
3733
  },
3301
3734
  "python": {
3302
- "module": "aws_cdk.aws_xray"
3735
+ "module": "aws_cdk.aws_workspacesthinclient"
3736
+ }
3737
+ }
3738
+ },
3739
+ "aws-cdk-lib.aws_workspacesweb": {
3740
+ "targets": {
3741
+ "dotnet": {
3742
+ "package": "Amazon.CDK.AWS.WorkSpacesWeb"
3743
+ },
3744
+ "java": {
3745
+ "package": "software.amazon.awscdk.services.workspacesweb"
3746
+ },
3747
+ "python": {
3748
+ "module": "aws_cdk.aws_workspacesweb"
3303
3749
  }
3304
3750
  }
3305
3751
  },
3306
- "aws-cdk-lib.cloud_assembly_schema": {
3752
+ "aws-cdk-lib.aws_xray": {
3307
3753
  "targets": {
3308
3754
  "dotnet": {
3309
- "namespace": "Amazon.CDK.CloudAssembly.Schema"
3755
+ "namespace": "Amazon.CDK.AWS.XRay"
3310
3756
  },
3311
3757
  "java": {
3312
- "package": "software.amazon.awscdk.cloudassembly.schema"
3758
+ "package": "software.amazon.awscdk.services.xray"
3313
3759
  },
3314
3760
  "python": {
3315
- "module": "aws_cdk.cloud_assembly_schema"
3761
+ "module": "aws_cdk.aws_xray"
3316
3762
  }
3317
3763
  }
3318
3764
  },
3765
+ "aws-cdk-lib.cloud_assembly_schema": {},
3319
3766
  "aws-cdk-lib.cloudformation_include": {
3320
3767
  "targets": {
3321
3768
  "dotnet": {
@@ -3491,7 +3938,7 @@
3491
3938
  "stability": "stable"
3492
3939
  },
3493
3940
  "homepage": "https://github.com/go-to-k/image-scanner-with-trivy",
3494
- "jsiiVersion": "5.0.21 (build 1951a18)",
3941
+ "jsiiVersion": "5.8.12 (build 5c353f5)",
3495
3942
  "keywords": [
3496
3943
  "aws",
3497
3944
  "aws-cdk",
@@ -4198,6 +4645,6 @@
4198
4645
  "symbolId": "src/image-scanner-with-trivy:Severity"
4199
4646
  }
4200
4647
  },
4201
- "version": "1.4.3",
4202
- "fingerprint": "6/xDq8ZTtlK5eFIihPgazWlJ4sXUMgk2oN+0eRIifY0="
4648
+ "version": "2.0.0",
4649
+ "fingerprint": "AgLZ3VCxzpZE+D9DPljC53OKCs6bcGXU0vjOIwofx5w="
4203
4650
  }
package/.projenrc.d.ts ADDED
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ ## Contribution
2
+
3
+ ### Update Snapshots in Integration Tests
4
+
5
+ ```sh
6
+ yarn tsc -p tsconfig.dev.json
7
+
8
+ yarn integ --update-on-failed
9
+ ```
@@ -23,7 +23,7 @@ var Severity;
23
23
  Severity["MEDIUM"] = "MEDIUM";
24
24
  Severity["HIGH"] = "HIGH";
25
25
  Severity["CRITICAL"] = "CRITICAL";
26
- })(Severity = exports.Severity || (exports.Severity = {}));
26
+ })(Severity || (exports.Severity = Severity = {}));
27
27
  /**
28
28
  * Enum for Scanners
29
29
  *
@@ -35,7 +35,7 @@ var Scanners;
35
35
  Scanners["CONFIG"] = "config";
36
36
  Scanners["SECRET"] = "secret";
37
37
  Scanners["LICENSE"] = "license";
38
- })(Scanners = exports.Scanners || (exports.Scanners = {}));
38
+ })(Scanners || (exports.Scanners = Scanners = {}));
39
39
  /**
40
40
  * Enum for ImageConfigScanners
41
41
  *
@@ -45,7 +45,7 @@ var ImageConfigScanners;
45
45
  (function (ImageConfigScanners) {
46
46
  ImageConfigScanners["CONFIG"] = "config";
47
47
  ImageConfigScanners["SECRET"] = "secret";
48
- })(ImageConfigScanners = exports.ImageConfigScanners || (exports.ImageConfigScanners = {}));
48
+ })(ImageConfigScanners || (exports.ImageConfigScanners = ImageConfigScanners = {}));
49
49
  /**
50
50
  * Represents the output of the scan logs.
51
51
  */
@@ -57,9 +57,9 @@ class ScanLogsOutput {
57
57
  return new CloudWatchLogsOutput(options);
58
58
  }
59
59
  }
60
- _a = JSII_RTTI_SYMBOL_1;
61
- ScanLogsOutput[_a] = { fqn: "image-scanner-with-trivy.ScanLogsOutput", version: "1.4.3" };
62
60
  exports.ScanLogsOutput = ScanLogsOutput;
61
+ _a = JSII_RTTI_SYMBOL_1;
62
+ ScanLogsOutput[_a] = { fqn: "image-scanner-with-trivy.ScanLogsOutput", version: "2.0.0" };
63
63
  class CloudWatchLogsOutput extends ScanLogsOutput {
64
64
  constructor(options) {
65
65
  super();
@@ -179,7 +179,7 @@ class ImageScannerWithTrivy extends constructs_1.Construct {
179
179
  }
180
180
  }
181
181
  }
182
- _b = JSII_RTTI_SYMBOL_1;
183
- ImageScannerWithTrivy[_b] = { fqn: "image-scanner-with-trivy.ImageScannerWithTrivy", version: "1.4.3" };
184
182
  exports.ImageScannerWithTrivy = ImageScannerWithTrivy;
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-scanner-with-trivy.js","sourceRoot":"","sources":["../src/image-scanner-with-trivy.ts"],"names":[],"mappings":"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","sourcesContent":["import { join } from 'path';\nimport {\n  Annotations,\n  CfnDeletionPolicy,\n  CustomResource,\n  Duration,\n  RemovalPolicy,\n  Size,\n  Stack,\n  Token,\n} from 'aws-cdk-lib';\nimport { IRepository } from 'aws-cdk-lib/aws-ecr';\nimport { Platform } from 'aws-cdk-lib/aws-ecr-assets';\nimport { IGrantable } from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  AssetCode,\n  Handler,\n  Runtime,\n  SingletonFunction,\n} from 'aws-cdk-lib/aws-lambda';\nimport { CfnLogGroup, ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Provider } from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport {\n  CloudWatchLogsOutputOptions,\n  ScanLogsOutputOptions,\n  ScanLogsOutputType,\n  ScannerCustomResourceProps,\n} from './types';\n\n/**\n * Enum for Severity Selection\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#severity-selection\n */\nexport enum Severity {\n  UNKNOWN = 'UNKNOWN',\n  LOW = 'LOW',\n  MEDIUM = 'MEDIUM',\n  HIGH = 'HIGH',\n  CRITICAL = 'CRITICAL',\n}\n\n/**\n * Enum for Scanners\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#enabledisable-scanners\n */\nexport enum Scanners {\n  VULN = 'vuln',\n  CONFIG = 'config',\n  SECRET = 'secret',\n  LICENSE = 'license',\n}\n\n/**\n * Enum for ImageConfigScanners\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/target/container_image/#container-image-metadata\n */\nexport enum ImageConfigScanners {\n  CONFIG = 'config',\n  SECRET = 'secret',\n}\n\n/**\n * Configuration for scan logs output to CloudWatch Logs log group.\n */\nexport interface CloudWatchLogsOutputProps {\n  /**\n   * The log group to output scan logs.\n   */\n  readonly logGroup: ILogGroup;\n}\n\n/**\n * Represents the output of the scan logs.\n */\nexport abstract class ScanLogsOutput {\n  /**\n   * Scan logs output to CloudWatch Logs log group.\n   */\n  public static cloudWatchLogs(options: CloudWatchLogsOutputProps): ScanLogsOutput {\n    return new CloudWatchLogsOutput(options);\n  }\n\n  /**\n   * Returns the output configuration for scan logs.\n   */\n  public abstract bind(grantee: IGrantable): ScanLogsOutputOptions;\n}\n\nclass CloudWatchLogsOutput extends ScanLogsOutput {\n  /**\n   * The log group to output scan logs.\n   */\n  private readonly logGroup: ILogGroup;\n\n  constructor(options: CloudWatchLogsOutputProps) {\n    super();\n\n    this.logGroup = options.logGroup;\n  }\n\n  public bind(grantee: IGrantable): CloudWatchLogsOutputOptions {\n    // Most Lambdas are granted AWSLambdaBasicExecutionRole and can write to any CloudWatch Logs.\n    // However, just in case AWSLambdaBasicExecutionRole is not granted, allow writing to CloudWatch Logs.\n    this.logGroup.grantWrite(grantee);\n\n    return {\n      type: ScanLogsOutputType.CLOUDWATCH_LOGS,\n      logGroupName: this.logGroup.logGroupName,\n    };\n  }\n}\n\nexport interface ImageScannerWithTrivyProps {\n  /**\n   * Image URI for scan target.\n   */\n  readonly imageUri: string;\n\n  /**\n   * Repository including the image URI for scan target.\n   *\n   * Because of grantPull to CustomResourceLambda.\n   */\n  readonly repository: IRepository;\n\n  /**\n   * The unfixed/unfixable vulnerabilities mean that the patch has not yet been provided on their distribution.\n   *\n   * To hide unfixed/unfixable vulnerabilities, you can use the `--ignore-unfixed` flag.\n   *\n   * @default false\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#unfixed-vulnerabilities\n   */\n  readonly ignoreUnfixed?: boolean;\n\n  /**\n   * Severity Selection\n   *\n   * The severity is taken from the selected data source since the severity from vendors is more accurate.\n   * Using CVE-2023-0464 as an example, while it is rated as \"HIGH\" in NVD, Red Hat has marked its 'Impact' as \"Low\". As a result, Trivy will display it as \"Low\".\n   *\n   * The severity depends on the compile option, the default configuration, etc. NVD doesn't know how the vendor distributes the software.\n   * Red Hat evaluates the severity more accurately. That's why Trivy prefers vendor scores over NVD.\n   *\n   * It defaults to `CRITICAL` IN THIS CONSTRUCT for safety in CI/CD, but the default configuration of Trivy is \"CRITICAL,HIGH,MEDIUM,LOW,UNKNOWN\".\n   *\n   * @default [Severity.CRITICAL]\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#severity-selection\n   */\n  readonly severity?: Severity[];\n\n  /**\n   * Enable/Disable Scanners\n   *\n   * You can enable/disable scanners with the `scanners`.\n   *\n   * For example, container image scanning enables vulnerability (VULN) and secret scanners (SECRET) by default.\n   * If you don't need secret scanning, it can be disabled by specifying Scanners.VULN only.\n   *\n   * @default [Security.VULN,Scanners.SECRET]\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#enabledisable-scanners\n   */\n  readonly scanners?: Scanners[];\n\n  /**\n   * Enum for ImageConfigScanners\n   *\n   * Container images have configuration. docker inspect and `docker history` show the information according to the configuration.\n   * Trivy scans the configuration of container images for\n   *\n   * - Misconfigurations\n   * - Secrets\n   *\n   * They are disabled by default. You can enable them with `imageConfigScanners`.\n   *\n   * @default []\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/target/container_image/#container-image-metadata\n   */\n  readonly imageConfigScanners?: ImageConfigScanners[];\n\n  /**\n   * Exit Code\n   *\n   * Use the `exitCode` option if you want to exit with a non-zero exit code.\n   *\n   * You can specify 0 if you do not want to exit even when vulnerabilities are detected.\n   *\n   * It defaults to 1 IN THIS CONSTRUCT for safety in CI/CD. In the original trivy, it is 0.\n   *\n   * @default 1\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#exit-code\n   */\n  readonly exitCode?: number;\n\n  /**\n   * Exit on EOL\n   *\n   * Sometimes you may surprisingly get 0 vulnerabilities in an old image:\n   *  - Enabling --ignore-unfixed option while all packages have no fixed versions.\n   *  - Scanning a rather outdated OS (e.g. Ubuntu 10.04).\n   *\n   * An OS at the end of service/life (EOL) usually gets into this situation, which is definitely full of vulnerabilities.\n   * `exitOnEol` can fail scanning on EOL OS with a non-zero code.\n   *\n   * It defaults to 1 IN THIS CONSTRUCT for safety in CI/CD. In the original trivy, it is 0.\n   *\n   * @default 1\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#exit-on-eol\n   */\n  readonly exitOnEol?: number;\n\n  /**\n   * By Finding IDs\n   *\n   * The ignore rules written to the .trivyignore in trivy.\n   * Put each line you write in the file into one element of the array.\n   *\n   * @example\n   *     $ cat .trivyignore\n   *     # Accept the risk\n   *     CVE-2018-14618\n   *\n   *     # Accept the risk until 2023-01-01\n   *     CVE-2019-14697 exp:2023-01-01\n   *\n   *     # No impact in our settings\n   *     CVE-2019-1543\n   *\n   *     # Ignore misconfigurations\n   *     AVD-DS-0002\n   *\n   *     # Ignore secrets\n   *     generic-unwanted-rule\n   *     aws-account-id\n   *\n   * @default []\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/filtering/#trivyignore\n   */\n  readonly trivyIgnore?: string[];\n\n  /**\n   * Memory Size (MB) for Scanner Lambda\n   *\n   * You can specify between `3008` and `10240`.\n   *\n   * If this Construct execution terminates abnormally due to SIGKILL, try a larger size.\n   *\n   * Default value (`3008` MB) is Maximum Lambda memory size for default AWS account without quota limit increase.\n   *\n   * @default 3008\n   */\n  readonly memorySize?: number;\n\n  /**\n   * Scan Image on a specific Architecture and OS\n   *\n   * By default, Trivy loads an image on a `linux/amd64` machine.\n   *\n   * To customize this, pass a `platform` argument in the format OS/Architecture for the image, such as `linux/arm64`\n   *\n   * @default -\n   */\n  readonly platform?: string;\n\n  /**\n   * The removal policy to apply to Scanner Lambda's default log group\n   *\n   * If you use ImageScannerWithTrivy construct multiple times in the same stack, you cannot set different removal policies for the default log group.\n   * See `Notes` section in the README for more details.\n   *\n   * @default - Scanner Lambda creates the default log group(`/aws/lambda/${functionName}`).\n   */\n  readonly defaultLogGroupRemovalPolicy?: RemovalPolicy;\n\n  /**\n   * The number of days log events are kept in Scanner Lambda's default log group\n   *\n   * If you use ImageScannerWithTrivy construct multiple times in the same stack, you cannot set different retention days for the default log group.\n   * See `Notes` section in the README for more details.\n   *\n   * @default - Scanner Lambda creates the default log group(`/aws/lambda/${functionName}`) and log events never expire.\n   */\n  readonly defaultLogGroupRetentionDays?: RetentionDays;\n\n  /**\n   * Configuration for scan logs output\n   *\n   * By default, scan logs are output to default log group created by Scanner Lambda.\n   *\n   * Specify this if you want to send scan logs to other than the default log group.\n   *\n   * Currently, only `cloudWatchLogs` is supported.\n   *\n   * @default - scan logs output to default log group created by Scanner Lambda(`/aws/lambda/${functionName}`)\n   */\n  readonly scanLogsOutput?: ScanLogsOutput;\n}\n\n// Maximum Lambda memory size for default AWS account without quota limit increase\nconst DEFAULT_MEMORY_SIZE = 3008;\n\nexport class ImageScannerWithTrivy extends Construct {\n  constructor(scope: Construct, id: string, props: ImageScannerWithTrivyProps) {\n    super(scope, id);\n\n    if (\n      props.memorySize &&\n      !Token.isUnresolved(props.memorySize) &&\n      (props.memorySize < 3008 || props.memorySize > 10240)\n    ) {\n      throw new Error(\n        `You can specify between \\`3008\\` and \\`10240\\` for \\`memorySize\\`, got ${props.memorySize}.`,\n      );\n    }\n\n    const lambdaPurpose = 'Custom::ImageScannerWithTrivyCustomResourceLambda';\n    const customResourceLambda = new SingletonFunction(this, 'CustomResourceLambda', {\n      uuid: '470b6343-d267-f753-226c-1e99f09f319a',\n      lambdaPurpose,\n      runtime: Runtime.FROM_IMAGE,\n      handler: Handler.FROM_IMAGE,\n      code: AssetCode.fromAssetImage(join(__dirname, '../assets/lambda'), {\n        platform: Platform.LINUX_ARM64,\n        // exclude node_modules\n        // because the native binary of the installed esbuild changes depending on the cpu architecture\n        // and the hash value of the image asset changes depending on the execution environment.\n        exclude: ['node_modules'],\n      }),\n      architecture: Architecture.ARM_64,\n      timeout: Duration.seconds(900),\n      retryAttempts: 0,\n      memorySize: props.memorySize ?? DEFAULT_MEMORY_SIZE,\n      ephemeralStorageSize: Size.gibibytes(10), // for cases that need to update trivy DB: /tmp/trivy/db/trivy.db\n    });\n    props.repository.grantPull(customResourceLambda);\n\n    const customResourceLambdaLogGroupConstructName = `DefaultLogGroupFor${lambdaPurpose}`;\n\n    this.validateLambdaDefaultLogGroupOptions(customResourceLambdaLogGroupConstructName, props);\n\n    if (props.defaultLogGroupRemovalPolicy || props.defaultLogGroupRetentionDays) {\n      this.ensureLambdaDefaultLogGroup(\n        customResourceLambda,\n        customResourceLambdaLogGroupConstructName,\n        props,\n      );\n    }\n\n    const imageScannerProvider = new Provider(this, 'Provider', {\n      onEventHandler: customResourceLambda,\n    });\n\n    const imageScannerProperties: ScannerCustomResourceProps = {\n      addr: this.node.addr,\n      imageUri: props.imageUri,\n      ignoreUnfixed: String(props.ignoreUnfixed ?? false),\n      severity: props.severity ?? [Severity.CRITICAL],\n      scanners: props.scanners ?? [],\n      imageConfigScanners: props.imageConfigScanners ?? [],\n      exitCode: props.exitCode ?? 1,\n      exitOnEol: props.exitOnEol ?? 1,\n      trivyIgnore: props.trivyIgnore ?? [],\n      platform: props.platform ?? '',\n      output: props.scanLogsOutput?.bind(customResourceLambda),\n    };\n\n    new CustomResource(this, 'Resource', {\n      resourceType: 'Custom::ImageScannerWithTrivy',\n      properties: imageScannerProperties,\n      serviceToken: imageScannerProvider.serviceToken,\n    });\n  }\n\n  /**\n   * Validates that specified default log group options are the same for existing default log group.\n   */\n  private validateLambdaDefaultLogGroupOptions(\n    logGroupConstructName: string,\n    props: ImageScannerWithTrivyProps,\n  ): void {\n    const existing = Stack.of(this).node.tryFindChild(logGroupConstructName) as\n      | LogGroup\n      | undefined;\n    if (!existing) return;\n\n    const cfnLogGroup = existing.node.defaultChild as CfnLogGroup;\n\n    if (\n      !this.isSameResourceDeletionBehavior(\n        props.defaultLogGroupRemovalPolicy,\n        cfnLogGroup.cfnOptions.deletionPolicy,\n      ) ||\n      cfnLogGroup.retentionInDays !== props.defaultLogGroupRetentionDays\n    ) {\n      Annotations.of(this).addWarningV2(\n        '@image-scanner-with-trivy:duplicateLambdaDefaultLogGroupOptions',\n        \"You have to set the same values for 'defaultLogGroupRemovalPolicy' and 'defaultLogGroupRetentionDays' for each ImageScannerWithTrivy construct in the same stack.\",\n      );\n    }\n  }\n\n  /**\n   * Creates the default log group for Scanner Lambda if it does not exist.\n   *\n   * This method checks if the default log group for Scanner Lambda exists in children of the stack construct.\n   * If it does not exist, it creates the default log group for Scanner Lambda as a child of the stack construct.\n   */\n  private ensureLambdaDefaultLogGroup(\n    singletonFunction: SingletonFunction,\n    logGroupConstructName: string,\n    props: ImageScannerWithTrivyProps,\n  ): LogGroup {\n    const existing = Stack.of(this).node.tryFindChild(logGroupConstructName) as\n      | LogGroup\n      | undefined;\n    if (existing) {\n      return existing;\n    }\n\n    return new LogGroup(Stack.of(this), logGroupConstructName, {\n      logGroupName: `/aws/lambda/${singletonFunction.functionName}`,\n      retention: props.defaultLogGroupRetentionDays,\n      removalPolicy: props.defaultLogGroupRemovalPolicy,\n    });\n  }\n\n  private isSameResourceDeletionBehavior(\n    removalPolicy?: RemovalPolicy,\n    deletionPolicy?: CfnDeletionPolicy,\n  ): boolean {\n    switch (removalPolicy) {\n      case RemovalPolicy.DESTROY:\n        return deletionPolicy === CfnDeletionPolicy.DELETE;\n      case RemovalPolicy.RETAIN:\n        return deletionPolicy === CfnDeletionPolicy.RETAIN;\n      case RemovalPolicy.SNAPSHOT:\n        return deletionPolicy === CfnDeletionPolicy.SNAPSHOT;\n      case RemovalPolicy.RETAIN_ON_UPDATE_OR_DELETE:\n        return deletionPolicy === CfnDeletionPolicy.RETAIN_EXCEPT_ON_CREATE;\n      case undefined:\n        return deletionPolicy === undefined;\n      default:\n        return removalPolicy satisfies never;\n    }\n  }\n}\n"]}
183
+ _b = JSII_RTTI_SYMBOL_1;
184
+ ImageScannerWithTrivy[_b] = { fqn: "image-scanner-with-trivy.ImageScannerWithTrivy", version: "2.0.0" };
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-scanner-with-trivy.js","sourceRoot":"","sources":["../src/image-scanner-with-trivy.ts"],"names":[],"mappings":"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","sourcesContent":["import { join } from 'path';\nimport {\n  Annotations,\n  CfnDeletionPolicy,\n  CustomResource,\n  Duration,\n  RemovalPolicy,\n  Size,\n  Stack,\n  Token,\n} from 'aws-cdk-lib';\nimport { IRepository } from 'aws-cdk-lib/aws-ecr';\nimport { Platform } from 'aws-cdk-lib/aws-ecr-assets';\nimport { IGrantable } from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  AssetCode,\n  Handler,\n  Runtime,\n  SingletonFunction,\n} from 'aws-cdk-lib/aws-lambda';\nimport { CfnLogGroup, ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Provider } from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport {\n  CloudWatchLogsOutputOptions,\n  ScanLogsOutputOptions,\n  ScanLogsOutputType,\n  ScannerCustomResourceProps,\n} from './types';\n\n/**\n * Enum for Severity Selection\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#severity-selection\n */\nexport enum Severity {\n  UNKNOWN = 'UNKNOWN',\n  LOW = 'LOW',\n  MEDIUM = 'MEDIUM',\n  HIGH = 'HIGH',\n  CRITICAL = 'CRITICAL',\n}\n\n/**\n * Enum for Scanners\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#enabledisable-scanners\n */\nexport enum Scanners {\n  VULN = 'vuln',\n  CONFIG = 'config',\n  SECRET = 'secret',\n  LICENSE = 'license',\n}\n\n/**\n * Enum for ImageConfigScanners\n *\n * @see https://aquasecurity.github.io/trivy/latest/docs/target/container_image/#container-image-metadata\n */\nexport enum ImageConfigScanners {\n  CONFIG = 'config',\n  SECRET = 'secret',\n}\n\n/**\n * Configuration for scan logs output to CloudWatch Logs log group.\n */\nexport interface CloudWatchLogsOutputProps {\n  /**\n   * The log group to output scan logs.\n   */\n  readonly logGroup: ILogGroup;\n}\n\n/**\n * Represents the output of the scan logs.\n */\nexport abstract class ScanLogsOutput {\n  /**\n   * Scan logs output to CloudWatch Logs log group.\n   */\n  public static cloudWatchLogs(options: CloudWatchLogsOutputProps): ScanLogsOutput {\n    return new CloudWatchLogsOutput(options);\n  }\n\n  /**\n   * Returns the output configuration for scan logs.\n   */\n  public abstract bind(grantee: IGrantable): ScanLogsOutputOptions;\n}\n\nclass CloudWatchLogsOutput extends ScanLogsOutput {\n  /**\n   * The log group to output scan logs.\n   */\n  private readonly logGroup: ILogGroup;\n\n  constructor(options: CloudWatchLogsOutputProps) {\n    super();\n\n    this.logGroup = options.logGroup;\n  }\n\n  public bind(grantee: IGrantable): CloudWatchLogsOutputOptions {\n    // Most Lambdas are granted AWSLambdaBasicExecutionRole and can write to any CloudWatch Logs.\n    // However, just in case AWSLambdaBasicExecutionRole is not granted, allow writing to CloudWatch Logs.\n    this.logGroup.grantWrite(grantee);\n\n    return {\n      type: ScanLogsOutputType.CLOUDWATCH_LOGS,\n      logGroupName: this.logGroup.logGroupName,\n    };\n  }\n}\n\nexport interface ImageScannerWithTrivyProps {\n  /**\n   * Image URI for scan target.\n   */\n  readonly imageUri: string;\n\n  /**\n   * Repository including the image URI for scan target.\n   *\n   * Because of grantPull to CustomResourceLambda.\n   */\n  readonly repository: IRepository;\n\n  /**\n   * The unfixed/unfixable vulnerabilities mean that the patch has not yet been provided on their distribution.\n   *\n   * To hide unfixed/unfixable vulnerabilities, you can use the `--ignore-unfixed` flag.\n   *\n   * @default false\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#unfixed-vulnerabilities\n   */\n  readonly ignoreUnfixed?: boolean;\n\n  /**\n   * Severity Selection\n   *\n   * The severity is taken from the selected data source since the severity from vendors is more accurate.\n   * Using CVE-2023-0464 as an example, while it is rated as \"HIGH\" in NVD, Red Hat has marked its 'Impact' as \"Low\". As a result, Trivy will display it as \"Low\".\n   *\n   * The severity depends on the compile option, the default configuration, etc. NVD doesn't know how the vendor distributes the software.\n   * Red Hat evaluates the severity more accurately. That's why Trivy prefers vendor scores over NVD.\n   *\n   * It defaults to `CRITICAL` IN THIS CONSTRUCT for safety in CI/CD, but the default configuration of Trivy is \"CRITICAL,HIGH,MEDIUM,LOW,UNKNOWN\".\n   *\n   * @default [Severity.CRITICAL]\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/scanner/vulnerability/#severity-selection\n   */\n  readonly severity?: Severity[];\n\n  /**\n   * Enable/Disable Scanners\n   *\n   * You can enable/disable scanners with the `scanners`.\n   *\n   * For example, container image scanning enables vulnerability (VULN) and secret scanners (SECRET) by default.\n   * If you don't need secret scanning, it can be disabled by specifying Scanners.VULN only.\n   *\n   * @default [Security.VULN,Scanners.SECRET]\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#enabledisable-scanners\n   */\n  readonly scanners?: Scanners[];\n\n  /**\n   * Enum for ImageConfigScanners\n   *\n   * Container images have configuration. docker inspect and `docker history` show the information according to the configuration.\n   * Trivy scans the configuration of container images for\n   *\n   * - Misconfigurations\n   * - Secrets\n   *\n   * They are disabled by default. You can enable them with `imageConfigScanners`.\n   *\n   * @default []\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/target/container_image/#container-image-metadata\n   */\n  readonly imageConfigScanners?: ImageConfigScanners[];\n\n  /**\n   * Exit Code\n   *\n   * Use the `exitCode` option if you want to exit with a non-zero exit code.\n   *\n   * You can specify 0 if you do not want to exit even when vulnerabilities are detected.\n   *\n   * It defaults to 1 IN THIS CONSTRUCT for safety in CI/CD. In the original trivy, it is 0.\n   *\n   * @default 1\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#exit-code\n   */\n  readonly exitCode?: number;\n\n  /**\n   * Exit on EOL\n   *\n   * Sometimes you may surprisingly get 0 vulnerabilities in an old image:\n   *  - Enabling --ignore-unfixed option while all packages have no fixed versions.\n   *  - Scanning a rather outdated OS (e.g. Ubuntu 10.04).\n   *\n   * An OS at the end of service/life (EOL) usually gets into this situation, which is definitely full of vulnerabilities.\n   * `exitOnEol` can fail scanning on EOL OS with a non-zero code.\n   *\n   * It defaults to 1 IN THIS CONSTRUCT for safety in CI/CD. In the original trivy, it is 0.\n   *\n   * @default 1\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/others/#exit-on-eol\n   */\n  readonly exitOnEol?: number;\n\n  /**\n   * By Finding IDs\n   *\n   * The ignore rules written to the .trivyignore in trivy.\n   * Put each line you write in the file into one element of the array.\n   *\n   * @example\n   *     $ cat .trivyignore\n   *     # Accept the risk\n   *     CVE-2018-14618\n   *\n   *     # Accept the risk until 2023-01-01\n   *     CVE-2019-14697 exp:2023-01-01\n   *\n   *     # No impact in our settings\n   *     CVE-2019-1543\n   *\n   *     # Ignore misconfigurations\n   *     AVD-DS-0002\n   *\n   *     # Ignore secrets\n   *     generic-unwanted-rule\n   *     aws-account-id\n   *\n   * @default []\n   *\n   * @see https://aquasecurity.github.io/trivy/latest/docs/configuration/filtering/#trivyignore\n   */\n  readonly trivyIgnore?: string[];\n\n  /**\n   * Memory Size (MB) for Scanner Lambda\n   *\n   * You can specify between `3008` and `10240`.\n   *\n   * If this Construct execution terminates abnormally due to SIGKILL, try a larger size.\n   *\n   * Default value (`3008` MB) is Maximum Lambda memory size for default AWS account without quota limit increase.\n   *\n   * @default 3008\n   */\n  readonly memorySize?: number;\n\n  /**\n   * Scan Image on a specific Architecture and OS\n   *\n   * By default, Trivy loads an image on a `linux/amd64` machine.\n   *\n   * To customize this, pass a `platform` argument in the format OS/Architecture for the image, such as `linux/arm64`\n   *\n   * @default -\n   */\n  readonly platform?: string;\n\n  /**\n   * The removal policy to apply to Scanner Lambda's default log group\n   *\n   * If you use ImageScannerWithTrivy construct multiple times in the same stack, you cannot set different removal policies for the default log group.\n   * See `Notes` section in the README for more details.\n   *\n   * @default - Scanner Lambda creates the default log group(`/aws/lambda/${functionName}`).\n   */\n  readonly defaultLogGroupRemovalPolicy?: RemovalPolicy;\n\n  /**\n   * The number of days log events are kept in Scanner Lambda's default log group\n   *\n   * If you use ImageScannerWithTrivy construct multiple times in the same stack, you cannot set different retention days for the default log group.\n   * See `Notes` section in the README for more details.\n   *\n   * @default - Scanner Lambda creates the default log group(`/aws/lambda/${functionName}`) and log events never expire.\n   */\n  readonly defaultLogGroupRetentionDays?: RetentionDays;\n\n  /**\n   * Configuration for scan logs output\n   *\n   * By default, scan logs are output to default log group created by Scanner Lambda.\n   *\n   * Specify this if you want to send scan logs to other than the default log group.\n   *\n   * Currently, only `cloudWatchLogs` is supported.\n   *\n   * @default - scan logs output to default log group created by Scanner Lambda(`/aws/lambda/${functionName}`)\n   */\n  readonly scanLogsOutput?: ScanLogsOutput;\n}\n\n// Maximum Lambda memory size for default AWS account without quota limit increase\nconst DEFAULT_MEMORY_SIZE = 3008;\n\nexport class ImageScannerWithTrivy extends Construct {\n  constructor(scope: Construct, id: string, props: ImageScannerWithTrivyProps) {\n    super(scope, id);\n\n    if (\n      props.memorySize &&\n      !Token.isUnresolved(props.memorySize) &&\n      (props.memorySize < 3008 || props.memorySize > 10240)\n    ) {\n      throw new Error(\n        `You can specify between \\`3008\\` and \\`10240\\` for \\`memorySize\\`, got ${props.memorySize}.`,\n      );\n    }\n\n    const lambdaPurpose = 'Custom::ImageScannerWithTrivyCustomResourceLambda';\n    const customResourceLambda = new SingletonFunction(this, 'CustomResourceLambda', {\n      uuid: '470b6343-d267-f753-226c-1e99f09f319a',\n      lambdaPurpose,\n      runtime: Runtime.FROM_IMAGE,\n      handler: Handler.FROM_IMAGE,\n      code: AssetCode.fromAssetImage(join(__dirname, '../assets/lambda'), {\n        platform: Platform.LINUX_ARM64,\n        // exclude node_modules\n        // because the native binary of the installed esbuild changes depending on the cpu architecture\n        // and the hash value of the image asset changes depending on the execution environment.\n        exclude: ['node_modules'],\n      }),\n      architecture: Architecture.ARM_64,\n      timeout: Duration.seconds(900),\n      retryAttempts: 0,\n      memorySize: props.memorySize ?? DEFAULT_MEMORY_SIZE,\n      ephemeralStorageSize: Size.gibibytes(10), // for cases that need to update trivy DB: /tmp/trivy/db/trivy.db\n    });\n    props.repository.grantPull(customResourceLambda);\n\n    const customResourceLambdaLogGroupConstructName = `DefaultLogGroupFor${lambdaPurpose}`;\n\n    this.validateLambdaDefaultLogGroupOptions(customResourceLambdaLogGroupConstructName, props);\n\n    if (props.defaultLogGroupRemovalPolicy || props.defaultLogGroupRetentionDays) {\n      this.ensureLambdaDefaultLogGroup(\n        customResourceLambda,\n        customResourceLambdaLogGroupConstructName,\n        props,\n      );\n    }\n\n    const imageScannerProvider = new Provider(this, 'Provider', {\n      onEventHandler: customResourceLambda,\n    });\n\n    const imageScannerProperties: ScannerCustomResourceProps = {\n      addr: this.node.addr,\n      imageUri: props.imageUri,\n      ignoreUnfixed: String(props.ignoreUnfixed ?? false),\n      severity: props.severity ?? [Severity.CRITICAL],\n      scanners: props.scanners ?? [],\n      imageConfigScanners: props.imageConfigScanners ?? [],\n      exitCode: props.exitCode ?? 1,\n      exitOnEol: props.exitOnEol ?? 1,\n      trivyIgnore: props.trivyIgnore ?? [],\n      platform: props.platform ?? '',\n      output: props.scanLogsOutput?.bind(customResourceLambda),\n    };\n\n    new CustomResource(this, 'Resource', {\n      resourceType: 'Custom::ImageScannerWithTrivy',\n      properties: imageScannerProperties,\n      serviceToken: imageScannerProvider.serviceToken,\n    });\n  }\n\n  /**\n   * Validates that specified default log group options are the same for existing default log group.\n   */\n  private validateLambdaDefaultLogGroupOptions(\n    logGroupConstructName: string,\n    props: ImageScannerWithTrivyProps,\n  ): void {\n    const existing = Stack.of(this).node.tryFindChild(logGroupConstructName) as\n      | LogGroup\n      | undefined;\n    if (!existing) return;\n\n    const cfnLogGroup = existing.node.defaultChild as CfnLogGroup;\n\n    if (\n      !this.isSameResourceDeletionBehavior(\n        props.defaultLogGroupRemovalPolicy,\n        cfnLogGroup.cfnOptions.deletionPolicy,\n      ) ||\n      cfnLogGroup.retentionInDays !== props.defaultLogGroupRetentionDays\n    ) {\n      Annotations.of(this).addWarningV2(\n        '@image-scanner-with-trivy:duplicateLambdaDefaultLogGroupOptions',\n        \"You have to set the same values for 'defaultLogGroupRemovalPolicy' and 'defaultLogGroupRetentionDays' for each ImageScannerWithTrivy construct in the same stack.\",\n      );\n    }\n  }\n\n  /**\n   * Creates the default log group for Scanner Lambda if it does not exist.\n   *\n   * This method checks if the default log group for Scanner Lambda exists in children of the stack construct.\n   * If it does not exist, it creates the default log group for Scanner Lambda as a child of the stack construct.\n   */\n  private ensureLambdaDefaultLogGroup(\n    singletonFunction: SingletonFunction,\n    logGroupConstructName: string,\n    props: ImageScannerWithTrivyProps,\n  ): LogGroup {\n    const existing = Stack.of(this).node.tryFindChild(logGroupConstructName) as\n      | LogGroup\n      | undefined;\n    if (existing) {\n      return existing;\n    }\n\n    return new LogGroup(Stack.of(this), logGroupConstructName, {\n      logGroupName: `/aws/lambda/${singletonFunction.functionName}`,\n      retention: props.defaultLogGroupRetentionDays,\n      removalPolicy: props.defaultLogGroupRemovalPolicy,\n    });\n  }\n\n  private isSameResourceDeletionBehavior(\n    removalPolicy?: RemovalPolicy,\n    deletionPolicy?: CfnDeletionPolicy,\n  ): boolean {\n    switch (removalPolicy) {\n      case RemovalPolicy.DESTROY:\n        return deletionPolicy === CfnDeletionPolicy.DELETE;\n      case RemovalPolicy.RETAIN:\n        return deletionPolicy === CfnDeletionPolicy.RETAIN;\n      case RemovalPolicy.SNAPSHOT:\n        return deletionPolicy === CfnDeletionPolicy.SNAPSHOT;\n      case RemovalPolicy.RETAIN_ON_UPDATE_OR_DELETE:\n        return deletionPolicy === CfnDeletionPolicy.RETAIN_EXCEPT_ON_CREATE;\n      case undefined:\n        return deletionPolicy === undefined;\n      default:\n        return removalPolicy satisfies never;\n    }\n  }\n}\n"]}
package/lib/types.js CHANGED
@@ -7,5 +7,5 @@ exports.ScanLogsOutputType = void 0;
7
7
  var ScanLogsOutputType;
8
8
  (function (ScanLogsOutputType) {
9
9
  ScanLogsOutputType["CLOUDWATCH_LOGS"] = "cloudWatchLogs";
10
- })(ScanLogsOutputType = exports.ScanLogsOutputType || (exports.ScanLogsOutputType = {}));
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxJQUFZLGtCQUVYO0FBRkQsV0FBWSxrQkFBa0I7SUFDNUIsd0RBQWtDLENBQUE7QUFDcEMsQ0FBQyxFQUZXLGtCQUFrQixHQUFsQiwwQkFBa0IsS0FBbEIsMEJBQWtCLFFBRTdCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFbnVtIGZvciBTY2FuTG9nc091dHB1dFR5cGVcbiAqL1xuZXhwb3J0IGVudW0gU2NhbkxvZ3NPdXRwdXRUeXBlIHtcbiAgQ0xPVURXQVRDSF9MT0dTID0gJ2Nsb3VkV2F0Y2hMb2dzJyxcbn1cblxuLyoqXG4gKiBPdXRwdXQgY29uZmlndXJhdGlvbnMgZm9yIHNjYW4gbG9ncy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTY2FuTG9nc091dHB1dE9wdGlvbnMge1xuICByZWFkb25seSB0eXBlOiBTY2FuTG9nc091dHB1dFR5cGU7XG59XG5cbi8qKlxuICogT3V0cHV0IGNvbmZpZ3VyYXRpb24gZm9yIHNjYW4gbG9ncyB0byBDbG91ZFdhdGNoIExvZ3MuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2xvdWRXYXRjaExvZ3NPdXRwdXRPcHRpb25zIGV4dGVuZHMgU2NhbkxvZ3NPdXRwdXRPcHRpb25zIHtcbiAgcmVhZG9ubHkgbG9nR3JvdXBOYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogTGFtYmRhIGZ1bmN0aW9uIGV2ZW50IG9iamVjdCBmb3IgU2Nhbm5lciBDdXN0b20gUmVzb3VyY2UuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2Nhbm5lckN1c3RvbVJlc291cmNlUHJvcHMge1xuICByZWFkb25seSBhZGRyOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGltYWdlVXJpOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlnbm9yZVVuZml4ZWQ6IHN0cmluZztcbiAgcmVhZG9ubHkgc2V2ZXJpdHk6IHN0cmluZ1tdO1xuICByZWFkb25seSBzY2FubmVyczogc3RyaW5nW107XG4gIHJlYWRvbmx5IGltYWdlQ29uZmlnU2Nhbm5lcnM6IHN0cmluZ1tdO1xuICByZWFkb25seSBleGl0Q29kZTogbnVtYmVyO1xuICByZWFkb25seSBleGl0T25Fb2w6IG51bWJlcjtcbiAgcmVhZG9ubHkgdHJpdnlJZ25vcmU6IHN0cmluZ1tdO1xuICByZWFkb25seSBwbGF0Zm9ybTogc3RyaW5nO1xuICByZWFkb25seSBvdXRwdXQ/OiBTY2FuTG9nc091dHB1dE9wdGlvbnM7XG59XG4iXX0=
10
+ })(ScanLogsOutputType || (exports.ScanLogsOutputType = ScanLogsOutputType = {}));
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxJQUFZLGtCQUVYO0FBRkQsV0FBWSxrQkFBa0I7SUFDNUIsd0RBQWtDLENBQUE7QUFDcEMsQ0FBQyxFQUZXLGtCQUFrQixrQ0FBbEIsa0JBQWtCLFFBRTdCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFbnVtIGZvciBTY2FuTG9nc091dHB1dFR5cGVcbiAqL1xuZXhwb3J0IGVudW0gU2NhbkxvZ3NPdXRwdXRUeXBlIHtcbiAgQ0xPVURXQVRDSF9MT0dTID0gJ2Nsb3VkV2F0Y2hMb2dzJyxcbn1cblxuLyoqXG4gKiBPdXRwdXQgY29uZmlndXJhdGlvbnMgZm9yIHNjYW4gbG9ncy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTY2FuTG9nc091dHB1dE9wdGlvbnMge1xuICByZWFkb25seSB0eXBlOiBTY2FuTG9nc091dHB1dFR5cGU7XG59XG5cbi8qKlxuICogT3V0cHV0IGNvbmZpZ3VyYXRpb24gZm9yIHNjYW4gbG9ncyB0byBDbG91ZFdhdGNoIExvZ3MuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2xvdWRXYXRjaExvZ3NPdXRwdXRPcHRpb25zIGV4dGVuZHMgU2NhbkxvZ3NPdXRwdXRPcHRpb25zIHtcbiAgcmVhZG9ubHkgbG9nR3JvdXBOYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogTGFtYmRhIGZ1bmN0aW9uIGV2ZW50IG9iamVjdCBmb3IgU2Nhbm5lciBDdXN0b20gUmVzb3VyY2UuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2Nhbm5lckN1c3RvbVJlc291cmNlUHJvcHMge1xuICByZWFkb25seSBhZGRyOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGltYWdlVXJpOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlnbm9yZVVuZml4ZWQ6IHN0cmluZztcbiAgcmVhZG9ubHkgc2V2ZXJpdHk6IHN0cmluZ1tdO1xuICByZWFkb25seSBzY2FubmVyczogc3RyaW5nW107XG4gIHJlYWRvbmx5IGltYWdlQ29uZmlnU2Nhbm5lcnM6IHN0cmluZ1tdO1xuICByZWFkb25seSBleGl0Q29kZTogbnVtYmVyO1xuICByZWFkb25seSBleGl0T25Fb2w6IG51bWJlcjtcbiAgcmVhZG9ubHkgdHJpdnlJZ25vcmU6IHN0cmluZ1tdO1xuICByZWFkb25seSBwbGF0Zm9ybTogc3RyaW5nO1xuICByZWFkb25seSBvdXRwdXQ/OiBTY2FuTG9nc091dHB1dE9wdGlvbnM7XG59XG4iXX0=
package/package.json CHANGED
@@ -37,35 +37,35 @@
37
37
  "organization": false
38
38
  },
39
39
  "devDependencies": {
40
- "@aws-cdk/integ-runner": "2.95.1-alpha.0",
41
- "@aws-cdk/integ-tests-alpha": "2.95.1-alpha.0",
42
- "@types/jest": "^29.5.13",
40
+ "@aws-cdk/integ-runner": "2.178.1-alpha.0",
41
+ "@aws-cdk/integ-tests-alpha": "2.178.1-alpha.0",
42
+ "@types/jest": "^29.5.14",
43
43
  "@types/node": "^18",
44
- "@typescript-eslint/eslint-plugin": "^7",
45
- "@typescript-eslint/parser": "^7",
46
- "aws-cdk-lib": "2.95.1",
44
+ "@typescript-eslint/eslint-plugin": "^8",
45
+ "@typescript-eslint/parser": "^8",
46
+ "aws-cdk-lib": "2.178.1",
47
47
  "commit-and-tag-version": "^12",
48
48
  "constructs": "10.0.5",
49
- "eslint": "^8",
49
+ "eslint": "^9",
50
50
  "eslint-config-prettier": "^9.1.0",
51
- "eslint-import-resolver-typescript": "^3.6.3",
51
+ "eslint-import-resolver-typescript": "^3.10.1",
52
52
  "eslint-plugin-import": "^2.31.0",
53
- "eslint-plugin-prettier": "^5.2.1",
53
+ "eslint-plugin-prettier": "^5.4.1",
54
54
  "jest": "^29.7.0",
55
- "jest-junit": "^15",
56
- "jsii": "~5.0.0",
57
- "jsii-diff": "^1.103.1",
55
+ "jest-junit": "^16",
56
+ "jsii": "~5.8.0",
57
+ "jsii-diff": "^1.112.0",
58
58
  "jsii-docgen": "^10.5.0",
59
- "jsii-pacmak": "^1.103.1",
60
- "jsii-rosetta": "~5.0.0",
61
- "prettier": "^3.3.3",
62
- "projen": "^0.88.0",
63
- "ts-jest": "^29.2.5",
59
+ "jsii-pacmak": "^1.112.0",
60
+ "jsii-rosetta": "~5.8.0",
61
+ "prettier": "^3.5.3",
62
+ "projen": "^0.92.10",
63
+ "ts-jest": "^29.4.0",
64
64
  "ts-node": "^10.9.2",
65
- "typescript": "^5.6.2"
65
+ "typescript": "^5.8.3"
66
66
  },
67
67
  "peerDependencies": {
68
- "aws-cdk-lib": "^2.95.1",
68
+ "aws-cdk-lib": "^2.178.1",
69
69
  "constructs": "^10.0.5"
70
70
  },
71
71
  "keywords": [
@@ -88,7 +88,7 @@
88
88
  "publishConfig": {
89
89
  "access": "public"
90
90
  },
91
- "version": "1.4.3",
91
+ "version": "2.0.0",
92
92
  "types": "lib/index.d.ts",
93
93
  "stability": "stable",
94
94
  "jsii": {