@stacksjs/ts-cloud 0.1.9 → 0.1.14

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 (150) hide show
  1. package/README.md +39 -377
  2. package/dist/bin/cli.js +1047 -424
  3. package/dist/index.d.ts +36 -3
  4. package/dist/index.js +76430 -7096
  5. package/package.json +7 -8
  6. package/dist/aws/acm.d.ts +0 -129
  7. package/dist/aws/application-autoscaling.d.ts +0 -282
  8. package/dist/aws/bedrock.d.ts +0 -2292
  9. package/dist/aws/client.d.ts +0 -79
  10. package/dist/aws/cloudformation.d.ts +0 -105
  11. package/dist/aws/cloudfront.d.ts +0 -265
  12. package/dist/aws/cloudwatch-logs.d.ts +0 -48
  13. package/dist/aws/comprehend.d.ts +0 -505
  14. package/dist/aws/connect.d.ts +0 -377
  15. package/dist/aws/deploy-imap.d.ts +0 -14
  16. package/dist/aws/dynamodb.d.ts +0 -176
  17. package/dist/aws/ec2.d.ts +0 -272
  18. package/dist/aws/ecr.d.ts +0 -149
  19. package/dist/aws/ecs.d.ts +0 -162
  20. package/dist/aws/elasticache.d.ts +0 -71
  21. package/dist/aws/elbv2.d.ts +0 -248
  22. package/dist/aws/email.d.ts +0 -175
  23. package/dist/aws/eventbridge.d.ts +0 -142
  24. package/dist/aws/iam.d.ts +0 -638
  25. package/dist/aws/imap-server.d.ts +0 -119
  26. package/dist/aws/index.d.ts +0 -192
  27. package/dist/aws/kendra.d.ts +0 -782
  28. package/dist/aws/lambda.d.ts +0 -232
  29. package/dist/aws/opensearch.d.ts +0 -87
  30. package/dist/aws/personalize.d.ts +0 -516
  31. package/dist/aws/polly.d.ts +0 -214
  32. package/dist/aws/rds.d.ts +0 -240
  33. package/dist/aws/rekognition.d.ts +0 -543
  34. package/dist/aws/route53-domains.d.ts +0 -113
  35. package/dist/aws/route53.d.ts +0 -215
  36. package/dist/aws/s3.d.ts +0 -212
  37. package/dist/aws/scheduler.d.ts +0 -140
  38. package/dist/aws/secrets-manager.d.ts +0 -170
  39. package/dist/aws/ses.d.ts +0 -288
  40. package/dist/aws/setup-phone.d.ts +0 -0
  41. package/dist/aws/setup-sms.d.ts +0 -115
  42. package/dist/aws/sms.d.ts +0 -304
  43. package/dist/aws/smtp-server.d.ts +0 -61
  44. package/dist/aws/sns.d.ts +0 -117
  45. package/dist/aws/sqs.d.ts +0 -65
  46. package/dist/aws/ssm.d.ts +0 -179
  47. package/dist/aws/sts.d.ts +0 -15
  48. package/dist/aws/support.d.ts +0 -104
  49. package/dist/aws/test-imap.d.ts +0 -0
  50. package/dist/aws/textract.d.ts +0 -403
  51. package/dist/aws/transcribe.d.ts +0 -60
  52. package/dist/aws/translate.d.ts +0 -358
  53. package/dist/aws/voice.d.ts +0 -219
  54. package/dist/config.d.ts +0 -7
  55. package/dist/deploy/index.d.ts +0 -2
  56. package/dist/deploy/static-site-external-dns.d.ts +0 -51
  57. package/dist/deploy/static-site.d.ts +0 -71
  58. package/dist/dns/cloudflare.d.ts +0 -52
  59. package/dist/dns/godaddy.d.ts +0 -38
  60. package/dist/dns/index.d.ts +0 -45
  61. package/dist/dns/porkbun.d.ts +0 -18
  62. package/dist/dns/route53-adapter.d.ts +0 -38
  63. package/dist/dns/types.d.ts +0 -77
  64. package/dist/dns/validator.d.ts +0 -78
  65. package/dist/generators/index.d.ts +0 -1
  66. package/dist/generators/infrastructure.d.ts +0 -30
  67. package/dist/push/apns.d.ts +0 -60
  68. package/dist/push/fcm.d.ts +0 -117
  69. package/dist/push/index.d.ts +0 -14
  70. package/dist/security/pre-deploy-scanner.d.ts +0 -69
  71. package/dist/ssl/acme-client.d.ts +0 -67
  72. package/dist/ssl/index.d.ts +0 -2
  73. package/dist/ssl/letsencrypt.d.ts +0 -48
  74. package/dist/types.d.ts +0 -1
  75. package/dist/utils/cli.d.ts +0 -123
  76. package/dist/validation/index.d.ts +0 -1
  77. package/dist/validation/template.d.ts +0 -23
  78. package/src/aws/acm.ts +0 -768
  79. package/src/aws/application-autoscaling.ts +0 -845
  80. package/src/aws/bedrock.ts +0 -4074
  81. package/src/aws/client.ts +0 -891
  82. package/src/aws/cloudformation.ts +0 -896
  83. package/src/aws/cloudfront.ts +0 -1531
  84. package/src/aws/cloudwatch-logs.ts +0 -154
  85. package/src/aws/comprehend.ts +0 -839
  86. package/src/aws/connect.ts +0 -1056
  87. package/src/aws/deploy-imap.ts +0 -384
  88. package/src/aws/dynamodb.ts +0 -340
  89. package/src/aws/ec2.ts +0 -1385
  90. package/src/aws/ecr.ts +0 -621
  91. package/src/aws/ecs.ts +0 -615
  92. package/src/aws/elasticache.ts +0 -301
  93. package/src/aws/elbv2.ts +0 -942
  94. package/src/aws/email.ts +0 -928
  95. package/src/aws/eventbridge.ts +0 -248
  96. package/src/aws/iam.ts +0 -1689
  97. package/src/aws/imap-server.ts +0 -2100
  98. package/src/aws/index.ts +0 -213
  99. package/src/aws/kendra.ts +0 -1097
  100. package/src/aws/lambda.ts +0 -786
  101. package/src/aws/opensearch.ts +0 -158
  102. package/src/aws/personalize.ts +0 -977
  103. package/src/aws/polly.ts +0 -559
  104. package/src/aws/rds.ts +0 -888
  105. package/src/aws/rekognition.ts +0 -846
  106. package/src/aws/route53-domains.ts +0 -359
  107. package/src/aws/route53.ts +0 -1046
  108. package/src/aws/s3.ts +0 -2334
  109. package/src/aws/scheduler.ts +0 -571
  110. package/src/aws/secrets-manager.ts +0 -769
  111. package/src/aws/ses.ts +0 -1081
  112. package/src/aws/setup-phone.ts +0 -104
  113. package/src/aws/setup-sms.ts +0 -580
  114. package/src/aws/sms.ts +0 -1735
  115. package/src/aws/smtp-server.ts +0 -531
  116. package/src/aws/sns.ts +0 -758
  117. package/src/aws/sqs.ts +0 -382
  118. package/src/aws/ssm.ts +0 -807
  119. package/src/aws/sts.ts +0 -92
  120. package/src/aws/support.ts +0 -391
  121. package/src/aws/test-imap.ts +0 -86
  122. package/src/aws/textract.ts +0 -780
  123. package/src/aws/transcribe.ts +0 -108
  124. package/src/aws/translate.ts +0 -641
  125. package/src/aws/voice.ts +0 -1379
  126. package/src/config.ts +0 -35
  127. package/src/deploy/index.ts +0 -7
  128. package/src/deploy/static-site-external-dns.ts +0 -945
  129. package/src/deploy/static-site.ts +0 -1175
  130. package/src/dns/cloudflare.ts +0 -548
  131. package/src/dns/godaddy.ts +0 -412
  132. package/src/dns/index.ts +0 -205
  133. package/src/dns/porkbun.ts +0 -362
  134. package/src/dns/route53-adapter.ts +0 -414
  135. package/src/dns/types.ts +0 -119
  136. package/src/dns/validator.ts +0 -369
  137. package/src/generators/index.ts +0 -5
  138. package/src/generators/infrastructure.ts +0 -1660
  139. package/src/index.ts +0 -163
  140. package/src/push/apns.ts +0 -452
  141. package/src/push/fcm.ts +0 -506
  142. package/src/push/index.ts +0 -58
  143. package/src/security/pre-deploy-scanner.ts +0 -655
  144. package/src/ssl/acme-client.ts +0 -478
  145. package/src/ssl/index.ts +0 -7
  146. package/src/ssl/letsencrypt.ts +0 -747
  147. package/src/types.ts +0 -2
  148. package/src/utils/cli.ts +0 -398
  149. package/src/validation/index.ts +0 -5
  150. package/src/validation/template.ts +0 -405
@@ -1,369 +0,0 @@
1
- /**
2
- * Unified DNS Validator for ACM Certificates
3
- * Works with any DNS provider (Route53, Porkbun, GoDaddy, etc.)
4
- */
5
-
6
- import { ACMClient } from '../aws/acm'
7
- import type { DnsProvider, DnsProviderConfig } from './types'
8
- import { createDnsProvider } from './index'
9
-
10
- export interface ValidationRecord {
11
- domainName: string
12
- recordName: string
13
- recordType: string
14
- recordValue: string
15
- }
16
-
17
- export interface CertificateValidationResult {
18
- certificateArn: string
19
- validationRecords: ValidationRecord[]
20
- isNew: boolean
21
- status: 'pending' | 'issued' | 'failed'
22
- }
23
-
24
- /**
25
- * Unified DNS Validator
26
- * Handles ACM certificate validation with any DNS provider
27
- */
28
- export class UnifiedDnsValidator {
29
- private acm: ACMClient
30
- private dnsProvider: DnsProvider
31
-
32
- constructor(
33
- dnsProvider: DnsProvider | DnsProviderConfig,
34
- acmRegion: string = 'us-east-1',
35
- ) {
36
- this.acm = new ACMClient(acmRegion)
37
-
38
- if ('provider' in dnsProvider) {
39
- this.dnsProvider = createDnsProvider(dnsProvider)
40
- }
41
- else {
42
- this.dnsProvider = dnsProvider
43
- }
44
- }
45
-
46
- /**
47
- * Get the DNS provider being used
48
- */
49
- getProvider(): DnsProvider {
50
- return this.dnsProvider
51
- }
52
-
53
- /**
54
- * Request a certificate and create DNS validation records
55
- */
56
- async requestAndValidate(params: {
57
- domainName: string
58
- subjectAlternativeNames?: string[]
59
- waitForValidation?: boolean
60
- maxWaitMinutes?: number
61
- }): Promise<CertificateValidationResult> {
62
- const {
63
- domainName,
64
- subjectAlternativeNames = [],
65
- waitForValidation = false,
66
- maxWaitMinutes = 30,
67
- } = params
68
-
69
- // Request certificate from ACM
70
- const { CertificateArn } = await this.acm.requestCertificate({
71
- DomainName: domainName,
72
- SubjectAlternativeNames: subjectAlternativeNames.length > 0
73
- ? [domainName, ...subjectAlternativeNames]
74
- : undefined,
75
- ValidationMethod: 'DNS',
76
- })
77
-
78
- // Wait for validation options to be available
79
- await this.waitForValidationOptions(CertificateArn)
80
-
81
- // Get DNS validation records
82
- const validationRecords = await this.acm.getDnsValidationRecords(CertificateArn)
83
-
84
- // Create DNS records using the configured provider
85
- for (const record of validationRecords) {
86
- const result = await this.dnsProvider.upsertRecord(domainName, {
87
- name: record.recordName,
88
- type: record.recordType as any,
89
- content: record.recordValue,
90
- ttl: 300,
91
- })
92
-
93
- if (!result.success) {
94
- console.warn(`Failed to create validation record for ${record.domainName}: ${result.message}`)
95
- }
96
- }
97
-
98
- // Wait for certificate validation if requested
99
- let status: 'pending' | 'issued' | 'failed' = 'pending'
100
-
101
- if (waitForValidation) {
102
- const cert = await this.acm.waitForCertificateValidation(
103
- CertificateArn,
104
- maxWaitMinutes * 2,
105
- 30000,
106
- )
107
-
108
- status = cert?.Status === 'ISSUED' ? 'issued' : 'failed'
109
- }
110
-
111
- return {
112
- certificateArn: CertificateArn,
113
- validationRecords: validationRecords.map(r => ({
114
- domainName: r.domainName,
115
- recordName: r.recordName,
116
- recordType: r.recordType,
117
- recordValue: r.recordValue,
118
- })),
119
- isNew: true,
120
- status,
121
- }
122
- }
123
-
124
- /**
125
- * Create validation records for an existing certificate
126
- */
127
- async createValidationRecords(params: {
128
- certificateArn: string
129
- domain: string
130
- }): Promise<{
131
- success: boolean
132
- records: ValidationRecord[]
133
- errors: string[]
134
- }> {
135
- const { certificateArn, domain } = params
136
- const errors: string[] = []
137
-
138
- // Get validation records from ACM
139
- const validationRecords = await this.acm.getDnsValidationRecords(certificateArn)
140
-
141
- // Create DNS records
142
- for (const record of validationRecords) {
143
- const result = await this.dnsProvider.upsertRecord(domain, {
144
- name: record.recordName,
145
- type: record.recordType as any,
146
- content: record.recordValue,
147
- ttl: 300,
148
- })
149
-
150
- if (!result.success) {
151
- errors.push(`Failed to create record for ${record.domainName}: ${result.message}`)
152
- }
153
- }
154
-
155
- return {
156
- success: errors.length === 0,
157
- records: validationRecords.map(r => ({
158
- domainName: r.domainName,
159
- recordName: r.recordName,
160
- recordType: r.recordType,
161
- recordValue: r.recordValue,
162
- })),
163
- errors,
164
- }
165
- }
166
-
167
- /**
168
- * Delete validation records (cleanup after certificate is issued)
169
- */
170
- async deleteValidationRecords(params: {
171
- certificateArn: string
172
- domain: string
173
- }): Promise<{
174
- success: boolean
175
- errors: string[]
176
- }> {
177
- const { certificateArn, domain } = params
178
- const errors: string[] = []
179
-
180
- // Get validation records from ACM
181
- const validationRecords = await this.acm.getDnsValidationRecords(certificateArn)
182
-
183
- // Delete DNS records
184
- for (const record of validationRecords) {
185
- const result = await this.dnsProvider.deleteRecord(domain, {
186
- name: record.recordName,
187
- type: record.recordType as any,
188
- content: record.recordValue,
189
- })
190
-
191
- if (!result.success) {
192
- errors.push(`Failed to delete record for ${record.domainName}: ${result.message}`)
193
- }
194
- }
195
-
196
- return {
197
- success: errors.length === 0,
198
- errors,
199
- }
200
- }
201
-
202
- /**
203
- * Find or create a certificate for a domain
204
- */
205
- async findOrCreateCertificate(params: {
206
- domainName: string
207
- subjectAlternativeNames?: string[]
208
- waitForValidation?: boolean
209
- maxWaitMinutes?: number
210
- }): Promise<CertificateValidationResult> {
211
- const { domainName, subjectAlternativeNames = [], waitForValidation = true, maxWaitMinutes } = params
212
-
213
- // Try to find existing certificate
214
- const existing = await this.acm.findCertificateByDomain(domainName)
215
-
216
- if (existing && existing.Status === 'ISSUED') {
217
- // Check if the existing certificate covers all required SANs
218
- const existingSans = existing.SubjectAlternativeNames || [existing.DomainName]
219
- const hasWildcard = existingSans.some(san => san === `*.${domainName}`)
220
- const allSansCovered = subjectAlternativeNames.every(san =>
221
- existingSans.includes(san) || hasWildcard,
222
- )
223
-
224
- if (allSansCovered) {
225
- return {
226
- certificateArn: existing.CertificateArn,
227
- validationRecords: [],
228
- isNew: false,
229
- status: 'issued',
230
- }
231
- }
232
- // Existing cert doesn't cover all SANs, request a new one
233
- console.log(`Existing certificate doesn't cover all required SANs, requesting new certificate...`)
234
- }
235
-
236
- // Request new certificate
237
- return this.requestAndValidate({
238
- domainName,
239
- subjectAlternativeNames,
240
- waitForValidation,
241
- maxWaitMinutes,
242
- })
243
- }
244
-
245
- /**
246
- * Request certificate with common SANs (www and wildcard)
247
- */
248
- async requestCertificateWithCommonSans(params: {
249
- domainName: string
250
- includeWww?: boolean
251
- includeWildcard?: boolean
252
- additionalSans?: string[]
253
- waitForValidation?: boolean
254
- }): Promise<CertificateValidationResult> {
255
- const {
256
- domainName,
257
- includeWww = true,
258
- includeWildcard = false,
259
- additionalSans = [],
260
- waitForValidation = false,
261
- } = params
262
-
263
- const sans: string[] = []
264
-
265
- if (includeWww) {
266
- sans.push(`www.${domainName}`)
267
- }
268
-
269
- if (includeWildcard) {
270
- sans.push(`*.${domainName}`)
271
- }
272
-
273
- sans.push(...additionalSans)
274
-
275
- return this.requestAndValidate({
276
- domainName,
277
- subjectAlternativeNames: sans,
278
- waitForValidation,
279
- })
280
- }
281
-
282
- /**
283
- * Wait for validation options to become available
284
- */
285
- private async waitForValidationOptions(
286
- certificateArn: string,
287
- maxAttempts = 30,
288
- ): Promise<void> {
289
- for (let i = 0; i < maxAttempts; i++) {
290
- const cert = await this.acm.describeCertificate({ CertificateArn: certificateArn })
291
-
292
- if (
293
- cert.DomainValidationOptions
294
- && cert.DomainValidationOptions.length > 0
295
- && cert.DomainValidationOptions[0].ResourceRecord
296
- ) {
297
- return
298
- }
299
-
300
- await new Promise(resolve => setTimeout(resolve, 2000))
301
- }
302
-
303
- throw new Error('Timeout waiting for DNS validation options')
304
- }
305
-
306
- /**
307
- * Get the status of a certificate
308
- */
309
- async getCertificateStatus(certificateArn: string): Promise<{
310
- status: string
311
- domainValidations: Array<{
312
- domain: string
313
- status: string
314
- }>
315
- }> {
316
- const cert = await this.acm.describeCertificate({ CertificateArn: certificateArn })
317
-
318
- return {
319
- status: cert.Status,
320
- domainValidations: (cert.DomainValidationOptions || []).map(opt => ({
321
- domain: opt.DomainName,
322
- status: opt.ValidationStatus || 'UNKNOWN',
323
- })),
324
- }
325
- }
326
- }
327
-
328
- /**
329
- * Helper function to create a validator with Porkbun
330
- */
331
- export function createPorkbunValidator(
332
- apiKey: string,
333
- secretKey: string,
334
- acmRegion?: string,
335
- ): UnifiedDnsValidator {
336
- return new UnifiedDnsValidator(
337
- { provider: 'porkbun', apiKey, secretKey },
338
- acmRegion,
339
- )
340
- }
341
-
342
- /**
343
- * Helper function to create a validator with GoDaddy
344
- */
345
- export function createGoDaddyValidator(
346
- apiKey: string,
347
- apiSecret: string,
348
- acmRegion?: string,
349
- environment?: 'production' | 'ote',
350
- ): UnifiedDnsValidator {
351
- return new UnifiedDnsValidator(
352
- { provider: 'godaddy', apiKey, apiSecret, environment },
353
- acmRegion,
354
- )
355
- }
356
-
357
- /**
358
- * Helper function to create a validator with Route53
359
- */
360
- export function createRoute53Validator(
361
- region?: string,
362
- hostedZoneId?: string,
363
- acmRegion?: string,
364
- ): UnifiedDnsValidator {
365
- return new UnifiedDnsValidator(
366
- { provider: 'route53', region, hostedZoneId },
367
- acmRegion || region,
368
- )
369
- }
@@ -1,5 +0,0 @@
1
- /**
2
- * Infrastructure Generators
3
- */
4
-
5
- export * from './infrastructure'