@stacksjs/ts-cloud-core 0.1.3 → 0.1.7
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/README.md +98 -13
- package/dist/advanced-features.test.d.ts +0 -0
- package/dist/aws/cloudformation.d.ts +69 -0
- package/dist/aws/cloudfront.d.ts +21 -0
- package/dist/aws/credentials.d.ts +66 -0
- package/dist/aws/credentials.test.d.ts +0 -0
- package/{src/aws/index.ts → dist/aws/index.d.ts} +37 -51
- package/dist/aws/s3.d.ts +130 -0
- package/dist/aws/s3.test.d.ts +0 -0
- package/dist/aws/signature.d.ts +101 -0
- package/dist/aws/signature.test.d.ts +0 -0
- package/dist/backup/disaster-recovery.d.ts +98 -0
- package/dist/backup/disaster-recovery.test.d.ts +0 -0
- package/{src/backup/index.ts → dist/backup/index.d.ts} +10 -20
- package/dist/backup/manager.d.ts +112 -0
- package/dist/backup/manager.test.d.ts +0 -0
- package/dist/cicd/circleci.d.ts +47 -0
- package/dist/cicd/github-actions.d.ts +55 -0
- package/dist/cicd/gitlab-ci.d.ts +46 -0
- package/dist/cicd/index.d.ts +3 -0
- package/dist/cli/history.d.ts +66 -0
- package/dist/cli/index.d.ts +5 -0
- package/dist/cli/progress.d.ts +97 -0
- package/dist/cli/repl.d.ts +76 -0
- package/dist/cli/suggestions.d.ts +67 -0
- package/dist/cli/table.d.ts +70 -0
- package/dist/cli/table.test.d.ts +0 -0
- package/dist/cloudformation/builder.d.ts +59 -0
- package/dist/cloudformation/builder.test.d.ts +0 -0
- package/dist/cloudformation/builders/api-gateway.d.ts +30 -0
- package/dist/cloudformation/builders/cache.d.ts +35 -0
- package/dist/cloudformation/builders/cdn.d.ts +34 -0
- package/dist/cloudformation/builders/compute.d.ts +66 -0
- package/dist/cloudformation/builders/database.d.ts +61 -0
- package/dist/cloudformation/builders/functions.d.ts +32 -0
- package/dist/cloudformation/builders/messaging.d.ts +17 -0
- package/dist/cloudformation/builders/monitoring.d.ts +36 -0
- package/dist/cloudformation/builders/network.d.ts +14 -0
- package/dist/cloudformation/builders/queue.d.ts +8 -0
- package/dist/cloudformation/builders/security.d.ts +31 -0
- package/dist/cloudformation/builders/storage.d.ts +8 -0
- package/dist/cloudformation/index.d.ts +24 -0
- package/dist/cloudformation/types.d.ts +132 -0
- package/dist/compliance/aws-config.d.ts +88 -0
- package/dist/compliance/cloudtrail.d.ts +96 -0
- package/dist/compliance/compliance.test.d.ts +0 -0
- package/dist/compliance/guardduty.d.ts +110 -0
- package/{src/compliance/index.ts → dist/compliance/index.d.ts} +20 -36
- package/dist/compliance/security-hub.d.ts +110 -0
- package/dist/containers/build-optimization.d.ts +110 -0
- package/dist/containers/containers.test.d.ts +0 -0
- package/dist/containers/image-scanning.d.ts +96 -0
- package/dist/containers/index.d.ts +4 -0
- package/dist/containers/registry.d.ts +99 -0
- package/dist/containers/service-mesh.d.ts +206 -0
- package/dist/database/database.test.d.ts +0 -0
- package/dist/database/index.d.ts +4 -0
- package/dist/database/migrations.d.ts +102 -0
- package/dist/database/performance.d.ts +168 -0
- package/dist/database/replicas.d.ts +146 -0
- package/dist/database/users.d.ts +102 -0
- package/dist/dependency-graph.d.ts +19 -0
- package/dist/deployment/ab-testing.d.ts +114 -0
- package/dist/deployment/blue-green.d.ts +98 -0
- package/dist/deployment/canary.d.ts +103 -0
- package/dist/deployment/deployment.test.d.ts +0 -0
- package/{src/deployment/index.ts → dist/deployment/index.d.ts} +20 -36
- package/dist/deployment/progressive.d.ts +34 -0
- package/dist/dns/dns.test.d.ts +0 -0
- package/dist/dns/dnssec.d.ts +75 -0
- package/dist/dns/index.d.ts +3 -0
- package/dist/dns/resolver.d.ts +150 -0
- package/dist/dns/routing.d.ts +217 -0
- package/dist/email/advanced/analytics.d.ts +78 -0
- package/dist/email/advanced/index.d.ts +7 -0
- package/dist/email/advanced/rules.d.ts +60 -0
- package/dist/email/advanced/scheduling.d.ts +63 -0
- package/dist/email/advanced/search.d.ts +76 -0
- package/dist/email/advanced/shared-mailboxes.d.ts +66 -0
- package/dist/email/advanced/templates.d.ts +39 -0
- package/dist/email/advanced/threading.d.ts +53 -0
- package/dist/email/analytics.d.ts +144 -0
- package/dist/email/bounce-handling.d.ts +120 -0
- package/dist/email/email.test.d.ts +0 -0
- package/dist/email/handlers/__tests__/inbound.test.d.ts +0 -0
- package/dist/email/handlers/__tests__/outbound.test.d.ts +0 -0
- package/{src/email/handlers/converter.ts → dist/email/handlers/converter.d.ts} +3 -5
- package/{src/email/handlers/feedback.ts → dist/email/handlers/feedback.d.ts} +3 -5
- package/{src/email/handlers/inbound.ts → dist/email/handlers/inbound.d.ts} +3 -5
- package/{src/email/handlers/outbound.ts → dist/email/handlers/outbound.d.ts} +3 -5
- package/dist/email/index.d.ts +6 -0
- package/dist/email/reputation.d.ts +97 -0
- package/dist/email/templates.d.ts +82 -0
- package/dist/errors/index.d.ts +186 -0
- package/dist/errors/index.test.d.ts +0 -0
- package/dist/health-checks/index.d.ts +35 -0
- package/dist/index.d.ts +256 -0
- package/dist/index.js +63499 -0
- package/dist/intrinsic-functions.d.ts +37 -0
- package/dist/lambda/concurrency.d.ts +98 -0
- package/dist/lambda/destinations.d.ts +99 -0
- package/dist/lambda/dlq.d.ts +109 -0
- package/dist/lambda/index.d.ts +6 -0
- package/dist/lambda/lambda.test.d.ts +0 -0
- package/dist/lambda/layers.d.ts +81 -0
- package/dist/lambda/versions.d.ts +91 -0
- package/dist/lambda/vpc.d.ts +116 -0
- package/dist/local/config.d.ts +44 -0
- package/dist/local/index.d.ts +2 -0
- package/dist/local/mock-aws.d.ts +60 -0
- package/dist/modules/ai.d.ts +47 -0
- package/dist/modules/api.d.ts +98 -0
- package/dist/modules/auth.d.ts +165 -0
- package/dist/modules/cache.d.ts +73 -0
- package/dist/modules/cdn.d.ts +125 -0
- package/dist/modules/communication.d.ts +98 -0
- package/dist/modules/compute.d.ts +309 -0
- package/dist/modules/database.d.ts +105 -0
- package/dist/modules/deployment.d.ts +181 -0
- package/dist/modules/dns.d.ts +45 -0
- package/dist/modules/email.d.ts +217 -0
- package/dist/modules/filesystem.d.ts +94 -0
- package/dist/modules/index.d.ts +27 -0
- package/dist/modules/messaging.d.ts +108 -0
- package/dist/modules/monitoring.d.ts +127 -0
- package/dist/modules/network.d.ts +102 -0
- package/dist/modules/parameter-store.d.ts +33 -0
- package/dist/modules/permissions.d.ts +132 -0
- package/dist/modules/phone.d.ts +80 -0
- package/dist/modules/queue.d.ts +210 -0
- package/dist/modules/redirects.d.ts +59 -0
- package/dist/modules/registry.d.ts +73 -0
- package/dist/modules/search.d.ts +56 -0
- package/dist/modules/secrets.d.ts +80 -0
- package/dist/modules/security.d.ts +100 -0
- package/dist/modules/sms.d.ts +52 -0
- package/dist/modules/storage.d.ts +160 -0
- package/dist/modules/workflow.d.ts +205 -0
- package/dist/multi-account/config.d.ts +315 -0
- package/dist/multi-account/index.d.ts +2 -0
- package/dist/multi-account/manager.d.ts +100 -0
- package/dist/multi-region/cross-region.d.ts +114 -0
- package/dist/multi-region/index.d.ts +3 -0
- package/dist/multi-region/manager.d.ts +72 -0
- package/dist/multi-region/regions.d.ts +98 -0
- package/dist/network-security/index.d.ts +39 -0
- package/dist/observability/index.d.ts +4 -0
- package/dist/observability/logs.d.ts +129 -0
- package/dist/observability/metrics.d.ts +153 -0
- package/dist/observability/observability.test.d.ts +0 -0
- package/dist/observability/synthetics.d.ts +146 -0
- package/dist/observability/xray.d.ts +129 -0
- package/dist/phone/advanced/analytics.d.ts +66 -0
- package/dist/phone/advanced/callbacks.d.ts +50 -0
- package/dist/phone/advanced/index.d.ts +4 -0
- package/dist/phone/advanced/ivr-builder.d.ts +83 -0
- package/dist/phone/advanced/recording.d.ts +48 -0
- package/dist/phone/handlers/__tests__/incoming-call.test.d.ts +0 -0
- package/{src/phone/handlers/incoming-call.ts → dist/phone/handlers/incoming-call.d.ts} +3 -5
- package/{src/phone/handlers/missed-call.ts → dist/phone/handlers/missed-call.d.ts} +3 -5
- package/{src/phone/handlers/voicemail.ts → dist/phone/handlers/voicemail.d.ts} +3 -5
- package/dist/phone/index.d.ts +2 -0
- package/dist/presets/api-backend.d.ts +11 -0
- package/dist/presets/data-pipeline.d.ts +11 -0
- package/{src/presets/extend.ts → dist/presets/extend.d.ts} +11 -114
- package/dist/presets/extend.test.d.ts +0 -0
- package/dist/presets/fullstack-app.d.ts +12 -0
- package/dist/presets/index.d.ts +24 -0
- package/dist/presets/jamstack.d.ts +12 -0
- package/dist/presets/microservices.d.ts +18 -0
- package/dist/presets/ml-api.d.ts +13 -0
- package/dist/presets/nodejs-server.d.ts +14 -0
- package/dist/presets/nodejs-serverless.d.ts +14 -0
- package/dist/presets/realtime-app.d.ts +11 -0
- package/dist/presets/static-site.d.ts +12 -0
- package/dist/presets/traditional-web-app.d.ts +16 -0
- package/dist/presets/wordpress.d.ts +12 -0
- package/dist/preview/github.d.ts +32 -0
- package/dist/preview/github.test.d.ts +0 -0
- package/{src/preview/index.ts → dist/preview/index.d.ts} +16 -26
- package/dist/preview/manager.d.ts +58 -0
- package/dist/preview/manager.test.d.ts +0 -0
- package/dist/preview/notifications.d.ts +55 -0
- package/dist/preview/notifications.test.d.ts +0 -0
- package/dist/queue/batch-processing.d.ts +87 -0
- package/dist/queue/dlq-monitoring.d.ts +95 -0
- package/dist/queue/fifo.d.ts +90 -0
- package/dist/queue/index.d.ts +4 -0
- package/dist/queue/management.d.ts +105 -0
- package/dist/queue/queue.test.d.ts +0 -0
- package/dist/resource-mgmt/index.d.ts +29 -0
- package/dist/resource-naming.d.ts +26 -0
- package/dist/s3/index.d.ts +173 -0
- package/dist/schema/index.d.ts +9 -0
- package/dist/security/certificate-manager.d.ts +121 -0
- package/dist/security/index.d.ts +4 -0
- package/dist/security/scanning.d.ts +147 -0
- package/dist/security/secrets-manager.d.ts +144 -0
- package/dist/security/secrets-rotation.d.ts +115 -0
- package/dist/security/security.test.d.ts +0 -0
- package/dist/sms/advanced/ab-testing.d.ts +54 -0
- package/dist/sms/advanced/analytics.d.ts +56 -0
- package/dist/sms/advanced/campaigns.d.ts +82 -0
- package/dist/sms/advanced/chatbot.d.ts +48 -0
- package/dist/sms/advanced/index.d.ts +6 -0
- package/dist/sms/advanced/link-tracking.d.ts +42 -0
- package/dist/sms/advanced/mms.d.ts +35 -0
- package/dist/sms/handlers/__tests__/send.test.d.ts +0 -0
- package/{src/sms/handlers/delivery-status.ts → dist/sms/handlers/delivery-status.d.ts} +3 -5
- package/{src/sms/handlers/receive.ts → dist/sms/handlers/receive.d.ts} +3 -5
- package/{src/sms/handlers/send.ts → dist/sms/handlers/send.d.ts} +3 -5
- package/dist/sms/index.d.ts +2 -0
- package/dist/stack-diff.d.ts +34 -0
- package/dist/static-site/index.d.ts +49 -0
- package/dist/template-builder.d.ts +14 -0
- package/dist/template-validator.d.ts +24 -0
- package/dist/utils/cache.d.ts +55 -0
- package/dist/utils/diff.d.ts +48 -0
- package/dist/utils/hash.d.ts +58 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/parallel.d.ts +60 -0
- package/dist/validators/credentials.d.ts +23 -0
- package/dist/validators/credentials.test.d.ts +0 -0
- package/dist/validators/quotas.d.ts +60 -0
- package/dist/validators/quotas.test.d.ts +0 -0
- package/package.json +13 -4
- package/src/advanced-features.test.ts +0 -465
- package/src/aws/cloudformation.ts +0 -421
- package/src/aws/cloudfront.ts +0 -158
- package/src/aws/credentials.test.ts +0 -132
- package/src/aws/credentials.ts +0 -545
- package/src/aws/s3.test.ts +0 -188
- package/src/aws/s3.ts +0 -1088
- package/src/aws/signature.test.ts +0 -670
- package/src/aws/signature.ts +0 -1155
- package/src/backup/disaster-recovery.test.ts +0 -726
- package/src/backup/disaster-recovery.ts +0 -500
- package/src/backup/manager.test.ts +0 -498
- package/src/backup/manager.ts +0 -432
- package/src/cicd/circleci.ts +0 -430
- package/src/cicd/github-actions.ts +0 -424
- package/src/cicd/gitlab-ci.ts +0 -255
- package/src/cicd/index.ts +0 -8
- package/src/cli/history.ts +0 -396
- package/src/cli/index.ts +0 -10
- package/src/cli/progress.ts +0 -458
- package/src/cli/repl.ts +0 -454
- package/src/cli/suggestions.ts +0 -327
- package/src/cli/table.test.ts +0 -319
- package/src/cli/table.ts +0 -332
- package/src/cloudformation/builder.test.ts +0 -327
- package/src/cloudformation/builder.ts +0 -378
- package/src/cloudformation/builders/api-gateway.ts +0 -449
- package/src/cloudformation/builders/cache.ts +0 -334
- package/src/cloudformation/builders/cdn.ts +0 -278
- package/src/cloudformation/builders/compute.ts +0 -485
- package/src/cloudformation/builders/database.ts +0 -392
- package/src/cloudformation/builders/functions.ts +0 -343
- package/src/cloudformation/builders/messaging.ts +0 -140
- package/src/cloudformation/builders/monitoring.ts +0 -300
- package/src/cloudformation/builders/network.ts +0 -264
- package/src/cloudformation/builders/queue.ts +0 -147
- package/src/cloudformation/builders/security.ts +0 -399
- package/src/cloudformation/builders/storage.ts +0 -285
- package/src/cloudformation/index.ts +0 -30
- package/src/cloudformation/types.ts +0 -173
- package/src/compliance/aws-config.ts +0 -543
- package/src/compliance/cloudtrail.ts +0 -376
- package/src/compliance/compliance.test.ts +0 -423
- package/src/compliance/guardduty.ts +0 -446
- package/src/compliance/security-hub.ts +0 -456
- package/src/containers/build-optimization.ts +0 -416
- package/src/containers/containers.test.ts +0 -508
- package/src/containers/image-scanning.ts +0 -360
- package/src/containers/index.ts +0 -9
- package/src/containers/registry.ts +0 -293
- package/src/containers/service-mesh.ts +0 -520
- package/src/database/database.test.ts +0 -762
- package/src/database/index.ts +0 -9
- package/src/database/migrations.ts +0 -444
- package/src/database/performance.ts +0 -528
- package/src/database/replicas.ts +0 -534
- package/src/database/users.ts +0 -494
- package/src/dependency-graph.ts +0 -143
- package/src/deployment/ab-testing.ts +0 -582
- package/src/deployment/blue-green.ts +0 -452
- package/src/deployment/canary.ts +0 -500
- package/src/deployment/deployment.test.ts +0 -526
- package/src/deployment/progressive.ts +0 -62
- package/src/dns/dns.test.ts +0 -641
- package/src/dns/dnssec.ts +0 -315
- package/src/dns/index.ts +0 -8
- package/src/dns/resolver.ts +0 -496
- package/src/dns/routing.ts +0 -593
- package/src/email/advanced/analytics.ts +0 -445
- package/src/email/advanced/index.ts +0 -11
- package/src/email/advanced/rules.ts +0 -465
- package/src/email/advanced/scheduling.ts +0 -352
- package/src/email/advanced/search.ts +0 -412
- package/src/email/advanced/shared-mailboxes.ts +0 -404
- package/src/email/advanced/templates.ts +0 -455
- package/src/email/advanced/threading.ts +0 -281
- package/src/email/analytics.ts +0 -467
- package/src/email/bounce-handling.ts +0 -425
- package/src/email/email.test.ts +0 -431
- package/src/email/handlers/__tests__/inbound.test.ts +0 -38
- package/src/email/handlers/__tests__/outbound.test.ts +0 -37
- package/src/email/index.ts +0 -15
- package/src/email/reputation.ts +0 -303
- package/src/email/templates.ts +0 -352
- package/src/errors/index.test.ts +0 -434
- package/src/errors/index.ts +0 -416
- package/src/health-checks/index.ts +0 -40
- package/src/index.ts +0 -360
- package/src/intrinsic-functions.ts +0 -118
- package/src/lambda/concurrency.ts +0 -330
- package/src/lambda/destinations.ts +0 -345
- package/src/lambda/dlq.ts +0 -425
- package/src/lambda/index.ts +0 -11
- package/src/lambda/lambda.test.ts +0 -840
- package/src/lambda/layers.ts +0 -263
- package/src/lambda/versions.ts +0 -376
- package/src/lambda/vpc.ts +0 -399
- package/src/local/config.ts +0 -114
- package/src/local/index.ts +0 -6
- package/src/local/mock-aws.ts +0 -351
- package/src/modules/ai.ts +0 -340
- package/src/modules/api.ts +0 -478
- package/src/modules/auth.ts +0 -805
- package/src/modules/cache.ts +0 -417
- package/src/modules/cdn.ts +0 -1062
- package/src/modules/communication.ts +0 -1094
- package/src/modules/compute.ts +0 -3348
- package/src/modules/database.ts +0 -554
- package/src/modules/deployment.ts +0 -1079
- package/src/modules/dns.ts +0 -337
- package/src/modules/email.ts +0 -1538
- package/src/modules/filesystem.ts +0 -515
- package/src/modules/index.ts +0 -32
- package/src/modules/messaging.ts +0 -486
- package/src/modules/monitoring.ts +0 -2086
- package/src/modules/network.ts +0 -664
- package/src/modules/parameter-store.ts +0 -325
- package/src/modules/permissions.ts +0 -1081
- package/src/modules/phone.ts +0 -494
- package/src/modules/queue.ts +0 -1260
- package/src/modules/redirects.ts +0 -464
- package/src/modules/registry.ts +0 -699
- package/src/modules/search.ts +0 -401
- package/src/modules/secrets.ts +0 -416
- package/src/modules/security.ts +0 -731
- package/src/modules/sms.ts +0 -389
- package/src/modules/storage.ts +0 -1120
- package/src/modules/workflow.ts +0 -680
- package/src/multi-account/config.ts +0 -521
- package/src/multi-account/index.ts +0 -7
- package/src/multi-account/manager.ts +0 -427
- package/src/multi-region/cross-region.ts +0 -410
- package/src/multi-region/index.ts +0 -8
- package/src/multi-region/manager.ts +0 -483
- package/src/multi-region/regions.ts +0 -435
- package/src/network-security/index.ts +0 -48
- package/src/observability/index.ts +0 -9
- package/src/observability/logs.ts +0 -522
- package/src/observability/metrics.ts +0 -460
- package/src/observability/observability.test.ts +0 -782
- package/src/observability/synthetics.ts +0 -568
- package/src/observability/xray.ts +0 -358
- package/src/phone/advanced/analytics.ts +0 -349
- package/src/phone/advanced/callbacks.ts +0 -428
- package/src/phone/advanced/index.ts +0 -8
- package/src/phone/advanced/ivr-builder.ts +0 -504
- package/src/phone/advanced/recording.ts +0 -310
- package/src/phone/handlers/__tests__/incoming-call.test.ts +0 -40
- package/src/phone/index.ts +0 -9
- package/src/presets/api-backend.ts +0 -134
- package/src/presets/data-pipeline.ts +0 -204
- package/src/presets/extend.test.ts +0 -295
- package/src/presets/fullstack-app.ts +0 -144
- package/src/presets/index.ts +0 -27
- package/src/presets/jamstack.ts +0 -135
- package/src/presets/microservices.ts +0 -167
- package/src/presets/ml-api.ts +0 -208
- package/src/presets/nodejs-server.ts +0 -104
- package/src/presets/nodejs-serverless.ts +0 -114
- package/src/presets/realtime-app.ts +0 -184
- package/src/presets/static-site.ts +0 -64
- package/src/presets/traditional-web-app.ts +0 -339
- package/src/presets/wordpress.ts +0 -138
- package/src/preview/github.test.ts +0 -249
- package/src/preview/github.ts +0 -297
- package/src/preview/manager.test.ts +0 -440
- package/src/preview/manager.ts +0 -326
- package/src/preview/notifications.test.ts +0 -582
- package/src/preview/notifications.ts +0 -341
- package/src/queue/batch-processing.ts +0 -402
- package/src/queue/dlq-monitoring.ts +0 -402
- package/src/queue/fifo.ts +0 -342
- package/src/queue/index.ts +0 -9
- package/src/queue/management.ts +0 -428
- package/src/queue/queue.test.ts +0 -429
- package/src/resource-mgmt/index.ts +0 -39
- package/src/resource-naming.ts +0 -62
- package/src/s3/index.ts +0 -523
- package/src/schema/cloud-config.schema.json +0 -554
- package/src/schema/index.ts +0 -68
- package/src/security/certificate-manager.ts +0 -492
- package/src/security/index.ts +0 -9
- package/src/security/scanning.ts +0 -545
- package/src/security/secrets-manager.ts +0 -476
- package/src/security/secrets-rotation.ts +0 -456
- package/src/security/security.test.ts +0 -738
- package/src/sms/advanced/ab-testing.ts +0 -389
- package/src/sms/advanced/analytics.ts +0 -336
- package/src/sms/advanced/campaigns.ts +0 -523
- package/src/sms/advanced/chatbot.ts +0 -224
- package/src/sms/advanced/index.ts +0 -10
- package/src/sms/advanced/link-tracking.ts +0 -248
- package/src/sms/advanced/mms.ts +0 -308
- package/src/sms/handlers/__tests__/send.test.ts +0 -40
- package/src/sms/index.ts +0 -9
- package/src/stack-diff.ts +0 -389
- package/src/static-site/index.ts +0 -85
- package/src/template-builder.ts +0 -110
- package/src/template-validator.ts +0 -574
- package/src/utils/cache.ts +0 -291
- package/src/utils/diff.ts +0 -269
- package/src/utils/hash.ts +0 -227
- package/src/utils/index.ts +0 -8
- package/src/utils/parallel.ts +0 -294
- package/src/validators/credentials.test.ts +0 -274
- package/src/validators/credentials.ts +0 -233
- package/src/validators/quotas.test.ts +0 -434
- package/src/validators/quotas.ts +0 -217
- package/test/ai.test.ts +0 -327
- package/test/api.test.ts +0 -511
- package/test/auth.test.ts +0 -632
- package/test/cache.test.ts +0 -406
- package/test/cdn.test.ts +0 -247
- package/test/compute.test.ts +0 -861
- package/test/database.test.ts +0 -523
- package/test/deployment.test.ts +0 -499
- package/test/dns.test.ts +0 -270
- package/test/email.test.ts +0 -439
- package/test/filesystem.test.ts +0 -382
- package/test/integration.test.ts +0 -350
- package/test/messaging.test.ts +0 -514
- package/test/monitoring.test.ts +0 -634
- package/test/network.test.ts +0 -425
- package/test/permissions.test.ts +0 -488
- package/test/queue.test.ts +0 -484
- package/test/registry.test.ts +0 -306
- package/test/security.test.ts +0 -462
- package/test/storage.test.ts +0 -463
- package/test/template-validator.test.ts +0 -559
- package/test/workflow.test.ts +0 -592
- package/tsconfig.json +0 -16
- package/tsconfig.tsbuildinfo +0 -1
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Helper functions for creating CloudFormation intrinsic functions
|
|
3
|
+
*/
|
|
4
|
+
export declare const Fn: {
|
|
5
|
+
ref: (logicalId: string) => unknown;
|
|
6
|
+
getAtt: (logicalId: string, attribute: string) => unknown;
|
|
7
|
+
join: (delimiter: string, values: any[]) => unknown;
|
|
8
|
+
sub: (template: string, variables?: Record<string, any>) => unknown;
|
|
9
|
+
select: (index: number, list: any[] | CloudFormationIntrinsicFunction) => unknown;
|
|
10
|
+
split: (delimiter: string, source: string) => unknown;
|
|
11
|
+
getAZs: (region: string?) => unknown;
|
|
12
|
+
importValue: (name: any) => unknown;
|
|
13
|
+
findInMap: (mapName: string, topLevelKey: any, secondLevelKey: any) => unknown;
|
|
14
|
+
base64: (value: any) => unknown;
|
|
15
|
+
cidr: (ipBlock: any, count: number, cidrBits: number) => unknown;
|
|
16
|
+
equals: (value1: any, value2: any) => unknown;
|
|
17
|
+
if: (conditionName: string, trueValue: any, falseValue: any) => unknown;
|
|
18
|
+
not: (condition: any) => unknown;
|
|
19
|
+
and: (...conditions: any[]) => unknown;
|
|
20
|
+
or: (...conditions: any[]) => unknown
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Common AWS resource ARN patterns
|
|
24
|
+
*/
|
|
25
|
+
export declare const Arn: {
|
|
26
|
+
s3Bucket: (bucketName: any) => unknown;
|
|
27
|
+
s3Object: (bucketName: any, key: string?) => unknown;
|
|
28
|
+
lambda: (functionName: string, region?: string, account?: string) => unknown;
|
|
29
|
+
dynamodb: (tableName: string) => unknown;
|
|
30
|
+
sqs: (queueName: string) => unknown;
|
|
31
|
+
sns: (topicName: string) => unknown;
|
|
32
|
+
kinesis: (streamName: string) => unknown;
|
|
33
|
+
iam: (resourceType: 'role' | 'policy' | 'user' | 'group', name: string) => unknown;
|
|
34
|
+
secretsManager: (secretName: string) => unknown;
|
|
35
|
+
cloudwatch: (logGroup: string) => unknown
|
|
36
|
+
};
|
|
37
|
+
/**
|
|
38
|
+
* Common CloudFormation pseudo parameters
|
|
39
|
+
*/
|
|
40
|
+
export declare const AWS_PSEUDO_PARAMETERS: {
|
|
41
|
+
ACCOUNT_ID: {
|
|
42
|
+
Ref: 'AWS::AccountId'
|
|
43
|
+
};
|
|
44
|
+
NOTIFICATION_ARNS: {
|
|
45
|
+
Ref: 'AWS::NotificationARNs'
|
|
46
|
+
};
|
|
47
|
+
NO_VALUE: {
|
|
48
|
+
Ref: 'AWS::NoValue'
|
|
49
|
+
};
|
|
50
|
+
PARTITION: {
|
|
51
|
+
Ref: 'AWS::Partition'
|
|
52
|
+
};
|
|
53
|
+
REGION: {
|
|
54
|
+
Ref: 'AWS::Region'
|
|
55
|
+
};
|
|
56
|
+
STACK_ID: {
|
|
57
|
+
Ref: 'AWS::StackId'
|
|
58
|
+
};
|
|
59
|
+
STACK_NAME: {
|
|
60
|
+
Ref: 'AWS::StackName'
|
|
61
|
+
};
|
|
62
|
+
URL_SUFFIX: {
|
|
63
|
+
Ref: 'AWS::URLSuffix'
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
/**
|
|
67
|
+
* CloudFormation Template Types
|
|
68
|
+
* Based on AWS CloudFormation Resource Specification
|
|
69
|
+
*/
|
|
70
|
+
export declare interface CloudFormationTemplate {
|
|
71
|
+
AWSTemplateFormatVersion: '2010-09-09'
|
|
72
|
+
Description?: string
|
|
73
|
+
Metadata?: Record<string, any>
|
|
74
|
+
Parameters?: Record<string, CloudFormationParameter>
|
|
75
|
+
Mappings?: Record<string, Record<string, Record<string, string>>>
|
|
76
|
+
Conditions?: Record<string, CloudFormationCondition>
|
|
77
|
+
Resources: Record<string, CloudFormationResource>
|
|
78
|
+
Outputs?: Record<string, CloudFormationOutput>
|
|
79
|
+
}
|
|
80
|
+
export declare interface CloudFormationParameter {
|
|
81
|
+
Type: 'String' | 'Number' | 'List<Number>' | 'CommaDelimitedList' | 'AWS::EC2::AvailabilityZone::Name' | 'AWS::EC2::Image::Id' | 'AWS::EC2::Instance::Id' | 'AWS::EC2::KeyPair::KeyName' | 'AWS::EC2::SecurityGroup::GroupName' | 'AWS::EC2::SecurityGroup::Id' | 'AWS::EC2::Subnet::Id' | 'AWS::EC2::Volume::Id' | 'AWS::EC2::VPC::Id' | 'AWS::Route53::HostedZone::Id' | 'List<AWS::EC2::AvailabilityZone::Name>' | 'List<AWS::EC2::Image::Id>' | 'List<AWS::EC2::Instance::Id>' | 'List<AWS::EC2::SecurityGroup::GroupName>' | 'List<AWS::EC2::SecurityGroup::Id>' | 'List<AWS::EC2::Subnet::Id>' | 'List<AWS::EC2::Volume::Id>' | 'List<AWS::EC2::VPC::Id>' | 'List<AWS::Route53::HostedZone::Id>'
|
|
82
|
+
Default?: string | number
|
|
83
|
+
Description?: string
|
|
84
|
+
AllowedValues?: string[]
|
|
85
|
+
AllowedPattern?: string
|
|
86
|
+
MinLength?: number
|
|
87
|
+
MaxLength?: number
|
|
88
|
+
MinValue?: number
|
|
89
|
+
MaxValue?: number
|
|
90
|
+
ConstraintDescription?: string
|
|
91
|
+
NoEcho?: boolean
|
|
92
|
+
}
|
|
93
|
+
export declare interface CloudFormationResource {
|
|
94
|
+
Type: string
|
|
95
|
+
Properties?: Record<string, any>
|
|
96
|
+
DependsOn?: string | string[]
|
|
97
|
+
Condition?: string
|
|
98
|
+
Metadata?: Record<string, any>
|
|
99
|
+
CreationPolicy?: Record<string, any>
|
|
100
|
+
UpdatePolicy?: Record<string, any>
|
|
101
|
+
DeletionPolicy?: 'Delete' | 'Retain' | 'Snapshot'
|
|
102
|
+
UpdateReplacePolicy?: 'Delete' | 'Retain' | 'Snapshot'
|
|
103
|
+
}
|
|
104
|
+
export declare interface CloudFormationOutput {
|
|
105
|
+
Value: any
|
|
106
|
+
Description?: string
|
|
107
|
+
Export?: {
|
|
108
|
+
Name: any
|
|
109
|
+
}
|
|
110
|
+
Condition?: string
|
|
111
|
+
}
|
|
112
|
+
export type CloudFormationCondition = | CloudFormationIntrinsicFunction
|
|
113
|
+
| boolean
|
|
114
|
+
/**
|
|
115
|
+
* CloudFormation Intrinsic Functions
|
|
116
|
+
*/
|
|
117
|
+
export type CloudFormationIntrinsicFunction = | { Ref: string }
|
|
118
|
+
| { 'Fn::GetAtt': [string, string] }
|
|
119
|
+
| { 'Fn::Join': [string, any[]] }
|
|
120
|
+
| { 'Fn::Sub': string | [string, Record<string, any>] }
|
|
121
|
+
| { 'Fn::Select': [number, any[] | CloudFormationIntrinsicFunction] }
|
|
122
|
+
| { 'Fn::Split': [string, string] }
|
|
123
|
+
| { 'Fn::GetAZs': string }
|
|
124
|
+
| { 'Fn::ImportValue': any }
|
|
125
|
+
| { 'Fn::FindInMap': [string, any, any] }
|
|
126
|
+
| { 'Fn::Base64': any }
|
|
127
|
+
| { 'Fn::Cidr': [any, number, number] }
|
|
128
|
+
| { 'Fn::Equals': [any, any] }
|
|
129
|
+
| { 'Fn::If': [string, any, any] }
|
|
130
|
+
| { 'Fn::Not': [any] }
|
|
131
|
+
| { 'Fn::And': any[] }
|
|
132
|
+
| { 'Fn::Or': any[] }
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global AWS Config manager instance
|
|
3
|
+
*/
|
|
4
|
+
export declare const awsConfigManager: AWSConfigManager;
|
|
5
|
+
/**
|
|
6
|
+
* AWS Config Rules
|
|
7
|
+
* Automated compliance checking and configuration management
|
|
8
|
+
*/
|
|
9
|
+
export declare interface ConfigRule {
|
|
10
|
+
id: string
|
|
11
|
+
name: string
|
|
12
|
+
description: string
|
|
13
|
+
source: 'AWS_MANAGED' | 'CUSTOM_LAMBDA'
|
|
14
|
+
identifier?: string
|
|
15
|
+
lambdaFunctionArn?: string
|
|
16
|
+
inputParameters?: Record<string, any>
|
|
17
|
+
scope?: ConfigScope
|
|
18
|
+
maxExecutionFrequency?: 'One_Hour' | 'Three_Hours' | 'Six_Hours' | 'Twelve_Hours' | 'TwentyFour_Hours'
|
|
19
|
+
}
|
|
20
|
+
export declare interface ConfigScope {
|
|
21
|
+
complianceResourceTypes?: string[]
|
|
22
|
+
tagKey?: string
|
|
23
|
+
tagValue?: string
|
|
24
|
+
}
|
|
25
|
+
export declare interface ConfigRecorder {
|
|
26
|
+
name: string
|
|
27
|
+
roleArn: string
|
|
28
|
+
recordingGroup?: RecordingGroup
|
|
29
|
+
}
|
|
30
|
+
export declare interface RecordingGroup {
|
|
31
|
+
allSupported?: boolean
|
|
32
|
+
includeGlobalResourceTypes?: boolean
|
|
33
|
+
resourceTypes?: string[]
|
|
34
|
+
}
|
|
35
|
+
export declare interface DeliveryChannel {
|
|
36
|
+
name: string
|
|
37
|
+
s3BucketName: string
|
|
38
|
+
s3KeyPrefix?: string
|
|
39
|
+
snsTopicArn?: string
|
|
40
|
+
configSnapshotDeliveryProperties?: {
|
|
41
|
+
deliveryFrequency?: 'One_Hour' | 'Three_Hours' | 'Six_Hours' | 'Twelve_Hours' | 'TwentyFour_Hours'
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* AWS Config manager
|
|
46
|
+
*/
|
|
47
|
+
export declare class AWSConfigManager {
|
|
48
|
+
private configRules: Map<string, ConfigRule>;
|
|
49
|
+
private configRecorders: Map<string, ConfigRecorder>;
|
|
50
|
+
private deliveryChannels: Map<string, DeliveryChannel>;
|
|
51
|
+
private ruleCounter: any;
|
|
52
|
+
createConfigRecorder(recorder: ConfigRecorder): ConfigRecorder;
|
|
53
|
+
createDeliveryChannel(channel: DeliveryChannel): DeliveryChannel;
|
|
54
|
+
createConfigRule(rule: Omit<ConfigRule, 'id'>): ConfigRule;
|
|
55
|
+
createS3EncryptionRule(): ConfigRule;
|
|
56
|
+
createS3PublicAccessBlockRule(): ConfigRule;
|
|
57
|
+
createS3VersioningRule(): ConfigRule;
|
|
58
|
+
createRdsEncryptionRule(): ConfigRule;
|
|
59
|
+
createRdsSnapshotEncryptionRule(): ConfigRule;
|
|
60
|
+
createRdsBackupRule(retentionPeriod?: number): ConfigRule;
|
|
61
|
+
createEc2InstanceProfileRule(): ConfigRule;
|
|
62
|
+
createEbsEncryptionRule(): ConfigRule;
|
|
63
|
+
createIamPasswordPolicyRule(): ConfigRule;
|
|
64
|
+
createIamMfaRule(): ConfigRule;
|
|
65
|
+
createRootAccountMfaRule(): ConfigRule;
|
|
66
|
+
createVpcFlowLogsRule(): ConfigRule;
|
|
67
|
+
createCloudTrailEnabledRule(): ConfigRule;
|
|
68
|
+
createCloudWatchAlarmRule(): ConfigRule;
|
|
69
|
+
createCustomLambdaRule(options: {
|
|
70
|
+
name: string
|
|
71
|
+
description: string
|
|
72
|
+
lambdaFunctionArn: string
|
|
73
|
+
resourceTypes?: string[]
|
|
74
|
+
maxExecutionFrequency?: ConfigRule['maxExecutionFrequency']
|
|
75
|
+
inputParameters?: Record<string, any>
|
|
76
|
+
}): ConfigRule;
|
|
77
|
+
createCompliancePreset(preset: 'hipaa' | 'pci-dss' | 'sox' | 'gdpr' | 'basic'): ConfigRule[];
|
|
78
|
+
getConfigRule(id: string): ConfigRule | undefined;
|
|
79
|
+
listConfigRules(): ConfigRule[];
|
|
80
|
+
getConfigRecorder(name: string): ConfigRecorder | undefined;
|
|
81
|
+
listConfigRecorders(): ConfigRecorder[];
|
|
82
|
+
getDeliveryChannel(name: string): DeliveryChannel | undefined;
|
|
83
|
+
listDeliveryChannels(): DeliveryChannel[];
|
|
84
|
+
generateConfigRuleCF(rule: ConfigRule): any;
|
|
85
|
+
generateConfigRecorderCF(recorder: ConfigRecorder): any;
|
|
86
|
+
generateDeliveryChannelCF(channel: DeliveryChannel): any;
|
|
87
|
+
clear(): void;
|
|
88
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global CloudTrail manager instance
|
|
3
|
+
*/
|
|
4
|
+
export declare const cloudTrailManager: CloudTrailManager;
|
|
5
|
+
/**
|
|
6
|
+
* AWS CloudTrail Configuration
|
|
7
|
+
* API logging and auditing for security and compliance
|
|
8
|
+
*/
|
|
9
|
+
export declare interface CloudTrailConfig {
|
|
10
|
+
id: string
|
|
11
|
+
name: string
|
|
12
|
+
s3BucketName: string
|
|
13
|
+
s3KeyPrefix?: string
|
|
14
|
+
includeGlobalServiceEvents?: boolean
|
|
15
|
+
isMultiRegionTrail?: boolean
|
|
16
|
+
enableLogFileValidation?: boolean
|
|
17
|
+
cloudWatchLogsLogGroupArn?: string
|
|
18
|
+
cloudWatchLogsRoleArn?: string
|
|
19
|
+
snsTopicName?: string
|
|
20
|
+
kmsKeyId?: string
|
|
21
|
+
eventSelectors?: EventSelector[]
|
|
22
|
+
insightSelectors?: InsightSelector[]
|
|
23
|
+
advancedEventSelectors?: AdvancedEventSelector[]
|
|
24
|
+
}
|
|
25
|
+
export declare interface EventSelector {
|
|
26
|
+
readWriteType: 'ReadOnly' | 'WriteOnly' | 'All'
|
|
27
|
+
includeManagementEvents?: boolean
|
|
28
|
+
dataResources?: DataResource[]
|
|
29
|
+
excludeManagementEventSources?: string[]
|
|
30
|
+
}
|
|
31
|
+
export declare interface DataResource {
|
|
32
|
+
type: string
|
|
33
|
+
values: string[]
|
|
34
|
+
}
|
|
35
|
+
export declare interface InsightSelector {
|
|
36
|
+
insightType: 'ApiCallRateInsight' | 'ApiErrorRateInsight'
|
|
37
|
+
}
|
|
38
|
+
export declare interface AdvancedEventSelector {
|
|
39
|
+
name: string
|
|
40
|
+
fieldSelectors: FieldSelector[]
|
|
41
|
+
}
|
|
42
|
+
export declare interface FieldSelector {
|
|
43
|
+
field: string
|
|
44
|
+
equals?: string[]
|
|
45
|
+
startsWith?: string[]
|
|
46
|
+
endsWith?: string[]
|
|
47
|
+
notEquals?: string[]
|
|
48
|
+
notStartsWith?: string[]
|
|
49
|
+
notEndsWith?: string[]
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* CloudTrail manager
|
|
53
|
+
*/
|
|
54
|
+
export declare class CloudTrailManager {
|
|
55
|
+
private trails: Map<string, CloudTrailConfig>;
|
|
56
|
+
private trailCounter: any;
|
|
57
|
+
createTrail(trail: Omit<CloudTrailConfig, 'id'>): CloudTrailConfig;
|
|
58
|
+
createOrganizationTrail(options: {
|
|
59
|
+
name: string
|
|
60
|
+
s3BucketName: string
|
|
61
|
+
kmsKeyId?: string
|
|
62
|
+
cloudWatchLogsLogGroupArn?: string
|
|
63
|
+
cloudWatchLogsRoleArn?: string
|
|
64
|
+
}): CloudTrailConfig;
|
|
65
|
+
createSecurityAuditTrail(options: {
|
|
66
|
+
name: string
|
|
67
|
+
s3BucketName: string
|
|
68
|
+
kmsKeyId: string
|
|
69
|
+
cloudWatchLogsLogGroupArn: string
|
|
70
|
+
cloudWatchLogsRoleArn: string
|
|
71
|
+
}): CloudTrailConfig;
|
|
72
|
+
createDataEventsTrail(options: {
|
|
73
|
+
name: string
|
|
74
|
+
s3BucketName: string
|
|
75
|
+
s3DataBuckets?: string[]
|
|
76
|
+
lambdaFunctions?: string[]
|
|
77
|
+
}): CloudTrailConfig;
|
|
78
|
+
createAdvancedTrail(options: {
|
|
79
|
+
name: string
|
|
80
|
+
s3BucketName: string
|
|
81
|
+
selectors: AdvancedEventSelector[]
|
|
82
|
+
}): CloudTrailConfig;
|
|
83
|
+
createReadOnlyTrail(options: {
|
|
84
|
+
name: string
|
|
85
|
+
s3BucketName: string
|
|
86
|
+
}): CloudTrailConfig;
|
|
87
|
+
createWriteOnlyTrail(options: {
|
|
88
|
+
name: string
|
|
89
|
+
s3BucketName: string
|
|
90
|
+
}): CloudTrailConfig;
|
|
91
|
+
getTrail(id: string): CloudTrailConfig | undefined;
|
|
92
|
+
listTrails(): CloudTrailConfig[];
|
|
93
|
+
generateTrailCF(trail: CloudTrailConfig): any;
|
|
94
|
+
generateBucketPolicy(bucketName: string, trailAccountIds: string[]): any;
|
|
95
|
+
clear(): void;
|
|
96
|
+
}
|
|
File without changes
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global GuardDuty manager instance
|
|
3
|
+
*/
|
|
4
|
+
export declare const guardDutyManager: GuardDutyManager;
|
|
5
|
+
/**
|
|
6
|
+
* AWS GuardDuty
|
|
7
|
+
* Intelligent threat detection and continuous monitoring
|
|
8
|
+
*/
|
|
9
|
+
export declare interface GuardDutyDetector {
|
|
10
|
+
id: string
|
|
11
|
+
enable: boolean
|
|
12
|
+
findingPublishingFrequency?: 'FIFTEEN_MINUTES' | 'ONE_HOUR' | 'SIX_HOURS'
|
|
13
|
+
dataSources?: DataSourceConfigurations
|
|
14
|
+
features?: DetectorFeature[]
|
|
15
|
+
}
|
|
16
|
+
export declare interface DataSourceConfigurations {
|
|
17
|
+
s3Logs?: {
|
|
18
|
+
enable: boolean
|
|
19
|
+
}
|
|
20
|
+
kubernetes?: {
|
|
21
|
+
auditLogs: {
|
|
22
|
+
enable: boolean
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
malwareProtection?: {
|
|
26
|
+
scanEc2InstanceWithFindings: {
|
|
27
|
+
ebsVolumes: {
|
|
28
|
+
enable: boolean
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
export declare interface DetectorFeature {
|
|
34
|
+
name: 'S3_DATA_EVENTS' | 'EKS_AUDIT_LOGS' | 'EBS_MALWARE_PROTECTION' | 'RDS_LOGIN_EVENTS' | 'LAMBDA_NETWORK_LOGS'
|
|
35
|
+
status: 'ENABLED' | 'DISABLED'
|
|
36
|
+
additionalConfiguration?: {
|
|
37
|
+
name: string
|
|
38
|
+
status: 'ENABLED' | 'DISABLED'
|
|
39
|
+
}[]
|
|
40
|
+
}
|
|
41
|
+
export declare interface ThreatIntelSet {
|
|
42
|
+
id: string
|
|
43
|
+
detectorId: string
|
|
44
|
+
name: string
|
|
45
|
+
format: 'TXT' | 'STIX' | 'OTX_CSV' | 'ALIEN_VAULT' | 'PROOF_POINT' | 'FIRE_EYE'
|
|
46
|
+
location: string
|
|
47
|
+
activate: boolean
|
|
48
|
+
}
|
|
49
|
+
export declare interface IPSet {
|
|
50
|
+
id: string
|
|
51
|
+
detectorId: string
|
|
52
|
+
name: string
|
|
53
|
+
format: 'TXT' | 'STIX' | 'OTX_CSV' | 'ALIEN_VAULT' | 'PROOF_POINT' | 'FIRE_EYE'
|
|
54
|
+
location: string
|
|
55
|
+
activate: boolean
|
|
56
|
+
}
|
|
57
|
+
export declare interface FindingFilter {
|
|
58
|
+
id: string
|
|
59
|
+
detectorId: string
|
|
60
|
+
name: string
|
|
61
|
+
description?: string
|
|
62
|
+
action: 'NOOP' | 'ARCHIVE'
|
|
63
|
+
rank: number
|
|
64
|
+
findingCriteria: FindingCriteria
|
|
65
|
+
}
|
|
66
|
+
export declare interface FindingCriteria {
|
|
67
|
+
criterion: Record<string, {
|
|
68
|
+
eq?: string[]
|
|
69
|
+
neq?: string[]
|
|
70
|
+
gt?: number
|
|
71
|
+
gte?: number
|
|
72
|
+
lt?: number
|
|
73
|
+
lte?: number
|
|
74
|
+
}>
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* GuardDuty manager
|
|
78
|
+
*/
|
|
79
|
+
export declare class GuardDutyManager {
|
|
80
|
+
private detectors: Map<string, GuardDutyDetector>;
|
|
81
|
+
private threatIntelSets: Map<string, ThreatIntelSet>;
|
|
82
|
+
private ipSets: Map<string, IPSet>;
|
|
83
|
+
private filters: Map<string, FindingFilter>;
|
|
84
|
+
private detectorCounter: any;
|
|
85
|
+
private threatIntelCounter: any;
|
|
86
|
+
private ipSetCounter: any;
|
|
87
|
+
private filterCounter: any;
|
|
88
|
+
createDetector(detector: Omit<GuardDutyDetector, 'id'>): GuardDutyDetector;
|
|
89
|
+
createComprehensiveDetector(): GuardDutyDetector;
|
|
90
|
+
createBasicDetector(): GuardDutyDetector;
|
|
91
|
+
createThreatIntelSet(set: Omit<ThreatIntelSet, 'id'>): ThreatIntelSet;
|
|
92
|
+
createIPSet(set: Omit<IPSet, 'id'>): IPSet;
|
|
93
|
+
createFindingFilter(filter: Omit<FindingFilter, 'id'>): FindingFilter;
|
|
94
|
+
createLowSeverityArchiveFilter(detectorId: string): FindingFilter;
|
|
95
|
+
createFindingTypeFilter(detectorId: string, findingTypes: string[], action: 'NOOP' | 'ARCHIVE'): FindingFilter;
|
|
96
|
+
createTrustedIPFilter(detectorId: string, ipAddresses: string[]): FindingFilter;
|
|
97
|
+
getDetector(id: string): GuardDutyDetector | undefined;
|
|
98
|
+
listDetectors(): GuardDutyDetector[];
|
|
99
|
+
getThreatIntelSet(id: string): ThreatIntelSet | undefined;
|
|
100
|
+
listThreatIntelSets(): ThreatIntelSet[];
|
|
101
|
+
getIPSet(id: string): IPSet | undefined;
|
|
102
|
+
listIPSets(): IPSet[];
|
|
103
|
+
getFindingFilter(id: string): FindingFilter | undefined;
|
|
104
|
+
listFindingFilters(): FindingFilter[];
|
|
105
|
+
generateDetectorCF(detector: GuardDutyDetector): any;
|
|
106
|
+
generateThreatIntelSetCF(set: ThreatIntelSet): any;
|
|
107
|
+
generateIPSetCF(set: IPSet): any;
|
|
108
|
+
generateFilterCF(filter: FindingFilter): any;
|
|
109
|
+
clear(): void;
|
|
110
|
+
}
|
|
@@ -1,28 +1,10 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Compliance & Governance
|
|
3
|
-
* AWS Config, CloudTrail, GuardDuty, and Security Hub integrations
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
// AWS Config
|
|
7
|
-
export {
|
|
8
|
-
AWSConfigManager,
|
|
9
|
-
awsConfigManager,
|
|
10
|
-
} from './aws-config'
|
|
11
|
-
|
|
12
1
|
export type {
|
|
13
2
|
ConfigRule,
|
|
14
3
|
ConfigScope,
|
|
15
4
|
ConfigRecorder,
|
|
16
5
|
RecordingGroup,
|
|
17
6
|
DeliveryChannel,
|
|
18
|
-
} from './aws-config'
|
|
19
|
-
|
|
20
|
-
// CloudTrail
|
|
21
|
-
export {
|
|
22
|
-
CloudTrailManager,
|
|
23
|
-
cloudTrailManager,
|
|
24
|
-
} from './cloudtrail'
|
|
25
|
-
|
|
7
|
+
} from './aws-config';
|
|
26
8
|
export type {
|
|
27
9
|
CloudTrailConfig,
|
|
28
10
|
EventSelector,
|
|
@@ -30,14 +12,7 @@ export type {
|
|
|
30
12
|
InsightSelector,
|
|
31
13
|
AdvancedEventSelector,
|
|
32
14
|
FieldSelector,
|
|
33
|
-
} from './cloudtrail'
|
|
34
|
-
|
|
35
|
-
// GuardDuty
|
|
36
|
-
export {
|
|
37
|
-
GuardDutyManager,
|
|
38
|
-
guardDutyManager,
|
|
39
|
-
} from './guardduty'
|
|
40
|
-
|
|
15
|
+
} from './cloudtrail';
|
|
41
16
|
export type {
|
|
42
17
|
GuardDutyDetector,
|
|
43
18
|
DataSourceConfigurations,
|
|
@@ -46,14 +21,7 @@ export type {
|
|
|
46
21
|
IPSet,
|
|
47
22
|
FindingFilter,
|
|
48
23
|
FindingCriteria,
|
|
49
|
-
} from './guardduty'
|
|
50
|
-
|
|
51
|
-
// Security Hub
|
|
52
|
-
export {
|
|
53
|
-
SecurityHubManager,
|
|
54
|
-
securityHubManager,
|
|
55
|
-
} from './security-hub'
|
|
56
|
-
|
|
24
|
+
} from './guardduty';
|
|
57
25
|
export type {
|
|
58
26
|
SecurityHubConfig,
|
|
59
27
|
SecurityStandard,
|
|
@@ -63,4 +31,20 @@ export type {
|
|
|
63
31
|
StringFilter,
|
|
64
32
|
NumberFilter,
|
|
65
33
|
MapFilter,
|
|
66
|
-
} from './security-hub'
|
|
34
|
+
} from './security-hub';
|
|
35
|
+
export {
|
|
36
|
+
AWSConfigManager,
|
|
37
|
+
awsConfigManager,
|
|
38
|
+
} from './aws-config';
|
|
39
|
+
export {
|
|
40
|
+
CloudTrailManager,
|
|
41
|
+
cloudTrailManager,
|
|
42
|
+
} from './cloudtrail';
|
|
43
|
+
export {
|
|
44
|
+
GuardDutyManager,
|
|
45
|
+
guardDutyManager,
|
|
46
|
+
} from './guardduty';
|
|
47
|
+
export {
|
|
48
|
+
SecurityHubManager,
|
|
49
|
+
securityHubManager,
|
|
50
|
+
} from './security-hub';
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global Security Hub manager instance
|
|
3
|
+
*/
|
|
4
|
+
export declare const securityHubManager: SecurityHubManager;
|
|
5
|
+
/**
|
|
6
|
+
* AWS Security Hub
|
|
7
|
+
* Centralized security and compliance view across AWS accounts
|
|
8
|
+
*/
|
|
9
|
+
export declare interface SecurityHubConfig {
|
|
10
|
+
id: string
|
|
11
|
+
enable: boolean
|
|
12
|
+
controlFindingGenerator?: 'STANDARD_CONTROL' | 'SECURITY_CONTROL'
|
|
13
|
+
enableDefaultStandards?: boolean
|
|
14
|
+
standards?: SecurityStandard[]
|
|
15
|
+
automationRules?: AutomationRule[]
|
|
16
|
+
}
|
|
17
|
+
export declare interface SecurityStandard {
|
|
18
|
+
id: string
|
|
19
|
+
arn: string
|
|
20
|
+
name: string
|
|
21
|
+
description: string
|
|
22
|
+
enabled: boolean
|
|
23
|
+
disabledControls?: string[]
|
|
24
|
+
}
|
|
25
|
+
export declare interface AutomationRule {
|
|
26
|
+
id: string
|
|
27
|
+
ruleName: string
|
|
28
|
+
description?: string
|
|
29
|
+
actions: AutomationAction[]
|
|
30
|
+
criteria: AutomationCriteria
|
|
31
|
+
ruleStatus: 'ENABLED' | 'DISABLED'
|
|
32
|
+
ruleOrder: number
|
|
33
|
+
}
|
|
34
|
+
export declare interface AutomationAction {
|
|
35
|
+
type: 'FINDING_FIELDS_UPDATE'
|
|
36
|
+
findingFieldsUpdate: {
|
|
37
|
+
note?: {
|
|
38
|
+
text: string
|
|
39
|
+
updatedBy: string
|
|
40
|
+
}
|
|
41
|
+
severity?: {
|
|
42
|
+
label: 'INFORMATIONAL' | 'LOW' | 'MEDIUM' | 'HIGH' | 'CRITICAL'
|
|
43
|
+
}
|
|
44
|
+
workflow?: {
|
|
45
|
+
status: 'NEW' | 'NOTIFIED' | 'RESOLVED' | 'SUPPRESSED'
|
|
46
|
+
}
|
|
47
|
+
relatedFindings?: Array<{
|
|
48
|
+
productArn: string
|
|
49
|
+
id: string
|
|
50
|
+
}>
|
|
51
|
+
userDefinedFields?: Record<string, string>
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
export declare interface AutomationCriteria {
|
|
55
|
+
productName?: StringFilter[]
|
|
56
|
+
companyName?: StringFilter[]
|
|
57
|
+
severityLabel?: StringFilter[]
|
|
58
|
+
resourceType?: StringFilter[]
|
|
59
|
+
resourceId?: StringFilter[]
|
|
60
|
+
recordState?: StringFilter[]
|
|
61
|
+
workflowStatus?: StringFilter[]
|
|
62
|
+
complianceStatus?: StringFilter[]
|
|
63
|
+
verificationState?: StringFilter[]
|
|
64
|
+
confidence?: NumberFilter[]
|
|
65
|
+
criticality?: NumberFilter[]
|
|
66
|
+
title?: StringFilter[]
|
|
67
|
+
description?: StringFilter[]
|
|
68
|
+
sourceUrl?: StringFilter[]
|
|
69
|
+
productFields?: MapFilter[]
|
|
70
|
+
resourceTags?: MapFilter[]
|
|
71
|
+
userDefinedFields?: MapFilter[]
|
|
72
|
+
}
|
|
73
|
+
export declare interface StringFilter {
|
|
74
|
+
value: string
|
|
75
|
+
comparison: 'EQUALS' | 'PREFIX' | 'NOT_EQUALS' | 'PREFIX_NOT_EQUALS'
|
|
76
|
+
}
|
|
77
|
+
export declare interface NumberFilter {
|
|
78
|
+
gte?: number
|
|
79
|
+
lte?: number
|
|
80
|
+
eq?: number
|
|
81
|
+
gt?: number
|
|
82
|
+
lt?: number
|
|
83
|
+
}
|
|
84
|
+
export declare interface MapFilter {
|
|
85
|
+
key: string
|
|
86
|
+
value?: string
|
|
87
|
+
comparison: 'EQUALS' | 'NOT_EQUALS'
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Security Hub manager
|
|
91
|
+
*/
|
|
92
|
+
export declare class SecurityHubManager {
|
|
93
|
+
private hubs: Map<string, SecurityHubConfig>;
|
|
94
|
+
private hubCounter: any;
|
|
95
|
+
private ruleCounter: any;
|
|
96
|
+
static readonly Standards: any;
|
|
97
|
+
createHub(hub: Omit<SecurityHubConfig, 'id'>): SecurityHubConfig;
|
|
98
|
+
createComprehensiveHub(): SecurityHubConfig;
|
|
99
|
+
createBasicHub(): SecurityHubConfig;
|
|
100
|
+
createLowSeveritySuppressionRule(): AutomationRule;
|
|
101
|
+
createResourceTypeNotificationRule(resourceTypes: string[]): AutomationRule;
|
|
102
|
+
createComplianceFailureRule(): AutomationRule;
|
|
103
|
+
createFalsePositiveSuppressionRule(productName: string, titlePatterns: string[]): AutomationRule;
|
|
104
|
+
getHub(id: string): SecurityHubConfig | undefined;
|
|
105
|
+
listHubs(): SecurityHubConfig[];
|
|
106
|
+
generateHubCF(hub: SecurityHubConfig): any;
|
|
107
|
+
generateStandardCF(standard: SecurityStandard): any;
|
|
108
|
+
generateAutomationRuleCF(rule: AutomationRule): any;
|
|
109
|
+
clear(): void;
|
|
110
|
+
}
|