@stacksjs/ts-cloud-core 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (251) hide show
  1. package/LICENSE.md +21 -0
  2. package/README.md +321 -0
  3. package/package.json +31 -0
  4. package/src/advanced-features.test.ts +465 -0
  5. package/src/aws/cloudformation.ts +421 -0
  6. package/src/aws/cloudfront.ts +158 -0
  7. package/src/aws/credentials.test.ts +132 -0
  8. package/src/aws/credentials.ts +545 -0
  9. package/src/aws/index.ts +87 -0
  10. package/src/aws/s3.test.ts +188 -0
  11. package/src/aws/s3.ts +1088 -0
  12. package/src/aws/signature.test.ts +670 -0
  13. package/src/aws/signature.ts +1155 -0
  14. package/src/backup/disaster-recovery.test.ts +726 -0
  15. package/src/backup/disaster-recovery.ts +500 -0
  16. package/src/backup/index.ts +34 -0
  17. package/src/backup/manager.test.ts +498 -0
  18. package/src/backup/manager.ts +432 -0
  19. package/src/cicd/circleci.ts +430 -0
  20. package/src/cicd/github-actions.ts +424 -0
  21. package/src/cicd/gitlab-ci.ts +255 -0
  22. package/src/cicd/index.ts +8 -0
  23. package/src/cli/history.ts +396 -0
  24. package/src/cli/index.ts +10 -0
  25. package/src/cli/progress.ts +458 -0
  26. package/src/cli/repl.ts +454 -0
  27. package/src/cli/suggestions.ts +327 -0
  28. package/src/cli/table.test.ts +319 -0
  29. package/src/cli/table.ts +332 -0
  30. package/src/cloudformation/builder.test.ts +327 -0
  31. package/src/cloudformation/builder.ts +378 -0
  32. package/src/cloudformation/builders/api-gateway.ts +449 -0
  33. package/src/cloudformation/builders/cache.ts +334 -0
  34. package/src/cloudformation/builders/cdn.ts +278 -0
  35. package/src/cloudformation/builders/compute.ts +485 -0
  36. package/src/cloudformation/builders/database.ts +392 -0
  37. package/src/cloudformation/builders/functions.ts +343 -0
  38. package/src/cloudformation/builders/messaging.ts +140 -0
  39. package/src/cloudformation/builders/monitoring.ts +300 -0
  40. package/src/cloudformation/builders/network.ts +264 -0
  41. package/src/cloudformation/builders/queue.ts +147 -0
  42. package/src/cloudformation/builders/security.ts +399 -0
  43. package/src/cloudformation/builders/storage.ts +285 -0
  44. package/src/cloudformation/index.ts +30 -0
  45. package/src/cloudformation/types.ts +173 -0
  46. package/src/compliance/aws-config.ts +543 -0
  47. package/src/compliance/cloudtrail.ts +376 -0
  48. package/src/compliance/compliance.test.ts +423 -0
  49. package/src/compliance/guardduty.ts +446 -0
  50. package/src/compliance/index.ts +66 -0
  51. package/src/compliance/security-hub.ts +456 -0
  52. package/src/containers/build-optimization.ts +416 -0
  53. package/src/containers/containers.test.ts +508 -0
  54. package/src/containers/image-scanning.ts +360 -0
  55. package/src/containers/index.ts +9 -0
  56. package/src/containers/registry.ts +293 -0
  57. package/src/containers/service-mesh.ts +520 -0
  58. package/src/database/database.test.ts +762 -0
  59. package/src/database/index.ts +9 -0
  60. package/src/database/migrations.ts +444 -0
  61. package/src/database/performance.ts +528 -0
  62. package/src/database/replicas.ts +534 -0
  63. package/src/database/users.ts +494 -0
  64. package/src/dependency-graph.ts +143 -0
  65. package/src/deployment/ab-testing.ts +582 -0
  66. package/src/deployment/blue-green.ts +452 -0
  67. package/src/deployment/canary.ts +500 -0
  68. package/src/deployment/deployment.test.ts +526 -0
  69. package/src/deployment/index.ts +61 -0
  70. package/src/deployment/progressive.ts +62 -0
  71. package/src/dns/dns.test.ts +641 -0
  72. package/src/dns/dnssec.ts +315 -0
  73. package/src/dns/index.ts +8 -0
  74. package/src/dns/resolver.ts +496 -0
  75. package/src/dns/routing.ts +593 -0
  76. package/src/email/advanced/analytics.ts +445 -0
  77. package/src/email/advanced/index.ts +11 -0
  78. package/src/email/advanced/rules.ts +465 -0
  79. package/src/email/advanced/scheduling.ts +352 -0
  80. package/src/email/advanced/search.ts +412 -0
  81. package/src/email/advanced/shared-mailboxes.ts +404 -0
  82. package/src/email/advanced/templates.ts +455 -0
  83. package/src/email/advanced/threading.ts +281 -0
  84. package/src/email/analytics.ts +467 -0
  85. package/src/email/bounce-handling.ts +425 -0
  86. package/src/email/email.test.ts +431 -0
  87. package/src/email/handlers/__tests__/inbound.test.ts +38 -0
  88. package/src/email/handlers/__tests__/outbound.test.ts +37 -0
  89. package/src/email/handlers/converter.ts +227 -0
  90. package/src/email/handlers/feedback.ts +228 -0
  91. package/src/email/handlers/inbound.ts +169 -0
  92. package/src/email/handlers/outbound.ts +178 -0
  93. package/src/email/index.ts +15 -0
  94. package/src/email/reputation.ts +303 -0
  95. package/src/email/templates.ts +352 -0
  96. package/src/errors/index.test.ts +434 -0
  97. package/src/errors/index.ts +416 -0
  98. package/src/health-checks/index.ts +40 -0
  99. package/src/index.ts +360 -0
  100. package/src/intrinsic-functions.ts +118 -0
  101. package/src/lambda/concurrency.ts +330 -0
  102. package/src/lambda/destinations.ts +345 -0
  103. package/src/lambda/dlq.ts +425 -0
  104. package/src/lambda/index.ts +11 -0
  105. package/src/lambda/lambda.test.ts +840 -0
  106. package/src/lambda/layers.ts +263 -0
  107. package/src/lambda/versions.ts +376 -0
  108. package/src/lambda/vpc.ts +399 -0
  109. package/src/local/config.ts +114 -0
  110. package/src/local/index.ts +6 -0
  111. package/src/local/mock-aws.ts +351 -0
  112. package/src/modules/ai.ts +340 -0
  113. package/src/modules/api.ts +478 -0
  114. package/src/modules/auth.ts +805 -0
  115. package/src/modules/cache.ts +417 -0
  116. package/src/modules/cdn.ts +1062 -0
  117. package/src/modules/communication.ts +1094 -0
  118. package/src/modules/compute.ts +3348 -0
  119. package/src/modules/database.ts +554 -0
  120. package/src/modules/deployment.ts +1079 -0
  121. package/src/modules/dns.ts +337 -0
  122. package/src/modules/email.ts +1538 -0
  123. package/src/modules/filesystem.ts +515 -0
  124. package/src/modules/index.ts +32 -0
  125. package/src/modules/messaging.ts +486 -0
  126. package/src/modules/monitoring.ts +2086 -0
  127. package/src/modules/network.ts +664 -0
  128. package/src/modules/parameter-store.ts +325 -0
  129. package/src/modules/permissions.ts +1081 -0
  130. package/src/modules/phone.ts +494 -0
  131. package/src/modules/queue.ts +1260 -0
  132. package/src/modules/redirects.ts +464 -0
  133. package/src/modules/registry.ts +699 -0
  134. package/src/modules/search.ts +401 -0
  135. package/src/modules/secrets.ts +416 -0
  136. package/src/modules/security.ts +731 -0
  137. package/src/modules/sms.ts +389 -0
  138. package/src/modules/storage.ts +1120 -0
  139. package/src/modules/workflow.ts +680 -0
  140. package/src/multi-account/config.ts +521 -0
  141. package/src/multi-account/index.ts +7 -0
  142. package/src/multi-account/manager.ts +427 -0
  143. package/src/multi-region/cross-region.ts +410 -0
  144. package/src/multi-region/index.ts +8 -0
  145. package/src/multi-region/manager.ts +483 -0
  146. package/src/multi-region/regions.ts +435 -0
  147. package/src/network-security/index.ts +48 -0
  148. package/src/observability/index.ts +9 -0
  149. package/src/observability/logs.ts +522 -0
  150. package/src/observability/metrics.ts +460 -0
  151. package/src/observability/observability.test.ts +782 -0
  152. package/src/observability/synthetics.ts +568 -0
  153. package/src/observability/xray.ts +358 -0
  154. package/src/phone/advanced/analytics.ts +349 -0
  155. package/src/phone/advanced/callbacks.ts +428 -0
  156. package/src/phone/advanced/index.ts +8 -0
  157. package/src/phone/advanced/ivr-builder.ts +504 -0
  158. package/src/phone/advanced/recording.ts +310 -0
  159. package/src/phone/handlers/__tests__/incoming-call.test.ts +40 -0
  160. package/src/phone/handlers/incoming-call.ts +117 -0
  161. package/src/phone/handlers/missed-call.ts +116 -0
  162. package/src/phone/handlers/voicemail.ts +179 -0
  163. package/src/phone/index.ts +9 -0
  164. package/src/presets/api-backend.ts +134 -0
  165. package/src/presets/data-pipeline.ts +204 -0
  166. package/src/presets/extend.test.ts +295 -0
  167. package/src/presets/extend.ts +297 -0
  168. package/src/presets/fullstack-app.ts +144 -0
  169. package/src/presets/index.ts +27 -0
  170. package/src/presets/jamstack.ts +135 -0
  171. package/src/presets/microservices.ts +167 -0
  172. package/src/presets/ml-api.ts +208 -0
  173. package/src/presets/nodejs-server.ts +104 -0
  174. package/src/presets/nodejs-serverless.ts +114 -0
  175. package/src/presets/realtime-app.ts +184 -0
  176. package/src/presets/static-site.ts +64 -0
  177. package/src/presets/traditional-web-app.ts +339 -0
  178. package/src/presets/wordpress.ts +138 -0
  179. package/src/preview/github.test.ts +249 -0
  180. package/src/preview/github.ts +297 -0
  181. package/src/preview/index.ts +37 -0
  182. package/src/preview/manager.test.ts +440 -0
  183. package/src/preview/manager.ts +326 -0
  184. package/src/preview/notifications.test.ts +582 -0
  185. package/src/preview/notifications.ts +341 -0
  186. package/src/queue/batch-processing.ts +402 -0
  187. package/src/queue/dlq-monitoring.ts +402 -0
  188. package/src/queue/fifo.ts +342 -0
  189. package/src/queue/index.ts +9 -0
  190. package/src/queue/management.ts +428 -0
  191. package/src/queue/queue.test.ts +429 -0
  192. package/src/resource-mgmt/index.ts +39 -0
  193. package/src/resource-naming.ts +62 -0
  194. package/src/s3/index.ts +523 -0
  195. package/src/schema/cloud-config.schema.json +554 -0
  196. package/src/schema/index.ts +68 -0
  197. package/src/security/certificate-manager.ts +492 -0
  198. package/src/security/index.ts +9 -0
  199. package/src/security/scanning.ts +545 -0
  200. package/src/security/secrets-manager.ts +476 -0
  201. package/src/security/secrets-rotation.ts +456 -0
  202. package/src/security/security.test.ts +738 -0
  203. package/src/sms/advanced/ab-testing.ts +389 -0
  204. package/src/sms/advanced/analytics.ts +336 -0
  205. package/src/sms/advanced/campaigns.ts +523 -0
  206. package/src/sms/advanced/chatbot.ts +224 -0
  207. package/src/sms/advanced/index.ts +10 -0
  208. package/src/sms/advanced/link-tracking.ts +248 -0
  209. package/src/sms/advanced/mms.ts +308 -0
  210. package/src/sms/handlers/__tests__/send.test.ts +40 -0
  211. package/src/sms/handlers/delivery-status.ts +133 -0
  212. package/src/sms/handlers/receive.ts +162 -0
  213. package/src/sms/handlers/send.ts +174 -0
  214. package/src/sms/index.ts +9 -0
  215. package/src/stack-diff.ts +389 -0
  216. package/src/static-site/index.ts +85 -0
  217. package/src/template-builder.ts +110 -0
  218. package/src/template-validator.ts +574 -0
  219. package/src/utils/cache.ts +291 -0
  220. package/src/utils/diff.ts +269 -0
  221. package/src/utils/hash.ts +227 -0
  222. package/src/utils/index.ts +8 -0
  223. package/src/utils/parallel.ts +294 -0
  224. package/src/validators/credentials.test.ts +274 -0
  225. package/src/validators/credentials.ts +233 -0
  226. package/src/validators/quotas.test.ts +434 -0
  227. package/src/validators/quotas.ts +217 -0
  228. package/test/ai.test.ts +327 -0
  229. package/test/api.test.ts +511 -0
  230. package/test/auth.test.ts +632 -0
  231. package/test/cache.test.ts +406 -0
  232. package/test/cdn.test.ts +247 -0
  233. package/test/compute.test.ts +861 -0
  234. package/test/database.test.ts +523 -0
  235. package/test/deployment.test.ts +499 -0
  236. package/test/dns.test.ts +270 -0
  237. package/test/email.test.ts +439 -0
  238. package/test/filesystem.test.ts +382 -0
  239. package/test/integration.test.ts +350 -0
  240. package/test/messaging.test.ts +514 -0
  241. package/test/monitoring.test.ts +634 -0
  242. package/test/network.test.ts +425 -0
  243. package/test/permissions.test.ts +488 -0
  244. package/test/queue.test.ts +484 -0
  245. package/test/registry.test.ts +306 -0
  246. package/test/security.test.ts +462 -0
  247. package/test/storage.test.ts +463 -0
  248. package/test/template-validator.test.ts +559 -0
  249. package/test/workflow.test.ts +592 -0
  250. package/tsconfig.json +16 -0
  251. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,330 @@
1
+ /**
2
+ * Lambda Concurrency Management
3
+ * Reserved and provisioned concurrency configuration
4
+ */
5
+
6
+ export interface ConcurrencyConfig {
7
+ id: string
8
+ functionName: string
9
+ reservedConcurrency?: number
10
+ provisionedConcurrency?: ProvisionedConcurrencyConfig[]
11
+ }
12
+
13
+ export interface ProvisionedConcurrencyConfig {
14
+ id: string
15
+ functionName: string
16
+ qualifier: string // version or alias
17
+ provisionedConcurrentExecutions: number
18
+ status: 'pending' | 'ready' | 'in_progress' | 'failed'
19
+ allocatedConcurrency?: number
20
+ availableConcurrency?: number
21
+ lastModified?: Date
22
+ }
23
+
24
+ export interface ConcurrencySchedule {
25
+ id: string
26
+ name: string
27
+ functionName: string
28
+ qualifier: string
29
+ schedule: ScheduleRule[]
30
+ }
31
+
32
+ export interface ScheduleRule {
33
+ name: string
34
+ cronExpression: string
35
+ targetConcurrency: number
36
+ minCapacity?: number
37
+ maxCapacity?: number
38
+ }
39
+
40
+ export interface AutoScalingConfig {
41
+ id: string
42
+ functionName: string
43
+ qualifier: string
44
+ minCapacity: number
45
+ maxCapacity: number
46
+ targetUtilization: number // 0-1
47
+ scaleInCooldown?: number // seconds
48
+ scaleOutCooldown?: number // seconds
49
+ }
50
+
51
+ /**
52
+ * Lambda concurrency manager
53
+ */
54
+ export class LambdaConcurrencyManager {
55
+ private configs: Map<string, ConcurrencyConfig> = new Map()
56
+ private provisionedConfigs: Map<string, ProvisionedConcurrencyConfig> = new Map()
57
+ private schedules: Map<string, ConcurrencySchedule> = new Map()
58
+ private autoScalingConfigs: Map<string, AutoScalingConfig> = new Map()
59
+ private configCounter = 0
60
+ private provisionedCounter = 0
61
+ private scheduleCounter = 0
62
+ private autoScalingCounter = 0
63
+
64
+ /**
65
+ * Set reserved concurrency
66
+ */
67
+ setReservedConcurrency(options: {
68
+ functionName: string
69
+ reservedConcurrency: number
70
+ }): ConcurrencyConfig {
71
+ const id = `concurrency-${Date.now()}-${this.configCounter++}`
72
+
73
+ const config: ConcurrencyConfig = {
74
+ id,
75
+ functionName: options.functionName,
76
+ reservedConcurrency: options.reservedConcurrency,
77
+ }
78
+
79
+ this.configs.set(id, config)
80
+
81
+ return config
82
+ }
83
+
84
+ /**
85
+ * Set provisioned concurrency
86
+ */
87
+ setProvisionedConcurrency(options: {
88
+ functionName: string
89
+ qualifier: string
90
+ provisionedConcurrentExecutions: number
91
+ }): ProvisionedConcurrencyConfig {
92
+ const id = `provisioned-${Date.now()}-${this.provisionedCounter++}`
93
+
94
+ const config: ProvisionedConcurrencyConfig = {
95
+ id,
96
+ functionName: options.functionName,
97
+ qualifier: options.qualifier,
98
+ provisionedConcurrentExecutions: options.provisionedConcurrentExecutions,
99
+ status: 'pending',
100
+ lastModified: new Date(),
101
+ }
102
+
103
+ this.provisionedConfigs.set(id, config)
104
+
105
+ // Simulate provisioning
106
+ setTimeout(() => {
107
+ config.status = 'ready'
108
+ config.allocatedConcurrency = options.provisionedConcurrentExecutions
109
+ config.availableConcurrency = options.provisionedConcurrentExecutions
110
+ }, 100)
111
+
112
+ return config
113
+ }
114
+
115
+ /**
116
+ * Configure warm pool
117
+ */
118
+ configureWarmPool(options: {
119
+ functionName: string
120
+ alias: string
121
+ minInstances: number
122
+ }): ProvisionedConcurrencyConfig {
123
+ return this.setProvisionedConcurrency({
124
+ functionName: options.functionName,
125
+ qualifier: options.alias,
126
+ provisionedConcurrentExecutions: options.minInstances,
127
+ })
128
+ }
129
+
130
+ /**
131
+ * Create concurrency schedule
132
+ */
133
+ createSchedule(schedule: Omit<ConcurrencySchedule, 'id'>): ConcurrencySchedule {
134
+ const id = `schedule-${Date.now()}-${this.scheduleCounter++}`
135
+
136
+ const concurrencySchedule: ConcurrencySchedule = {
137
+ id,
138
+ ...schedule,
139
+ }
140
+
141
+ this.schedules.set(id, concurrencySchedule)
142
+
143
+ return concurrencySchedule
144
+ }
145
+
146
+ /**
147
+ * Create business hours schedule
148
+ */
149
+ createBusinessHoursSchedule(options: {
150
+ functionName: string
151
+ qualifier: string
152
+ businessHoursConcurrency: number
153
+ offHoursConcurrency: number
154
+ }): ConcurrencySchedule {
155
+ return this.createSchedule({
156
+ name: `${options.functionName}-business-hours`,
157
+ functionName: options.functionName,
158
+ qualifier: options.qualifier,
159
+ schedule: [
160
+ {
161
+ name: 'business-hours',
162
+ cronExpression: '0 8 * * MON-FRI', // 8 AM weekdays
163
+ targetConcurrency: options.businessHoursConcurrency,
164
+ },
165
+ {
166
+ name: 'off-hours',
167
+ cronExpression: '0 18 * * MON-FRI', // 6 PM weekdays
168
+ targetConcurrency: options.offHoursConcurrency,
169
+ },
170
+ {
171
+ name: 'weekend',
172
+ cronExpression: '0 0 * * SAT', // Midnight Saturday
173
+ targetConcurrency: options.offHoursConcurrency,
174
+ },
175
+ ],
176
+ })
177
+ }
178
+
179
+ /**
180
+ * Configure auto-scaling
181
+ */
182
+ configureAutoScaling(config: Omit<AutoScalingConfig, 'id'>): AutoScalingConfig {
183
+ const id = `autoscaling-${Date.now()}-${this.autoScalingCounter++}`
184
+
185
+ const autoScalingConfig: AutoScalingConfig = {
186
+ id,
187
+ ...config,
188
+ }
189
+
190
+ this.autoScalingConfigs.set(id, autoScalingConfig)
191
+
192
+ return autoScalingConfig
193
+ }
194
+
195
+ /**
196
+ * Configure predictive auto-scaling
197
+ */
198
+ configurePredictiveScaling(options: {
199
+ functionName: string
200
+ qualifier: string
201
+ baselineCapacity: number
202
+ peakCapacity: number
203
+ }): AutoScalingConfig {
204
+ return this.configureAutoScaling({
205
+ functionName: options.functionName,
206
+ qualifier: options.qualifier,
207
+ minCapacity: options.baselineCapacity,
208
+ maxCapacity: options.peakCapacity,
209
+ targetUtilization: 0.7,
210
+ scaleInCooldown: 300,
211
+ scaleOutCooldown: 60,
212
+ })
213
+ }
214
+
215
+ /**
216
+ * Get concurrency config
217
+ */
218
+ getConfig(id: string): ConcurrencyConfig | undefined {
219
+ return this.configs.get(id)
220
+ }
221
+
222
+ /**
223
+ * List concurrency configs
224
+ */
225
+ listConfigs(): ConcurrencyConfig[] {
226
+ return Array.from(this.configs.values())
227
+ }
228
+
229
+ /**
230
+ * Get provisioned config
231
+ */
232
+ getProvisionedConfig(id: string): ProvisionedConcurrencyConfig | undefined {
233
+ return this.provisionedConfigs.get(id)
234
+ }
235
+
236
+ /**
237
+ * List provisioned configs
238
+ */
239
+ listProvisionedConfigs(): ProvisionedConcurrencyConfig[] {
240
+ return Array.from(this.provisionedConfigs.values())
241
+ }
242
+
243
+ /**
244
+ * Generate CloudFormation for reserved concurrency
245
+ */
246
+ generateReservedConcurrencyCF(config: ConcurrencyConfig): any {
247
+ return {
248
+ Type: 'AWS::Lambda::Function',
249
+ Properties: {
250
+ FunctionName: config.functionName,
251
+ ReservedConcurrentExecutions: config.reservedConcurrency,
252
+ },
253
+ }
254
+ }
255
+
256
+ /**
257
+ * Generate CloudFormation for provisioned concurrency
258
+ */
259
+ generateProvisionedConcurrencyCF(config: ProvisionedConcurrencyConfig): any {
260
+ return {
261
+ Type: 'AWS::Lambda::Alias',
262
+ Properties: {
263
+ FunctionName: config.functionName,
264
+ Name: config.qualifier,
265
+ ProvisionedConcurrencyConfig: {
266
+ ProvisionedConcurrentExecutions: config.provisionedConcurrentExecutions,
267
+ },
268
+ },
269
+ }
270
+ }
271
+
272
+ /**
273
+ * Generate CloudFormation for auto-scaling target
274
+ */
275
+ generateAutoScalingTargetCF(config: AutoScalingConfig): any {
276
+ return {
277
+ Type: 'AWS::ApplicationAutoScaling::ScalableTarget',
278
+ Properties: {
279
+ ServiceNamespace: 'lambda',
280
+ ResourceId: `function:${config.functionName}:${config.qualifier}`,
281
+ ScalableDimension: 'lambda:function:ProvisionedConcurrentExecutions',
282
+ MinCapacity: config.minCapacity,
283
+ MaxCapacity: config.maxCapacity,
284
+ },
285
+ }
286
+ }
287
+
288
+ /**
289
+ * Generate CloudFormation for auto-scaling policy
290
+ */
291
+ generateAutoScalingPolicyCF(config: AutoScalingConfig): any {
292
+ return {
293
+ Type: 'AWS::ApplicationAutoScaling::ScalingPolicy',
294
+ Properties: {
295
+ PolicyName: `${config.functionName}-autoscaling`,
296
+ PolicyType: 'TargetTrackingScaling',
297
+ ScalingTargetId: {
298
+ Ref: `${config.functionName}AutoScalingTarget`,
299
+ },
300
+ TargetTrackingScalingPolicyConfiguration: {
301
+ TargetValue: config.targetUtilization * 100,
302
+ PredefinedMetricSpecification: {
303
+ PredefinedMetricType: 'LambdaProvisionedConcurrencyUtilization',
304
+ },
305
+ ScaleInCooldown: config.scaleInCooldown || 300,
306
+ ScaleOutCooldown: config.scaleOutCooldown || 60,
307
+ },
308
+ },
309
+ }
310
+ }
311
+
312
+ /**
313
+ * Clear all data
314
+ */
315
+ clear(): void {
316
+ this.configs.clear()
317
+ this.provisionedConfigs.clear()
318
+ this.schedules.clear()
319
+ this.autoScalingConfigs.clear()
320
+ this.configCounter = 0
321
+ this.provisionedCounter = 0
322
+ this.scheduleCounter = 0
323
+ this.autoScalingCounter = 0
324
+ }
325
+ }
326
+
327
+ /**
328
+ * Global Lambda concurrency manager instance
329
+ */
330
+ export const lambdaConcurrencyManager: LambdaConcurrencyManager = new LambdaConcurrencyManager()
@@ -0,0 +1,345 @@
1
+ /**
2
+ * Lambda Destinations
3
+ * Asynchronous invocation destinations for success and failure
4
+ */
5
+
6
+ export interface LambdaDestination {
7
+ id: string
8
+ functionName: string
9
+ qualifier?: string
10
+ successDestination?: DestinationConfig
11
+ failureDestination?: DestinationConfig
12
+ maxEventAge?: number // seconds
13
+ maxRetries?: number
14
+ }
15
+
16
+ export interface DestinationConfig {
17
+ type: 'sqs' | 'sns' | 'eventbridge' | 'lambda'
18
+ arn: string
19
+ }
20
+
21
+ export interface DestinationRecord {
22
+ id: string
23
+ timestamp: Date
24
+ functionName: string
25
+ requestId: string
26
+ status: 'success' | 'failure'
27
+ destinationType: 'sqs' | 'sns' | 'eventbridge' | 'lambda'
28
+ destinationArn: string
29
+ payload?: any
30
+ error?: string
31
+ }
32
+
33
+ export interface EventBridgeDestination {
34
+ id: string
35
+ functionName: string
36
+ eventBusArn: string
37
+ detailType: string
38
+ source: string
39
+ }
40
+
41
+ /**
42
+ * Lambda destinations manager
43
+ */
44
+ export class LambdaDestinationsManager {
45
+ private destinations: Map<string, LambdaDestination> = new Map()
46
+ private records: Map<string, DestinationRecord> = new Map()
47
+ private eventBridgeDestinations: Map<string, EventBridgeDestination> = new Map()
48
+ private destinationCounter = 0
49
+ private recordCounter = 0
50
+ private eventBridgeCounter = 0
51
+
52
+ /**
53
+ * Configure destinations
54
+ */
55
+ configureDestinations(destination: Omit<LambdaDestination, 'id'>): LambdaDestination {
56
+ const id = `destination-${Date.now()}-${this.destinationCounter++}`
57
+
58
+ const lambdaDestination: LambdaDestination = {
59
+ id,
60
+ ...destination,
61
+ }
62
+
63
+ this.destinations.set(id, lambdaDestination)
64
+
65
+ return lambdaDestination
66
+ }
67
+
68
+ /**
69
+ * Configure SQS destination
70
+ */
71
+ configureSQSDestination(options: {
72
+ functionName: string
73
+ queueArn: string
74
+ onSuccess?: boolean
75
+ onFailure?: boolean
76
+ }): LambdaDestination {
77
+ const destinationConfig: DestinationConfig = {
78
+ type: 'sqs',
79
+ arn: options.queueArn,
80
+ }
81
+
82
+ return this.configureDestinations({
83
+ functionName: options.functionName,
84
+ successDestination: options.onSuccess ? destinationConfig : undefined,
85
+ failureDestination: options.onFailure ? destinationConfig : undefined,
86
+ maxEventAge: 21600, // 6 hours
87
+ maxRetries: 2,
88
+ })
89
+ }
90
+
91
+ /**
92
+ * Configure SNS destination
93
+ */
94
+ configureSNSDestination(options: {
95
+ functionName: string
96
+ topicArn: string
97
+ onSuccess?: boolean
98
+ onFailure?: boolean
99
+ }): LambdaDestination {
100
+ const destinationConfig: DestinationConfig = {
101
+ type: 'sns',
102
+ arn: options.topicArn,
103
+ }
104
+
105
+ return this.configureDestinations({
106
+ functionName: options.functionName,
107
+ successDestination: options.onSuccess ? destinationConfig : undefined,
108
+ failureDestination: options.onFailure ? destinationConfig : undefined,
109
+ maxEventAge: 21600,
110
+ maxRetries: 2,
111
+ })
112
+ }
113
+
114
+ /**
115
+ * Configure EventBridge destination
116
+ */
117
+ configureEventBridgeDestination(options: {
118
+ functionName: string
119
+ eventBusArn: string
120
+ onSuccess?: boolean
121
+ onFailure?: boolean
122
+ }): LambdaDestination {
123
+ const destinationConfig: DestinationConfig = {
124
+ type: 'eventbridge',
125
+ arn: options.eventBusArn,
126
+ }
127
+
128
+ return this.configureDestinations({
129
+ functionName: options.functionName,
130
+ successDestination: options.onSuccess ? destinationConfig : undefined,
131
+ failureDestination: options.onFailure ? destinationConfig : undefined,
132
+ maxEventAge: 21600,
133
+ maxRetries: 2,
134
+ })
135
+ }
136
+
137
+ /**
138
+ * Configure Lambda destination
139
+ */
140
+ configureLambdaDestination(options: {
141
+ functionName: string
142
+ destinationFunctionArn: string
143
+ onSuccess?: boolean
144
+ onFailure?: boolean
145
+ }): LambdaDestination {
146
+ const destinationConfig: DestinationConfig = {
147
+ type: 'lambda',
148
+ arn: options.destinationFunctionArn,
149
+ }
150
+
151
+ return this.configureDestinations({
152
+ functionName: options.functionName,
153
+ successDestination: options.onSuccess ? destinationConfig : undefined,
154
+ failureDestination: options.onFailure ? destinationConfig : undefined,
155
+ maxEventAge: 21600,
156
+ maxRetries: 2,
157
+ })
158
+ }
159
+
160
+ /**
161
+ * Configure DLQ with SNS destination
162
+ */
163
+ configureDLQWithNotification(options: {
164
+ functionName: string
165
+ dlqArn: string
166
+ notificationTopicArn: string
167
+ }): LambdaDestination {
168
+ return this.configureDestinations({
169
+ functionName: options.functionName,
170
+ failureDestination: {
171
+ type: 'sqs',
172
+ arn: options.dlqArn,
173
+ },
174
+ maxEventAge: 3600, // 1 hour for DLQ
175
+ maxRetries: 0, // No retries, go straight to DLQ
176
+ })
177
+ }
178
+
179
+ /**
180
+ * Create EventBridge integration
181
+ */
182
+ createEventBridgeIntegration(options: {
183
+ functionName: string
184
+ eventBusArn: string
185
+ detailType?: string
186
+ source?: string
187
+ }): EventBridgeDestination {
188
+ const id = `eventbridge-${Date.now()}-${this.eventBridgeCounter++}`
189
+
190
+ const destination: EventBridgeDestination = {
191
+ id,
192
+ functionName: options.functionName,
193
+ eventBusArn: options.eventBusArn,
194
+ detailType: options.detailType || 'Lambda Function Invocation Result',
195
+ source: options.source || `lambda.${options.functionName}`,
196
+ }
197
+
198
+ this.eventBridgeDestinations.set(id, destination)
199
+
200
+ return destination
201
+ }
202
+
203
+ /**
204
+ * Simulate sending to destination
205
+ */
206
+ sendToDestination(options: {
207
+ functionName: string
208
+ requestId: string
209
+ status: 'success' | 'failure'
210
+ payload?: any
211
+ error?: string
212
+ }): DestinationRecord | null {
213
+ // Find destination config
214
+ const destination = Array.from(this.destinations.values()).find(
215
+ d => d.functionName === options.functionName
216
+ )
217
+
218
+ if (!destination) {
219
+ return null
220
+ }
221
+
222
+ const destinationConfig =
223
+ options.status === 'success'
224
+ ? destination.successDestination
225
+ : destination.failureDestination
226
+
227
+ if (!destinationConfig) {
228
+ return null
229
+ }
230
+
231
+ const id = `record-${Date.now()}-${this.recordCounter++}`
232
+
233
+ const record: DestinationRecord = {
234
+ id,
235
+ timestamp: new Date(),
236
+ functionName: options.functionName,
237
+ requestId: options.requestId,
238
+ status: options.status,
239
+ destinationType: destinationConfig.type,
240
+ destinationArn: destinationConfig.arn,
241
+ payload: options.payload,
242
+ error: options.error,
243
+ }
244
+
245
+ this.records.set(id, record)
246
+
247
+ return record
248
+ }
249
+
250
+ /**
251
+ * Get destination
252
+ */
253
+ getDestination(id: string): LambdaDestination | undefined {
254
+ return this.destinations.get(id)
255
+ }
256
+
257
+ /**
258
+ * List destinations
259
+ */
260
+ listDestinations(functionName?: string): LambdaDestination[] {
261
+ const destinations = Array.from(this.destinations.values())
262
+ return functionName
263
+ ? destinations.filter(d => d.functionName === functionName)
264
+ : destinations
265
+ }
266
+
267
+ /**
268
+ * Get destination records
269
+ */
270
+ getDestinationRecords(functionName?: string): DestinationRecord[] {
271
+ const records = Array.from(this.records.values())
272
+ return functionName
273
+ ? records.filter(r => r.functionName === functionName)
274
+ : records
275
+ }
276
+
277
+ /**
278
+ * Generate CloudFormation for EventSourceMapping with destination
279
+ */
280
+ generateEventInvokeConfigCF(destination: LambdaDestination): any {
281
+ return {
282
+ Type: 'AWS::Lambda::EventInvokeConfig',
283
+ Properties: {
284
+ FunctionName: destination.functionName,
285
+ Qualifier: destination.qualifier || '$LATEST',
286
+ MaximumEventAgeInSeconds: destination.maxEventAge || 21600,
287
+ MaximumRetryAttempts: destination.maxRetries ?? 2,
288
+ ...(destination.successDestination && {
289
+ DestinationConfig: {
290
+ OnSuccess: {
291
+ Destination: destination.successDestination.arn,
292
+ },
293
+ },
294
+ }),
295
+ ...(destination.failureDestination && {
296
+ DestinationConfig: {
297
+ OnFailure: {
298
+ Destination: destination.failureDestination.arn,
299
+ },
300
+ },
301
+ }),
302
+ },
303
+ }
304
+ }
305
+
306
+ /**
307
+ * Generate CloudFormation for EventBridge rule
308
+ */
309
+ generateEventBridgeRuleCF(destination: EventBridgeDestination): any {
310
+ return {
311
+ Type: 'AWS::Events::Rule',
312
+ Properties: {
313
+ EventBusName: destination.eventBusArn.split('/').pop(),
314
+ EventPattern: {
315
+ source: [destination.source],
316
+ 'detail-type': [destination.detailType],
317
+ },
318
+ State: 'ENABLED',
319
+ Targets: [
320
+ {
321
+ Arn: `arn:aws:lambda:us-east-1:123456789012:function:${destination.functionName}`,
322
+ Id: destination.id,
323
+ },
324
+ ],
325
+ },
326
+ }
327
+ }
328
+
329
+ /**
330
+ * Clear all data
331
+ */
332
+ clear(): void {
333
+ this.destinations.clear()
334
+ this.records.clear()
335
+ this.eventBridgeDestinations.clear()
336
+ this.destinationCounter = 0
337
+ this.recordCounter = 0
338
+ this.eventBridgeCounter = 0
339
+ }
340
+ }
341
+
342
+ /**
343
+ * Global Lambda destinations manager instance
344
+ */
345
+ export const lambdaDestinationsManager: LambdaDestinationsManager = new LambdaDestinationsManager()